zookeeperStarted.html 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <head>
  4. <META http-equiv="Content-Type" content="text/html; charset=UTF-8">
  5. <meta content="Apache Forrest" name="Generator">
  6. <meta name="Forrest-version" content="0.9">
  7. <meta name="Forrest-skin-name" content="pelt">
  8. <title>ZooKeeper Getting Started Guide</title>
  9. <link type="text/css" href="skin/basic.css" rel="stylesheet">
  10. <link media="screen" type="text/css" href="skin/screen.css" rel="stylesheet">
  11. <link media="print" type="text/css" href="skin/print.css" rel="stylesheet">
  12. <link type="text/css" href="skin/profile.css" rel="stylesheet">
  13. <script src="skin/getBlank.js" language="javascript" type="text/javascript"></script><script src="skin/getMenu.js" language="javascript" type="text/javascript"></script><script src="skin/fontsize.js" language="javascript" type="text/javascript"></script>
  14. <link rel="shortcut icon" href="images/favicon.ico">
  15. </head>
  16. <body onload="init()">
  17. <script type="text/javascript">ndeSetTextSize();</script>
  18. <div id="top">
  19. <!--+
  20. |breadtrail
  21. +-->
  22. <div class="breadtrail">
  23. <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://zookeeper.apache.org/">ZooKeeper</a> &gt; <a href="http://zookeeper.apache.org/">ZooKeeper</a><script src="skin/breadcrumbs.js" language="JavaScript" type="text/javascript"></script>
  24. </div>
  25. <!--+
  26. |header
  27. +-->
  28. <div class="header">
  29. <!--+
  30. |start group logo
  31. +-->
  32. <div class="grouplogo">
  33. <a href="http://hadoop.apache.org/"><img class="logoImage" alt="Hadoop" src="images/hadoop-logo.jpg" title="Apache Hadoop"></a>
  34. </div>
  35. <!--+
  36. |end group logo
  37. +-->
  38. <!--+
  39. |start Project Logo
  40. +-->
  41. <div class="projectlogo">
  42. <a href="http://zookeeper.apache.org/"><img class="logoImage" alt="ZooKeeper" src="images/zookeeper_small.gif" title="ZooKeeper: distributed coordination"></a>
  43. </div>
  44. <!--+
  45. |end Project Logo
  46. +-->
  47. <!--+
  48. |start Search
  49. +-->
  50. <div class="searchbox">
  51. <form action="http://www.google.com/search" method="get" class="roundtopsmall">
  52. <input value="zookeeper.apache.org" name="sitesearch" type="hidden"><input onFocus="getBlank (this, 'Search the site with google');" size="25" name="q" id="query" type="text" value="Search the site with google">&nbsp;
  53. <input name="Search" value="Search" type="submit">
  54. </form>
  55. </div>
  56. <!--+
  57. |end search
  58. +-->
  59. <!--+
  60. |start Tabs
  61. +-->
  62. <ul id="tabs">
  63. <li>
  64. <a class="unselected" href="http://zookeeper.apache.org/">Project</a>
  65. </li>
  66. <li>
  67. <a class="unselected" href="https://cwiki.apache.org/confluence/display/ZOOKEEPER/">Wiki</a>
  68. </li>
  69. <li class="current">
  70. <a class="selected" href="index.html">ZooKeeper 3.4 Documentation</a>
  71. </li>
  72. </ul>
  73. <!--+
  74. |end Tabs
  75. +-->
  76. </div>
  77. </div>
  78. <div id="main">
  79. <div id="publishedStrip">
  80. <!--+
  81. |start Subtabs
  82. +-->
  83. <div id="level2tabs"></div>
  84. <!--+
  85. |end Endtabs
  86. +-->
  87. <script type="text/javascript"><!--
  88. document.write("Last Published: " + document.lastModified);
  89. // --></script>
  90. </div>
  91. <!--+
  92. |breadtrail
  93. +-->
  94. <div class="breadtrail">
  95. &nbsp;
  96. </div>
  97. <!--+
  98. |start Menu, mainarea
  99. +-->
  100. <!--+
  101. |start Menu
  102. +-->
  103. <div id="menu">
  104. <div onclick="SwitchMenu('menu_selected_1.1', 'skin/')" id="menu_selected_1.1Title" class="menutitle" style="background-image: url('skin/images/chapter_open.gif');">Overview</div>
  105. <div id="menu_selected_1.1" class="selectedmenuitemgroup" style="display: block;">
  106. <div class="menuitem">
  107. <a href="index.html">Welcome</a>
  108. </div>
  109. <div class="menuitem">
  110. <a href="zookeeperOver.html">Overview</a>
  111. </div>
  112. <div class="menupage">
  113. <div class="menupagetitle">Getting Started</div>
  114. </div>
  115. <div class="menuitem">
  116. <a href="releasenotes.html">Release Notes</a>
  117. </div>
  118. </div>
  119. <div onclick="SwitchMenu('menu_1.2', 'skin/')" id="menu_1.2Title" class="menutitle">Developer</div>
  120. <div id="menu_1.2" class="menuitemgroup">
  121. <div class="menuitem">
  122. <a href="api/index.html">API Docs</a>
  123. </div>
  124. <div class="menuitem">
  125. <a href="zookeeperProgrammers.html">Programmer's Guide</a>
  126. </div>
  127. <div class="menuitem">
  128. <a href="javaExample.html">Java Example</a>
  129. </div>
  130. <div class="menuitem">
  131. <a href="zookeeperTutorial.html">Barrier and Queue Tutorial</a>
  132. </div>
  133. <div class="menuitem">
  134. <a href="recipes.html">Recipes</a>
  135. </div>
  136. </div>
  137. <div onclick="SwitchMenu('menu_1.3', 'skin/')" id="menu_1.3Title" class="menutitle">Admin &amp; Ops</div>
  138. <div id="menu_1.3" class="menuitemgroup">
  139. <div class="menuitem">
  140. <a href="zookeeperAdmin.html">Administrator's Guide</a>
  141. </div>
  142. <div class="menuitem">
  143. <a href="zookeeperQuotas.html">Quota Guide</a>
  144. </div>
  145. <div class="menuitem">
  146. <a href="zookeeperJMX.html">JMX</a>
  147. </div>
  148. <div class="menuitem">
  149. <a href="zookeeperObservers.html">Observers Guide</a>
  150. </div>
  151. <div class="menuitem">
  152. <a href="zookeeperReconfig.html">Dynamic Reconfiguration</a>
  153. </div>
  154. </div>
  155. <div onclick="SwitchMenu('menu_1.4', 'skin/')" id="menu_1.4Title" class="menutitle">Contributor</div>
  156. <div id="menu_1.4" class="menuitemgroup">
  157. <div class="menuitem">
  158. <a href="zookeeperInternals.html">ZooKeeper Internals</a>
  159. </div>
  160. </div>
  161. <div onclick="SwitchMenu('menu_1.5', 'skin/')" id="menu_1.5Title" class="menutitle">Miscellaneous</div>
  162. <div id="menu_1.5" class="menuitemgroup">
  163. <div class="menuitem">
  164. <a href="https://cwiki.apache.org/confluence/display/ZOOKEEPER">Wiki</a>
  165. </div>
  166. <div class="menuitem">
  167. <a href="https://cwiki.apache.org/confluence/display/ZOOKEEPER/FAQ">FAQ</a>
  168. </div>
  169. <div class="menuitem">
  170. <a href="http://zookeeper.apache.org/mailing_lists.html">Mailing Lists</a>
  171. </div>
  172. </div>
  173. <div id="credit"></div>
  174. <div id="roundbottom">
  175. <img style="display: none" class="corner" height="15" width="15" alt="" src="skin/images/rc-b-l-15-1body-2menu-3menu.png"></div>
  176. <!--+
  177. |alternative credits
  178. +-->
  179. <div id="credit2"></div>
  180. </div>
  181. <!--+
  182. |end Menu
  183. +-->
  184. <!--+
  185. |start content
  186. +-->
  187. <div id="content">
  188. <div title="Portable Document Format" class="pdflink">
  189. <a class="dida" href="zookeeperStarted.pdf"><img alt="PDF -icon" src="skin/images/pdfdoc.gif" class="skin"><br>
  190. PDF</a>
  191. </div>
  192. <h1>ZooKeeper Getting Started Guide</h1>
  193. <div id="front-matter">
  194. <div id="minitoc-area">
  195. <ul class="minitoc">
  196. <li>
  197. <a href="#ch_GettingStarted">Getting Started: Coordinating Distributed Applications with
  198. ZooKeeper</a>
  199. <ul class="minitoc">
  200. <li>
  201. <a href="#sc_Prerequisites">Pre-requisites</a>
  202. </li>
  203. <li>
  204. <a href="#sc_Download">Download</a>
  205. </li>
  206. <li>
  207. <a href="#sc_InstallingSingleMode">Standalone Operation</a>
  208. </li>
  209. <li>
  210. <a href="#sc_FileManagement">Managing ZooKeeper Storage</a>
  211. </li>
  212. <li>
  213. <a href="#sc_ConnectingToZooKeeper">Connecting to ZooKeeper</a>
  214. </li>
  215. <li>
  216. <a href="#sc_ProgrammingToZooKeeper">Programming to ZooKeeper</a>
  217. </li>
  218. <li>
  219. <a href="#sc_RunningReplicatedZooKeeper">Running Replicated ZooKeeper</a>
  220. </li>
  221. <li>
  222. <a href="#Other+Optimizations">Other Optimizations</a>
  223. </li>
  224. </ul>
  225. </li>
  226. </ul>
  227. </div>
  228. </div>
  229. <a name="ch_GettingStarted"></a>
  230. <h2 class="h3">Getting Started: Coordinating Distributed Applications with
  231. ZooKeeper</h2>
  232. <div class="section">
  233. <p>This document contains information to get you started quickly with
  234. ZooKeeper. It is aimed primarily at developers hoping to try it out, and
  235. contains simple installation instructions for a single ZooKeeper server, a
  236. few commands to verify that it is running, and a simple programming
  237. example. Finally, as a convenience, there are a few sections regarding
  238. more complicated installations, for example running replicated
  239. deployments, and optimizing the transaction log. However for the complete
  240. instructions for commercial deployments, please refer to the <a href="zookeeperAdmin.html">ZooKeeper
  241. Administrator's Guide</a>.</p>
  242. <a name="sc_Prerequisites"></a>
  243. <h3 class="h4">Pre-requisites</h3>
  244. <p>See <a href="zookeeperAdmin.html#sc_systemReq">
  245. System Requirements</a> in the Admin guide.</p>
  246. <a name="sc_Download"></a>
  247. <h3 class="h4">Download</h3>
  248. <p>To get a ZooKeeper distribution, download a recent
  249. <a href="http://zookeeper.apache.org/releases.html">
  250. stable</a> release from one of the Apache Download
  251. Mirrors.</p>
  252. <a name="sc_InstallingSingleMode"></a>
  253. <h3 class="h4">Standalone Operation</h3>
  254. <p>Setting up a ZooKeeper server in standalone mode is
  255. straightforward. The server is contained in a single JAR file,
  256. so installation consists of creating a configuration.</p>
  257. <p>Once you've downloaded a stable ZooKeeper release unpack
  258. it and cd to the root</p>
  259. <p>To start ZooKeeper you need a configuration file. Here is a sample,
  260. create it in <strong>conf/zoo.cfg</strong>:</p>
  261. <pre class="code">
  262. tickTime=2000
  263. dataDir=/var/lib/zookeeper
  264. clientPort=2181
  265. </pre>
  266. <p>This file can be called anything, but for the sake of this
  267. discussion call
  268. it <strong>conf/zoo.cfg</strong>. Change the
  269. value of <strong>dataDir</strong> to specify an
  270. existing (empty to start with) directory. Here are the meanings
  271. for each of the fields:</p>
  272. <dl>
  273. <dt>
  274. <term>
  275. <strong>tickTime</strong>
  276. </term>
  277. </dt>
  278. <dd>
  279. <p>the basic time unit in milliseconds used by ZooKeeper. It is
  280. used to do heartbeats and the minimum session timeout will be
  281. twice the tickTime.</p>
  282. </dd>
  283. </dl>
  284. <dl>
  285. <dt>
  286. <term>
  287. <strong>dataDir</strong>
  288. </term>
  289. </dt>
  290. <dd>
  291. <p>the location to store the in-memory database snapshots and,
  292. unless specified otherwise, the transaction log of updates to the
  293. database.</p>
  294. </dd>
  295. <dt>
  296. <term>
  297. <strong>clientPort</strong>
  298. </term>
  299. </dt>
  300. <dd>
  301. <p>the port to listen for client connections</p>
  302. </dd>
  303. </dl>
  304. <p>Now that you created the configuration file, you can start
  305. ZooKeeper:</p>
  306. <pre class="code">bin/zkServer.sh start</pre>
  307. <p>ZooKeeper logs messages using log4j -- more detail
  308. available in the
  309. <a href="zookeeperProgrammers.html#Logging">Logging</a>
  310. section of the Programmer's Guide. You will see log messages
  311. coming to the console (default) and/or a log file depending on
  312. the log4j configuration.</p>
  313. <p>The steps outlined here run ZooKeeper in standalone mode. There is
  314. no replication, so if ZooKeeper process fails, the service will go down.
  315. This is fine for most development situations, but to run ZooKeeper in
  316. replicated mode, please see <a href="#sc_RunningReplicatedZooKeeper">Running Replicated
  317. ZooKeeper</a>.</p>
  318. <a name="sc_FileManagement"></a>
  319. <h3 class="h4">Managing ZooKeeper Storage</h3>
  320. <p>For long running production systems ZooKeeper storage must
  321. be managed externally (dataDir and logs). See the section on
  322. <a href="zookeeperAdmin.html#sc_maintenance">maintenance</a> for
  323. more details.</p>
  324. <a name="sc_ConnectingToZooKeeper"></a>
  325. <h3 class="h4">Connecting to ZooKeeper</h3>
  326. <pre class="code">$ bin/zkCli.sh -server 127.0.0.1:2181</pre>
  327. <p>This lets you perform simple, file-like operations.</p>
  328. <p>Once you have connected, you should see something like:
  329. </p>
  330. <pre class="code">
  331. Connecting to localhost:2181
  332. log4j:WARN No appenders could be found for logger (org.apache.zookeeper.ZooKeeper).
  333. log4j:WARN Please initialize the log4j system properly.
  334. Welcome to ZooKeeper!
  335. JLine support is enabled
  336. [zkshell: 0]
  337. </pre>
  338. <p>
  339. From the shell, type <span class="codefrag command">help</span> to get a listing of commands that can be executed from the client, as in:
  340. </p>
  341. <pre class="code">
  342. [zkshell: 0] help
  343. ZooKeeper host:port cmd args
  344. get path [watch]
  345. ls path [watch]
  346. set path data [version]
  347. delquota [-n|-b] path
  348. quit
  349. printwatches on|off
  350. create path data acl
  351. stat path [watch]
  352. listquota path
  353. history
  354. setAcl path acl
  355. getAcl path
  356. sync path
  357. redo cmdno
  358. addauth scheme auth
  359. delete path [version]
  360. deleteall path
  361. setquota -n|-b val path
  362. </pre>
  363. <p>From here, you can try a few simple commands to get a feel for this simple command line interface. First, start by issuing the list command, as
  364. in <span class="codefrag command">ls</span>, yielding:
  365. </p>
  366. <pre class="code">
  367. [zkshell: 8] ls /
  368. [zookeeper]
  369. </pre>
  370. <p>Next, create a new znode by running <span class="codefrag command">create /zk_test my_data</span>. This creates a new znode and associates the string "my_data" with the node.
  371. You should see:</p>
  372. <pre class="code">
  373. [zkshell: 9] create /zk_test my_data
  374. Created /zk_test
  375. </pre>
  376. <p> Issue another <span class="codefrag command">ls /</span> command to see what the directory looks like:
  377. </p>
  378. <pre class="code">
  379. [zkshell: 11] ls /
  380. [zookeeper, zk_test]
  381. </pre>
  382. <p>
  383. Notice that the zk_test directory has now been created.
  384. </p>
  385. <p>Next, verify that the data was associated with the znode by running the <span class="codefrag command">get</span> command, as in:
  386. </p>
  387. <pre class="code">
  388. [zkshell: 12] get /zk_test
  389. my_data
  390. cZxid = 5
  391. ctime = Fri Jun 05 13:57:06 PDT 2009
  392. mZxid = 5
  393. mtime = Fri Jun 05 13:57:06 PDT 2009
  394. pZxid = 5
  395. cversion = 0
  396. dataVersion = 0
  397. aclVersion = 0
  398. ephemeralOwner = 0
  399. dataLength = 7
  400. numChildren = 0
  401. </pre>
  402. <p>We can change the data associated with zk_test by issuing the <span class="codefrag command">set</span> command, as in:
  403. </p>
  404. <pre class="code">
  405. [zkshell: 14] set /zk_test junk
  406. cZxid = 5
  407. ctime = Fri Jun 05 13:57:06 PDT 2009
  408. mZxid = 6
  409. mtime = Fri Jun 05 14:01:52 PDT 2009
  410. pZxid = 5
  411. cversion = 0
  412. dataVersion = 1
  413. aclVersion = 0
  414. ephemeralOwner = 0
  415. dataLength = 4
  416. numChildren = 0
  417. [zkshell: 15] get /zk_test
  418. junk
  419. cZxid = 5
  420. ctime = Fri Jun 05 13:57:06 PDT 2009
  421. mZxid = 6
  422. mtime = Fri Jun 05 14:01:52 PDT 2009
  423. pZxid = 5
  424. cversion = 0
  425. dataVersion = 1
  426. aclVersion = 0
  427. ephemeralOwner = 0
  428. dataLength = 4
  429. numChildren = 0
  430. </pre>
  431. <p>
  432. (Notice we did a <span class="codefrag command">get</span> after setting the data and it did, indeed, change.</p>
  433. <p>Finally, let's <span class="codefrag command">delete</span> the node by issuing:
  434. </p>
  435. <pre class="code">
  436. [zkshell: 16] delete /zk_test
  437. [zkshell: 17] ls /
  438. [zookeeper]
  439. [zkshell: 18]
  440. </pre>
  441. <p>That's it for now. To explore more, continue with the rest of this document and see the <a href="zookeeperProgrammers.html">Programmer's Guide</a>. </p>
  442. <a name="sc_ProgrammingToZooKeeper"></a>
  443. <h3 class="h4">Programming to ZooKeeper</h3>
  444. <p>ZooKeeper has a Java bindings and C bindings. They are
  445. functionally equivalent. The C bindings exist in two variants: single
  446. threaded and multi-threaded. These differ only in how the messaging loop
  447. is done. For more information, see the <a href="zookeeperProgrammers.html#ch_programStructureWithExample">Programming
  448. Examples in the ZooKeeper Programmer's Guide</a> for
  449. sample code using of the different APIs.</p>
  450. <a name="sc_RunningReplicatedZooKeeper"></a>
  451. <h3 class="h4">Running Replicated ZooKeeper</h3>
  452. <p>Running ZooKeeper in standalone mode is convenient for evaluation,
  453. some development, and testing. But in production, you should run
  454. ZooKeeper in replicated mode. A replicated group of servers in the same
  455. application is called a <em>quorum</em>, and in replicated
  456. mode, all servers in the quorum have copies of the same configuration
  457. file.</p>
  458. <div class="note">
  459. <div class="label">Note</div>
  460. <div class="content">
  461. <p>
  462. For replicated mode, a minimum of three servers are required,
  463. and it is strongly recommended that you have an odd number of
  464. servers. If you only have two servers, then you are in a
  465. situation where if one of them fails, there are not enough
  466. machines to form a majority quorum. Two servers is inherently
  467. <strong>less</strong>
  468. stable than a single server, because there are two single
  469. points of failure.
  470. </p>
  471. </div>
  472. </div>
  473. <p>
  474. The required
  475. <strong>conf/zoo.cfg</strong>
  476. file for replicated mode is similar to the one used in standalone
  477. mode, but with a few differences. Here is an example:
  478. </p>
  479. <pre class="code">
  480. tickTime=2000
  481. dataDir=/var/lib/zookeeper
  482. clientPort=2181
  483. initLimit=5
  484. syncLimit=2
  485. server.1=zoo1:2888:3888
  486. server.2=zoo2:2888:3888
  487. server.3=zoo3:2888:3888
  488. </pre>
  489. <p>The new entry, <strong>initLimit</strong> is
  490. timeouts ZooKeeper uses to limit the length of time the ZooKeeper
  491. servers in quorum have to connect to a leader. The entry <strong>syncLimit</strong> limits how far out of date a server can
  492. be from a leader.</p>
  493. <p>With both of these timeouts, you specify the unit of time using
  494. <strong>tickTime</strong>. In this example, the timeout
  495. for initLimit is 5 ticks at 2000 milleseconds a tick, or 10
  496. seconds.</p>
  497. <p>The entries of the form <em>server.X</em> list the
  498. servers that make up the ZooKeeper service. When the server starts up,
  499. it knows which server it is by looking for the file
  500. <em>myid</em> in the data directory. That file has the
  501. contains the server number, in ASCII.</p>
  502. <p>Finally, note the two port numbers after each server
  503. name: " 2888" and "3888". Peers use the former port to connect
  504. to other peers. Such a connection is necessary so that peers
  505. can communicate, for example, to agree upon the order of
  506. updates. More specifically, a ZooKeeper server uses this port
  507. to connect followers to the leader. When a new leader arises, a
  508. follower opens a TCP connection to the leader using this
  509. port. Because the default leader election also uses TCP, we
  510. currently require another port for leader election. This is the
  511. second port in the server entry.
  512. </p>
  513. <div class="note">
  514. <div class="label">Note</div>
  515. <div class="content">
  516. <p>If you want to test multiple servers on a single
  517. machine, specify the servername
  518. as <em>localhost</em> with unique quorum &amp;
  519. leader election ports (i.e. 2888:3888, 2889:3889, 2890:3890 in
  520. the example above) for each server.X in that server's config
  521. file. Of course separate <em>dataDir</em>s and
  522. distinct <em>clientPort</em>s are also necessary
  523. (in the above replicated example, running on a
  524. single <em>localhost</em>, you would still have
  525. three config files).</p>
  526. <p>Please be aware that setting up multiple servers on a single
  527. machine will not create any redundancy. If something were to
  528. happen which caused the machine to die, all of the zookeeper
  529. servers would be offline. Full redundancy requires that each
  530. server have its own machine. It must be a completely separate
  531. physical server. Multiple virtual machines on the same physical
  532. host are still vulnerable to the complete failure of that host.</p>
  533. </div>
  534. </div>
  535. <a name="Other+Optimizations"></a>
  536. <h3 class="h4">Other Optimizations</h3>
  537. <p>There are a couple of other configuration parameters that can
  538. greatly increase performance:</p>
  539. <ul>
  540. <li>
  541. <p>To get low latencies on updates it is important to
  542. have a dedicated transaction log directory. By default
  543. transaction logs are put in the same directory as the data
  544. snapshots and <em>myid</em> file. The dataLogDir
  545. parameters indicates a different directory to use for the
  546. transaction logs.</p>
  547. </li>
  548. <li>
  549. <p>
  550. <em>[tbd: what is the other config param?]</em>
  551. </p>
  552. </li>
  553. </ul>
  554. </div>
  555. <p align="right">
  556. <font size="-2"></font>
  557. </p>
  558. </div>
  559. <!--+
  560. |end content
  561. +-->
  562. <div class="clearboth">&nbsp;</div>
  563. </div>
  564. <div id="footer">
  565. <!--+
  566. |start bottomstrip
  567. +-->
  568. <div class="lastmodified">
  569. <script type="text/javascript"><!--
  570. document.write("Last Published: " + document.lastModified);
  571. // --></script>
  572. </div>
  573. <div class="copyright">
  574. Copyright &copy;
  575. 2008-2013 <a href="http://www.apache.org/licenses/">The Apache Software Foundation.</a>
  576. </div>
  577. <!--+
  578. |end bottomstrip
  579. +-->
  580. </div>
  581. </body>
  582. </html>