diff --git a/content/404.html b/content/404.html
index 3736805..57d1c92 100644
--- a/content/404.html
+++ b/content/404.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Page Not Found | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/404.html"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Page Not Found | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/404.html"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/404.html" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/404.html" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/assets/js/04da809a.5105624e.js b/content/assets/js/04da809a.5105624e.js
new file mode 100644
index 0000000..8a7e2a7
--- /dev/null
+++ b/content/assets/js/04da809a.5105624e.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[5578],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var p=o.createContext({}),i=function(e){var t=o.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=i(e.components);return o.createElement(p.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=i(n),k=a,h=c["".concat(p,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var i=2;i<r;i++)l[i]=n[i];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},35016:function(e,t,n){n.r(t),n.d(t,{assets:function(){return p},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return i}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/docs/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/next/deployment/kubernetes",draft:!1,tags:[],version:"current",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/next/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/next/admin/bookies"}},p={},i=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:i},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/1e033391.c70fb775.js b/content/assets/js/1e033391.c70fb775.js
new file mode 100644
index 0000000..0894d60
--- /dev/null
+++ b/content/assets/js/1e033391.c70fb775.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[3171],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},30752:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.11.1/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.11.1/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.11.1/deployment/kubernetes",draft:!1,tags:[],version:"4.11.1",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.11.1/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.11.1/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.11.1/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/1fe02719.dc2960a5.js b/content/assets/js/1fe02719.dc2960a5.js
new file mode 100644
index 0000000..597fbcb
--- /dev/null
+++ b/content/assets/js/1fe02719.dc2960a5.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[6657],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},25354:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.14.8/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.14.8/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.14.8/deployment/kubernetes",draft:!1,tags:[],version:"4.14.8",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.14.8/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.14.8/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.14.8/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/286c567a.2d44e7c2.js b/content/assets/js/286c567a.2d44e7c2.js
new file mode 100644
index 0000000..c6f8bd9
--- /dev/null
+++ b/content/assets/js/286c567a.2d44e7c2.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[9782],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var p=o.createContext({}),i=function(e){var t=o.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=i(e.components);return o.createElement(p.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=i(n),k=a,h=c["".concat(p,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var i=2;i<r;i++)l[i]=n[i];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},94544:function(e,t,n){n.r(t),n.d(t,{assets:function(){return p},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return i}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.15.5/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.15.5/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.15.5/deployment/kubernetes",draft:!1,tags:[],version:"4.15.5",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.15.5/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.15.5/admin/bookies"}},p={},i=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:i},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/30c186c7.26c41084.js b/content/assets/js/30c186c7.26c41084.js
new file mode 100644
index 0000000..801e27f
--- /dev/null
+++ b/content/assets/js/30c186c7.26c41084.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[2329],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},69823:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.6.2/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.6.2/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.6.2/deployment/kubernetes",draft:!1,tags:[],version:"4.6.2",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.6.2/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.6.2/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.6.2/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/31b6813e.3db81d40.js b/content/assets/js/31b6813e.3db81d40.js
new file mode 100644
index 0000000..54a018f
--- /dev/null
+++ b/content/assets/js/31b6813e.3db81d40.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[2215],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},72986:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.8.2/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.8.2/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.8.2/deployment/kubernetes",draft:!1,tags:[],version:"4.8.2",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.8.2/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.8.2/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.8.2/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/39a4b53d.c3a88c51.js b/content/assets/js/39a4b53d.c3a88c51.js
new file mode 100644
index 0000000..426be9a
--- /dev/null
+++ b/content/assets/js/39a4b53d.c3a88c51.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[4258],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},62304:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.12.1/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.12.1/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.12.1/deployment/kubernetes",draft:!1,tags:[],version:"4.12.1",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.12.1/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.12.1/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.12.1/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/3a07cdee.67ee0e63.js b/content/assets/js/3a07cdee.67ee0e63.js
new file mode 100644
index 0000000..368aae3
--- /dev/null
+++ b/content/assets/js/3a07cdee.67ee0e63.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[2354],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},58598:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.13.0/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.13.0/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.13.0/deployment/kubernetes",draft:!1,tags:[],version:"4.13.0",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.13.0/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.13.0/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.13.0/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/8296c7ad.1727001a.js b/content/assets/js/8296c7ad.1727001a.js
new file mode 100644
index 0000000..83e4511
--- /dev/null
+++ b/content/assets/js/8296c7ad.1727001a.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[9946],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},9648:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.9.2/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.9.2/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.9.2/deployment/kubernetes",draft:!1,tags:[],version:"4.9.2",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.9.2/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.9.2/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.9.2/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/96616036.c6d7de90.js b/content/assets/js/96616036.c6d7de90.js
new file mode 100644
index 0000000..6b8bd7f
--- /dev/null
+++ b/content/assets/js/96616036.c6d7de90.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[1689],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var p=o.createContext({}),i=function(e){var t=o.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=i(e.components);return o.createElement(p.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=i(n),k=a,h=c["".concat(p,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var i=2;i<r;i++)l[i]=n[i];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},53095:function(e,t,n){n.r(t),n.d(t,{assets:function(){return p},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return i}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.16.5/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.16.5/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.16.5/deployment/kubernetes",draft:!1,tags:[],version:"4.16.5",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.16.5/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.16.5/admin/bookies"}},p={},i=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:i},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/b5173ce4.4c58bc21.js b/content/assets/js/b5173ce4.4c58bc21.js
new file mode 100644
index 0000000..152a246
--- /dev/null
+++ b/content/assets/js/b5173ce4.4c58bc21.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[1059],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var p=o.createContext({}),i=function(e){var t=o.useContext(p),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=i(e.components);return o.createElement(p.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,p=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=i(n),k=a,h=c["".concat(p,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var p in t)hasOwnProperty.call(t,p)&&(s[p]=t[p]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var i=2;i<r;i++)l[i]=n[i];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},12858:function(e,t,n){n.r(t),n.d(t,{assets:function(){return p},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return i}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.17.0/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.17.0/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/deployment/kubernetes",draft:!1,tags:[],version:"4.17.0",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/admin/bookies"}},p={},i=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:i},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/b68c61f5.12e03b01.js b/content/assets/js/b68c61f5.12e03b01.js
new file mode 100644
index 0000000..0b70d71
--- /dev/null
+++ b/content/assets/js/b68c61f5.12e03b01.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[7030],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},52781:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.10.0/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.10.0/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.10.0/deployment/kubernetes",draft:!1,tags:[],version:"4.10.0",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.10.0/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.10.0/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.10.0/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/ea0aa512.12d09daa.js b/content/assets/js/ea0aa512.12d09daa.js
new file mode 100644
index 0000000..3832a70
--- /dev/null
+++ b/content/assets/js/ea0aa512.12d09daa.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunksite_3=self.webpackChunksite_3||[]).push([[5232],{3905:function(e,t,n){n.d(t,{Zo:function(){return u},kt:function(){return h}});var o=n(67294);function a(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function r(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,o)}return n}function l(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?r(Object(n),!0).forEach((function(t){a(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):r(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function s(e,t){if(null==e)return{};var n,o,a=function(e,t){if(null==e)return{};var n,o,a={},r=Object.keys(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(o=0;o<r.length;o++)n=r[o],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=o.createContext({}),p=function(e){var t=o.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):l(l({},t),e)),n},u=function(e){var t=p(e.components);return o.createElement(i.Provider,{value:t},e.children)},c="mdxType",d={inlineCode:"code",wrapper:function(e){var t=e.children;return o.createElement(o.Fragment,{},t)}},k=o.forwardRef((function(e,t){var n=e.components,a=e.mdxType,r=e.originalType,i=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),c=p(n),k=a,h=c["".concat(i,".").concat(k)]||c[k]||d[k]||r;return n?o.createElement(h,l(l({ref:t},u),{},{components:n})):o.createElement(h,l({ref:t},u))}));function h(e,t){var n=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var r=n.length,l=new Array(r);l[0]=k;var s={};for(var i in t)hasOwnProperty.call(t,i)&&(s[i]=t[i]);s.originalType=e,s[c]="string"==typeof e?e:a,l[1]=s;for(var p=2;p<r;p++)l[p]=n[p];return o.createElement.apply(null,l)}return o.createElement.apply(null,n)}k.displayName="MDXCreateElement"},70284:function(e,t,n){n.r(t),n.d(t,{assets:function(){return i},contentTitle:function(){return l},default:function(){return d},frontMatter:function(){return r},metadata:function(){return s},toc:function(){return p}});var o=n(83117),a=(n(67294),n(3905));const r={id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},l=void 0,s={unversionedId:"deployment/kubernetes",id:"version-4.7.3/deployment/kubernetes",title:"Deploying Apache BookKeeper on Kubernetes",description:"Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way.",source:"@site/versioned_docs/version-4.7.3/deployment/kubernetes.md",sourceDirName:"deployment",slug:"/deployment/kubernetes",permalink:"/docs/4.7.3/deployment/kubernetes",draft:!1,tags:[],version:"4.7.3",frontMatter:{id:"kubernetes",title:"Deploying Apache BookKeeper on Kubernetes"},sidebar:"version-4.7.3/docsSidebar",previous:{title:"Manual deployment",permalink:"/docs/4.7.3/deployment/manual"},next:{title:"BookKeeper administration",permalink:"/docs/4.7.3/admin/bookies"}},i={},p=[{value:"Setup on Google Container Engine",id:"setup-on-google-container-engine",level:2},{value:"Prerequisites",id:"prerequisites",level:3},{value:"Create a new Kubernetes cluster",id:"create-a-new-kubernetes-cluster",level:3},{value:"Dashboard",id:"dashboard",level:3},{value:"ZooKeeper",id:"zookeeper",level:3},{value:"Deploy Bookies",id:"deploy-bookies",level:3},{value:"Un-Deploy",id:"un-deploy",level:3}],u={toc:p},c="wrapper";function d(e){let{components:t,...n}=e;return(0,a.kt)(c,(0,o.Z)({},u,n,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("p",null,"Apache BookKeeper can be easily deployed in ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/"},"Kubernetes")," clusters. The managed clusters on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Container Engine")," is the most convenient way."),(0,a.kt)("p",null,"The deployment method shown in this guide relies on ",(0,a.kt)("a",{parentName:"p",href:"http://yaml.org/"},"YAML")," definitions for Kubernetes ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/resources-reference/v1.6/"},"resources"),". The ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," subdirectory holds resource definitions for:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A three-node ZooKeeper cluster"),(0,a.kt)("li",{parentName:"ul"},"A BookKeeper cluster with a bookie runs on each node.")),(0,a.kt)("h2",{id:"setup-on-google-container-engine"},"Setup on Google Container Engine"),(0,a.kt)("p",null,"To get started, get source code of ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes"},(0,a.kt)("inlineCode",{parentName:"a"},"kubernetes"))," from github by git clone."),(0,a.kt)("p",null,"If you'd like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the ",(0,a.kt)("inlineCode",{parentName:"p"},"replicas")," parameter in the ",(0,a.kt)("inlineCode",{parentName:"p"},"spec")," section of the appropriate ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/deployment/"},(0,a.kt)("inlineCode",{parentName:"a"},"Deployment"))," or ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},(0,a.kt)("inlineCode",{parentName:"a"},"StatefulSet"))," resource."),(0,a.kt)("p",null,(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/kubernetes-engine"},"Google Container Engine")," (GKE) automates the creation and management of Kubernetes clusters in ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/"},"Google Compute Engine")," (GCE)."),(0,a.kt)("h3",{id:"prerequisites"},"Prerequisites"),(0,a.kt)("p",null,"To get started, you'll need:"),(0,a.kt)("ul",null,(0,a.kt)("li",{parentName:"ul"},"A Google Cloud Platform account, which you can sign up for at ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com"},"cloud.google.com")),(0,a.kt)("li",{parentName:"ul"},"An existing Cloud Platform project"),(0,a.kt)("li",{parentName:"ul"},"The ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/downloads"},"Google Cloud SDK")," (in particular the ",(0,a.kt)("a",{parentName:"li",href:"https://cloud.google.com/sdk/gcloud/"},(0,a.kt)("inlineCode",{parentName:"a"},"gcloud"))," and ",(0,a.kt)("a",{parentName:"li",href:"https://kubernetes.io/docs/tasks/tools/"},(0,a.kt)("inlineCode",{parentName:"a"},"kubectl"))," tools).")),(0,a.kt)("h3",{id:"create-a-new-kubernetes-cluster"},"Create a new Kubernetes cluster"),(0,a.kt)("p",null,"You can create a new GKE cluster using the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/sdk/gcloud/reference/container/clusters/create"},(0,a.kt)("inlineCode",{parentName:"a"},"container clusters create"))," command for ",(0,a.kt)("inlineCode",{parentName:"p"},"gcloud"),". This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more."),(0,a.kt)("p",null,"As an example, we'll create a new GKE cluster for Kubernetes version ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164"},"1.6.4")," in the ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/regions-zones/regions-zones#available"},"us-central1-a")," zone. The cluster will be named ",(0,a.kt)("inlineCode",{parentName:"p"},"bookkeeper-gke-cluster")," and will consist of three VMs, each using two locally attached SSDs and running on ",(0,a.kt)("a",{parentName:"p",href:"https://cloud.google.com/compute/docs/machine-types"},"n1-standard-8")," machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud config set compute/zone us-central1-a\n$ gcloud config set project your-project-name\n$ gcloud container clusters create bookkeeper-gke-cluster \\\n  --machine-type=n1-standard-8 \\\n  --num-nodes=3 \\\n  --local-ssd-count=2 \\\n  --enable-kubernetes-alpha\n")),(0,a.kt)("p",null,"By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/overview/working-with-objects/labels"},"labels"),"."),(0,a.kt)("h3",{id:"dashboard"},"Dashboard"),(0,a.kt)("p",null,"You can observe your cluster in the ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/"},"Kubernetes Dashboard")," by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters get-credentials bookkeeper-gke-cluster \\\n  --zone=us-central1-a \\\n  --project=your-project-name\n$ kubectl proxy\n")),(0,a.kt)("p",null,"By default, the proxy will be opened on port 8001. Now you can navigate to ",(0,a.kt)("a",{parentName:"p",href:"http://localhost:8001/ui"},"localhost:8001/ui")," in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying."),(0,a.kt)("p",null,"When you create a cluster, your ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," config in ",(0,a.kt)("inlineCode",{parentName:"p"},"~/.kube/config")," (on MacOS and Linux) will be updated for you, so you probably won't need to change your configuration. Nonetheless, you can ensure that ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," can interact with your cluster by listing the nodes in the cluster:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get nodes\n")),(0,a.kt)("p",null,"If ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl")," is working with your cluster, you can proceed to deploy ZooKeeper and Bookies."),(0,a.kt)("h3",{id:"zookeeper"},"ZooKeeper"),(0,a.kt)("p",null,"You ",(0,a.kt)("em",{parentName:"p"},"must")," deploy ZooKeeper as the first component, as it is a dependency for the others."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl apply -f zookeeper.yaml\n")),(0,a.kt)("p",null,"Wait until all three ZooKeeper server pods are up and have the status ",(0,a.kt)("inlineCode",{parentName:"p"},"Running"),". You can check on the status of the ZooKeeper pods at any time:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods -l component=zookeeper\nNAME      READY     STATUS             RESTARTS   AGE\nzk-0      1/1       Running            0          18m\nzk-1      1/1       Running            0          17m\nzk-2      0/1       Running            6          15m\n")),(0,a.kt)("p",null,"This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs."),(0,a.kt)("p",null,"If you want to connect to one of the remote zookeeper server, you can use",(0,a.kt)("a",{parentName:"p",href:"https://github.com/rgs1/zk_shell"},"zk-shell"),", you need to forward a local port to the\nremote zookeeper server:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl port-forward zk-0 2181:2181\n$ zk-shell localhost 2181\n")),(0,a.kt)("h3",{id:"deploy-bookies"},"Deploy Bookies"),(0,a.kt)("p",null,"Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/"},"DaemonSet")," or a ",(0,a.kt)("a",{parentName:"p",href:"https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/"},"StatefulSet"),"."),(0,a.kt)("blockquote",null,(0,a.kt)("p",{parentName:"blockquote"},"NOTE: ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," vs ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the\ncluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn't require any external storage for Persistent\nVolumes."),(0,a.kt)("p",{parentName:"blockquote"},"A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods\nare not interchangeable, the idenifiers for each pod are maintained across any rescheduling."),(0,a.kt)("p",{parentName:"blockquote"},"Which one to use? A ",(0,a.kt)("em",{parentName:"p"},"DaemonSet")," is the easiest way to deploy a bookkeeper cluster, because it doesn't require additional persistent volume provisioner and use local disks. BookKeeper manages\nthe data replication. It maintains the best latency property. However, it uses ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and ",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," for communications between pods. In some k8s platform (such as DC/OS), ",(0,a.kt)("inlineCode",{parentName:"p"},"hostIP")," and\n",(0,a.kt)("inlineCode",{parentName:"p"},"hostPort")," are not well supported. A ",(0,a.kt)("em",{parentName:"p"},"StatefulSet")," is only practical when deploying in a cloud environment or any K8S installation that has persistent volumes available. Also be aware, latency\ncan be potentially higher when using persistent volumes, because there is usually built-in replication in the persistent volumes.")),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"# deploy bookies in a daemon set\n$ kubectl apply -f bookkeeper.yaml\n\n# deploy bookies in a stateful set\n$ kubectl apply -f bookkeeper.stateful.yaml\n")),(0,a.kt)("p",null,"You can check on the status of the Bookie pods for these components either in the Kubernetes Dashboard or using ",(0,a.kt)("inlineCode",{parentName:"p"},"kubectl"),":"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl get pods\n")),(0,a.kt)("p",null,"While all BookKeeper pods is Running, by zk-shell you could find all available bookies under /ledgers/"),(0,a.kt)("p",null,"You could also run a ",(0,a.kt)("a",{parentName:"p",href:"https://github.com/ivankelly/bookkeeper-tutorial/"},"bookkeeper tutorial")," instance, which named as 'dice' here, in this bookkeeper cluster."),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},'$\ufeffkubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"\n')),(0,a.kt)("p",null,"An example output of Dice instance is like this:"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-aidl"},'\u279c $ kubectl run -i --tty --attach dice --image=caiok/bookkeeper-tutorial --env ZOOKEEPER_SERVERS="zk-0.zookeeper"          \nIf you don\'t see a command prompt, try pressing enter.\nValue = 1, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 5, epoch = 5, leading\nValue = 3, epoch = 5, leading\nValue = 2, epoch = 5, leading\nValue = 1, epoch = 5, leading\nValue = 4, epoch = 5, leading\nValue = 2, epoch = 5, leading\n')),(0,a.kt)("h3",{id:"un-deploy"},"Un-Deploy"),(0,a.kt)("p",null,"Delete Demo dice instance"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$\ufeffkubectl delete deployment dice      \n")),(0,a.kt)("p",null,"Delete BookKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f bookkeeper.yaml    \n")),(0,a.kt)("p",null,"Delete ZooKeeper"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ kubectl delete -f zookeeper.yaml    \n")),(0,a.kt)("p",null,"Delete cluster"),(0,a.kt)("pre",null,(0,a.kt)("code",{parentName:"pre",className:"language-bash"},"$ gcloud container clusters delete bookkeeper-gke-cluster    \n")))}d.isMDXComponent=!0}}]);
\ No newline at end of file
diff --git a/content/assets/js/runtime~main.94f37568.js b/content/assets/js/runtime~main.94f37568.js
new file mode 100644
index 0000000..1082aaa
--- /dev/null
+++ b/content/assets/js/runtime~main.94f37568.js
@@ -0,0 +1 @@
+!function(){"use strict";var e,f,c,a,b,d={},t={};function n(e){var f=t[e];if(void 0!==f)return f.exports;var c=t[e]={id:e,loaded:!1,exports:{}};return d[e].call(c.exports,c,c.exports,n),c.loaded=!0,c.exports}n.m=d,n.c=t,e=[],n.O=function(f,c,a,b){if(!c){var d=1/0;for(u=0;u<e.length;u++){c=e[u][0],a=e[u][1],b=e[u][2];for(var t=!0,r=0;r<c.length;r++)(!1&b||d>=b)&&Object.keys(n.O).every((function(e){return n.O[e](c[r])}))?c.splice(r--,1):(t=!1,b<d&&(d=b));if(t){e.splice(u--,1);var o=a();void 0!==o&&(f=o)}}return f}b=b||0;for(var u=e.length;u>0&&e[u-1][2]>b;u--)e[u]=e[u-1];e[u]=[c,a,b]},n.n=function(e){var f=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(f,{a:f}),f},c=Object.getPrototypeOf?function(e){return Object.getPrototypeOf(e)}:function(e){return e.__proto__},n.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var b=Object.create(null);n.r(b);var d={};f=f||[null,c({}),c([]),c(c)];for(var t=2&a&&e;"object"==typeof t&&!~f.indexOf(t);t=c(t))Object.getOwnPropertyNames(t).forEach((function(f){d[f]=function(){return e[f]}}));return d.default=function(){return e},n.d(b,d),b},n.d=function(e,f){for(var c in f)n.o(f,c)&&!n.o(e,c)&&Object.defineProperty(e,c,{enumerable:!0,get:f[c]})},n.f={},n.e=function(e){return Promise.all(Object.keys(n.f).reduce((function(f,c){return n.f[c](e,f),f}),[]))},n.u=function(e){return"assets/js/"+({5:"ed30e49e",10:"da284785",11:"4bfd050d",24:"4a8bd1f6",53:"935f2afb",60:"b4baf230",63:"d972a432",115:"73d377e5",119:"e494340d",122:"1268352f",123:"ff260964",152:"54f44165",157:"6ee89642",166:"1a41bcf4",205:"7c8189eb",248:"2ff57c08",253:"1c4211eb",289:"131f50d0",325:"213de9a1",338:"a1b73db9",349:"3c400ed9",355:"f51846fe",363:"7e9c80a9",368:"c23b53d6",372:"b3c11919",426:"a363edce",440:"07b748cc",453:"95ce3d34",478:"af1e75d9",520:"0187783a",534:"196689c8",609:"7fa58592",622:"cb952911",637:"87cc2ef4",643:"ffb1bb68",657:"a6fce498",659:"2ba8ffb1",663:"f69994f3",678:"3cef618a",724:"a386696c",741:"dca334c0",762:"35534a6f",771:"d67b6402",792:"816774dc",796:"eba79e96",833:"6beda70c",879:"2956de9a",906:"3d7bb4e0",908:"9dbc92a7",931:"07497906",937:"e39bc689",960:"91c76d4c",975:"c142e639",983:"485f610c",989:"f1ec30d1",1007:"035695b8",1059:"b5173ce4",1080:"05c61b00",1173:"313a661a",1181:"f4dc42ca",1209:"bbde899b",1227:"e66d8aa5",1271:"f51baf8e",1293:"edb7b4da",1310:"dd523e5f",1335:"9b42fb08",1359:"f2d60081",1361:"943eb5d2",1401:"9edca4e9",1406:"71605a32",1423:"28655793",1435:"af30b71e",1441:"421258aa",1467:"41168d35",1488:"a19a348a",1493:"896baf8c",1514:"2afb7445",1527:"cfc9ccfa",1536:"2b1d6972",1573:"7917e5c5",1594:"4808995b",1614:"739e861c",1626:"4e6f80aa",1631:"48e6979d",1666:"f9a3b6b7",1682:"fca08244",1689:"96616036",1708:"724151f0",1717:"78cfffe1",1744:"213d6dd2",1751:"7e8ff14f",1765:"b3100f29",1831:"aede75d4",1845:"a3335d39",1870:"7cefa220",1896:"2d24b11b",1898:"4cd56fdb",1922:"4882bd62",1948:"818526b6",1951:"0d53d5be",1963:"62a0d553",2009:"724e3ad7",2018:"52fd9c79",2047:"ac63e720",2049:"f47db9e6",2057:"f2d5ac7e",2128:"7bf77d86",2179:"257152cd",2207:"4a224a91",2211:"effdd252",2215:"31b6813e",2253:"a7a77925",2279:"f1c1c644",2288:"5ae0edee",2320:"662da30f",2329:"30c186c7",2354:"3a07cdee",2370:"4f98aae6",2407:"561b6265",2418:"9e5743fa",2422:"cb881008",2442:"3f883def",2493:"e151506d",2561:"492440dc",2572:"c93357d8",2575:"985bff7a",2609:"561c0d70",2657:"7b3ed863",2662:"c34c1aa0",2682:"e52fe1ed",2686:"e1797e98",2824:"d1a9d15c",2855:"e0128c32",2867:"772e10c8",2882:"4831039f",2893:"db40a819",2913:"9fedf7e0",2974:"df1f2a65",2993:"1bb26576",3011:"ba628d47",3012:"dff2692f",3035:"aa2b1be2",3066:"ea5d6149",3085:"1f391b9e",3096:"089cefec",3132:"7589009a",3133:"b2f83641",3159:"6ff4dfcf",3164:"4d70f3cf",3171:"1e033391",3200:"4bf870c6",3209:"79615c67",3239:"d2113218",3258:"43a0a41f",3310:"d8aef0aa",3323:"8b73681b",3331:"7e8a1336",3349:"0d2aa02e",3351:"5ccf8bb0",3390:"8cc504e2",3391:"c53b1d90",3404:"46fd0908",3413:"824fb3c0",3498:"bbef9193",3508:"d91115c6",3515:"8d5383ff",3523:"70ab0033",3577:"342215bd",3609:"65650ba2",3615:"8e8026e2",3617:"59304d55",3641:"8e901aa8",3676:"1b641edf",3690:"09c5a1ad",3699:"0537c41d",3757:"83e74c48",3758:"3cff1016",3782:"0aaf5a35",3786:"685312ca",3845:"1e371f09",3852:"5a1d798c",3877:"e2a8767f",3898:"fb18728e",3902:"d96302cc",3912:"f74a5a7b",3937:"b7fafd37",3958:"5f20ae4e",4010:"58753608",4014:"951f283b",4026:"bc5400c9",4050:"0d0fc48b",4051:"7537e02a",4061:"61a001f8",4107:"3d9fe30f",4110:"7472e927",4123:"f963ea94",4138:"84741dfb",4150:"20c15017",4152:"9f61d8e1",4186:"7dcbb8ba",4195:"c4f5d8e4",4203:"3bd732bb",4258:"39a4b53d",4377:"e2886f4d",4378:"9ca9b220",4380:"d1db332c",4392:"c56769ee",4539:"1791646b",4546:"9a9953e7",4579:"e526d9fb",4592:"8fde3252",4612:"e64000bb",4624:"be9b1ba5",4643:"65df3d35",4651:"6cdfbbfb",4670:"86a6f4a6",4696:"0d73263b",4756:"c9cfd710",4779:"caa6cc64",4840:"9c4aba92",4845:"a43fb5c1",4846:"ebba64f8",4849:"6b366f12",4869:"e6a6cdb5",4871:"91a9c488",4876:"8ef2f9fb",4887:"9260b226",4900:"bc29171d",4923:"3f753b27",4980:"ba18db30",5056:"fd1c180b",5156:"83a4731b",5178:"0843cb03",5181:"3ec050b2",5211:"c767f061",5221:"86ab4954",5232:"ea0aa512",5251:"ef3f5cc8",5268:"40712b22",5297:"97cfc084",5446:"037dd35f",5451:"9c5aab0e",5500:"1d91761b",5578:"04da809a",5585:"87d8598c",5593:"8af1d301",5616:"d0a2eb8e",5617:"f6025ed5",5631:"50f3a74f",5638:"7f23633c",5646:"d09aafa8",5694:"f7a674b2",5701:"00099f85",5729:"9a26ec38",5733:"13a7da5f",5777:"064c7463",5792:"5e6a0b05",5848:"c78e0dfd",5860:"bd384662",5866:"76097a60",5870:"1c223750",5904:"6f4e447b",5947:"137061ef",6004:"34dce56b",6016:"f6ba9a4b",6055:"638e6f40",6057:"014f04cc",6066:"23200584",6082:"03f88f06",6111:"bbd70f53",6114:"425c25af",6146:"22d76b2d",6174:"c3917577",6181:"beeb3fc3",6187:"5b25eae8",6192:"b54aa47d",6197:"736b32a3",6268:"e54bfd1f",6303:"f35ad539",6324:"c25ed854",6346:"612db47a",6395:"2e50ccc4",6405:"331b2a3d",6406:"72c0ad31",6415:"850e3a3d",6469:"ca9e19a0",6522:"5684741f",6525:"c87023c4",6552:"136f9a14",6572:"14a50b22",6583:"0012aeda",6643:"d9c8eb9a",6657:"1fe02719",6669:"2440862d",6696:"1ecfc0b9",6763:"1cb4afcc",6775:"6766c2ba",6783:"d78c0d88",6820:"2cc56763",6885:"b7d359f1",6902:"c2065ba5",6950:"24e8d336",6960:"7a19cc40",6994:"1ac84465",7030:"b68c61f5",7031:"11829f95",7053:"e0d9e15f",7055:"8df24095",7068:"bf29d81a",7071:"66ba8f65",7106:"de2333f9",7150:"0c3f6a2e",7211:"cb1fb814",7218:"b217b1df",7281:"b9567f41",7285:"93eb8f00",7307:"14609be1",7322:"3044fa47",7356:"634aee6c",7367:"a5854c89",7374:"3bb6078f",7378:"c29dbf77",7397:"976110e4",7399:"deffa85b",7406:"da8fb6e6",7474:"8d306d14",7590:"69138a9b",7595:"db1d00c4",7599:"7ef71a47",7626:"33c915ea",7666:"14da3ce7",7732:"b672ebd6",7741:"5d50bbf1",7743:"c0fb62f3",7753:"73663191",7764:"f440e5d3",7781:"b929e89b",7844:"abb3dda4",7845:"a4f4c0c8",7886:"026a1d69",7903:"b218484e",7909:"7b3ecbf1",7916:"7815c2d3",7918:"17896441",7934:"5acc7ccb",7942:"fcea3b45",7992:"3592d2f2",8001:"6789c389",8031:"e2a686c7",8037:"186b8a18",8049:"ed08832e",8095:"7f6538f4",8108:"c3a4d6bc",8130:"ded32efe",8136:"80055ea8",8173:"a647d08a",8211:"21e4306c",8262:"0066c128",8282:"491836cf",8308:"e94dfc49",8335:"5531b81f",8339:"ee8b4f50",8342:"4ce92582",8351:"2ec0be4c",8357:"3411c643",8385:"d70b4d73",8441:"c4b0d767",8461:"6eb9aa01",8473:"d86f913f",8502:"a9e28e86",8522:"b800115e",8540:"9050039c",8550:"8607f33a",8562:"c90cac61",8598:"05d43200",8629:"11433b40",8654:"1ddcee41",8663:"ffbf113e",8669:"f61db2e5",8682:"c6ff1e84",8687:"17b33b39",8743:"730767f4",8756:"35216708",8791:"5cf2c6e0",8805:"f8bf4ac5",8846:"a363e5d2",8859:"7c48a47e",8951:"f9a9d4c2",8969:"b022ea46",8986:"2246c66d",8991:"3f48ad20",9006:"17fed085",9023:"87726f30",9035:"a34b52ce",9041:"0e2af38d",9076:"8372258a",9084:"4cf33c28",9113:"bf69fc30",9122:"c7f18df2",9138:"abbc0c33",9178:"6e0bb75c",9192:"ebf8c8a4",9196:"629b6576",9199:"3f07749a",9211:"cf9c4b04",9232:"0a998885",9249:"cbfa528b",9263:"e1e94bbc",9272:"2c6e2254",9290:"b6c885a5",9295:"ee4ead70",9342:"92fa1062",9389:"25be17b9",9412:"ae4d2163",9418:"b26f55a5",9421:"7381f606",9433:"318dfdf9",9441:"94320cd8",9444:"7b53c4c5",9514:"1be78505",9521:"a47a33ba",9522:"dc0ec182",9547:"bb7ded3b",9550:"ef1ef56c",9552:"58efeb0f",9562:"76831a2f",9578:"ca99f506",9609:"a3d44527",9632:"5b83d837",9685:"1547da37",9693:"df9d0e7b",9694:"1020a002",9716:"87d315c4",9773:"4698369b",9782:"286c567a",9815:"07c6cf68",9861:"3630fad3",9877:"2d2c1853",9905:"3521ddbf",9940:"0de1e94b",9946:"8296c7ad",9999:"d288ceb1"}[e]||e)+"."+{5:"a1267848",10:"1f44f71c",11:"2596a5d0",24:"705eb4be",53:"504357c9",60:"4c0e16f1",63:"b894eaf4",115:"ca7aecfb",119:"eb60752d",122:"76523668",123:"67b0ce7e",152:"2d015a9b",157:"3d798173",166:"0409860f",205:"08b5c238",248:"7c3781a1",253:"c058f96d",289:"428b0007",325:"193d4a95",338:"be2737e6",349:"6628f470",355:"17596908",363:"b6b3daad",368:"3a4db739",372:"9430bd2b",426:"5246b47c",440:"36737b71",453:"c2f26e06",478:"3918027f",520:"bd4c3f40",534:"3b710a0b",609:"c59ff461",622:"6e72a5a3",637:"d8d5231e",643:"f089df53",657:"13780526",659:"fc1b31ab",663:"c1880411",678:"daae6f38",724:"0276d679",741:"4c68083c",762:"1c06cffb",771:"898bacd7",792:"5c09cf5c",796:"0fbf194a",833:"f4ce4984",879:"65abbd15",906:"b4dc97f1",908:"f247ea71",931:"c8800cb1",937:"6c223f02",960:"788e13c3",975:"13821c7f",983:"041ea4c4",989:"a0aa68c2",1007:"b54e48d3",1059:"4c58bc21",1080:"09c5dffd",1173:"3724c827",1181:"f42bfe77",1209:"21c98fbb",1227:"ada56b4d",1271:"af9efe7e",1293:"04978e5a",1310:"6d0df198",1335:"32af4ba7",1359:"70dcff65",1361:"f1c80bb8",1401:"5ea9817b",1406:"97e515a3",1423:"35f59c27",1435:"efd9791e",1441:"e04adf0b",1467:"f63635ca",1488:"27ae49ec",1493:"6c161e01",1514:"01b33d9b",1527:"553ca6af",1536:"5f83b2ef",1573:"12dd326e",1594:"8cca9da0",1614:"fa7801c1",1626:"52962ab1",1631:"b56566fe",1666:"7014dcdf",1682:"18bb3945",1689:"c6d7de90",1708:"19a709c7",1717:"a6ca6557",1744:"3b45e237",1751:"10538b01",1765:"7b9de6bf",1831:"dba7e92a",1845:"a5c4ec1f",1870:"2e401a7c",1896:"b15ede0f",1898:"bb578d20",1922:"8c32f656",1948:"73444937",1951:"3777119c",1963:"fd8b2bb4",2009:"eb5d831c",2018:"1de61a2f",2047:"97fb5aef",2049:"f751fcb9",2057:"90f1855d",2128:"cb08c121",2179:"f442e509",2207:"9401e76c",2211:"873e0f19",2215:"3db81d40",2253:"60211fde",2279:"38fda5d4",2288:"cf174016",2320:"d17d4e5d",2329:"26c41084",2354:"67ee0e63",2370:"10a437f0",2407:"7c9c780f",2418:"e0aff4dd",2422:"ac67b058",2442:"c53dbe52",2493:"0cb78d24",2561:"3e7cf672",2572:"82e17009",2575:"c0d976b8",2609:"11db1421",2657:"0338a35d",2662:"4887151e",2682:"85962fcb",2686:"1c5402c7",2824:"89645d1f",2855:"c5743b54",2867:"f45a7d65",2882:"d1f6bbbb",2893:"58a0c3c5",2913:"67bf80c3",2974:"12d920b8",2993:"bb5125c7",3011:"e54456ce",3012:"ace7798a",3035:"1976c23c",3066:"0be8279e",3085:"0fb5cf8b",3096:"e6435c4c",3132:"c48f0291",3133:"772bf96b",3159:"4775c98f",3164:"3d471605",3171:"c70fb775",3200:"3ec99cc3",3209:"2f97966c",3239:"8a92dae0",3258:"e9eb475d",3310:"1207c541",3323:"93f9bcd5",3331:"de9bf7ea",3349:"47d40a08",3351:"b6e917d2",3390:"4aff2f61",3391:"7d275d8e",3404:"337018dc",3413:"501f84c3",3498:"5379d0b1",3508:"dbd7c419",3515:"9a5c3bbe",3523:"5c73bddd",3577:"c32ac965",3609:"6ace7d45",3615:"902ec583",3617:"f75a7e6d",3641:"b4120add",3676:"b280220b",3690:"05ac8e86",3699:"68d6e821",3757:"31b4cbae",3758:"e25aa81f",3782:"46df78be",3786:"77279c58",3845:"30b311b2",3852:"782c801a",3877:"66b6e945",3898:"be66cb5c",3902:"f00604f7",3912:"fb91e6b4",3937:"df779e3f",3958:"9d7ea059",4010:"a7bac305",4014:"7ccb826b",4026:"cd8729eb",4050:"1fbe8cde",4051:"e7090e11",4061:"5f8ffa47",4107:"e46f7e11",4110:"d6b6a4b3",4123:"6e046f79",4138:"fa7883fd",4150:"2eb64447",4152:"a82d9221",4186:"ca4b2351",4195:"05607b4e",4203:"a5956234",4258:"c3a88c51",4377:"6ea746c5",4378:"7b3230f6",4380:"ed0f3ace",4392:"21ec65cb",4539:"bde49175",4546:"65c14018",4579:"7f0bff70",4592:"fc529619",4612:"cbf0dfe5",4624:"445e1007",4643:"46ee4d35",4651:"d0395d21",4670:"b307656e",4696:"ccc3979c",4756:"6646b229",4779:"0ff0b4d2",4840:"5f512aed",4845:"bfda8c01",4846:"29930b6c",4849:"1dc7aa20",4869:"3d9152ea",4871:"f5e315ab",4876:"966d3748",4887:"51f71314",4900:"43563054",4923:"77d573dc",4972:"4efb9969",4980:"cca82da0",5056:"b560c725",5156:"efa114fe",5178:"896cd70b",5181:"ffbc52c8",5211:"e2420c5e",5221:"3ddb3fea",5232:"12d09daa",5251:"a8e6633f",5268:"b3e39516",5297:"df055502",5430:"59f55404",5446:"e89fe8a9",5451:"330a7779",5500:"6b087361",5578:"5105624e",5585:"ebd7f880",5593:"570ae555",5616:"ddce0d4e",5617:"0ab72057",5631:"85ae0442",5638:"e8c29eec",5646:"f85c5c6c",5694:"89e8abe8",5701:"8f3cd12f",5729:"4b3fdc93",5733:"355741a9",5777:"22a29e45",5792:"bf87f2dc",5848:"6dad332f",5860:"ad31de6c",5866:"df3082b2",5870:"91e087e4",5904:"79fee0c8",5947:"e4c7b1dd",6004:"3d34b60d",6016:"2784fdcd",6055:"7b996c32",6057:"d0728b5e",6066:"a80ad9f7",6082:"c4b3dd21",6111:"3ce93788",6114:"fe6f3420",6146:"5af7c9ff",6174:"55dd15fa",6181:"8f0853f4",6187:"8f496247",6192:"69518e7a",6197:"f2a6c34e",6268:"9053ba4d",6303:"db09ef14",6324:"f1560450",6346:"f35def59",6395:"5e72b52f",6405:"96473883",6406:"2676e0e0",6415:"1d7b845d",6469:"8942fcb5",6522:"bb1382bd",6525:"39c59091",6552:"aebb3045",6572:"2d2f728f",6583:"b2c4e120",6643:"6a291df4",6657:"dc2960a5",6669:"0d6b9669",6696:"72db0c18",6763:"d2e8485a",6775:"1bfb31fe",6783:"91856f2a",6820:"37ec1364",6885:"a9bd9606",6902:"06dd2182",6950:"f03f3dc3",6960:"c9bd9016",6994:"1fd253bc",7030:"12e03b01",7031:"e1baad54",7053:"2e4b87f1",7055:"87050eb7",7068:"af9f28c1",7071:"54be5bd7",7106:"7419a4a2",7150:"5eb8aab2",7211:"7b6712cf",7218:"5661059b",7281:"c26713dc",7285:"c2c80a79",7307:"d71b0965",7322:"ca664e74",7356:"6e5a1bd7",7367:"501134f1",7374:"38ba318b",7378:"a5737e41",7397:"291b6630",7399:"8127469c",7406:"f300b68a",7474:"46da60cf",7590:"2ac30950",7595:"9c8629a8",7599:"0b2c382c",7626:"4188a719",7666:"1bc34ee2",7732:"4a961987",7741:"cdee7eaf",7743:"00d562ee",7753:"d80e3d21",7764:"f9da02bc",7781:"a0de2c3b",7844:"515b40b2",7845:"6a705c80",7886:"1bbc6a2d",7903:"a83de0c2",7909:"3fd00ed3",7916:"d604549c",7918:"6c174508",7934:"9515e64b",7942:"601a77ba",7992:"90797ba9",8001:"e5f433ae",8031:"7dbfb182",8037:"da278053",8049:"45fa32c7",8095:"929dd7e9",8108:"0d907cd0",8130:"04a93c74",8136:"2f6d0026",8173:"ea4a3701",8211:"25ba90f9",8262:"df0fb6af",8282:"54678624",8308:"da6d34de",8335:"69339167",8339:"36c7b387",8342:"2e414aa7",8351:"9be93492",8357:"29baa3fa",8385:"22ad7ea4",8441:"ff28aebd",8461:"4c5370d1",8473:"9ab8123b",8502:"881211c9",8522:"b936cf4b",8540:"86e66e60",8550:"53e47b26",8562:"7d94221f",8598:"293a1033",8629:"063eba33",8654:"d60848fc",8663:"6534dff6",8669:"350aa3ae",8682:"502cad7f",8687:"3790c3ca",8743:"dabfe4bb",8756:"a353df92",8791:"7b1f1e09",8805:"13176325",8846:"2b4efa60",8859:"880aafa2",8951:"ff73a56d",8969:"c7202217",8986:"40bfe885",8991:"61fd22d7",9006:"5694d907",9023:"4f339ae3",9035:"7291ea3f",9041:"5b77f36e",9076:"0fda46ea",9084:"7e57a85a",9113:"d0af63cf",9122:"84d80e98",9138:"e7cfff0d",9178:"16d207f5",9192:"6994b314",9196:"8cdc4cc6",9199:"45696df7",9211:"35f37a45",9232:"c6464417",9249:"5f038984",9263:"f7b48baa",9272:"3bb7638f",9290:"07ddf17e",9295:"07ba23ee",9342:"f2519dfe",9389:"577ee14f",9412:"2cfa90b7",9418:"c695a148",9421:"71cff605",9433:"f4d79510",9441:"e494d3ad",9444:"3d70c4d6",9514:"2e8a360b",9521:"98e1f582",9522:"9d5e3074",9547:"219cc36c",9550:"728ff610",9552:"2a19eb7b",9562:"645ef5ff",9578:"7916a854",9609:"8a4ce392",9632:"1037bbf8",9685:"0a42d63d",9693:"56ccff9b",9694:"f31a5bac",9716:"707acd30",9773:"e5467673",9782:"2d44e7c2",9815:"618baf7d",9861:"ef11d537",9877:"2aa4cf48",9905:"652aae66",9940:"a522e8d1",9946:"1727001a",9999:"f68eafd8"}[e]+".js"},n.miniCssF=function(e){},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=function(e,f){return Object.prototype.hasOwnProperty.call(e,f)},a={},b="site-3:",n.l=function(e,f,c,d){if(a[e])a[e].push(f);else{var t,r;if(void 0!==c)for(var o=document.getElementsByTagName("script"),u=0;u<o.length;u++){var i=o[u];if(i.getAttribute("src")==e||i.getAttribute("data-webpack")==b+c){t=i;break}}t||(r=!0,(t=document.createElement("script")).charset="utf-8",t.timeout=120,n.nc&&t.setAttribute("nonce",n.nc),t.setAttribute("data-webpack",b+c),t.src=e),a[e]=[f];var l=function(f,c){t.onerror=t.onload=null,clearTimeout(s);var b=a[e];if(delete a[e],t.parentNode&&t.parentNode.removeChild(t),b&&b.forEach((function(e){return e(c)})),f)return f(c)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:t}),12e4);t.onerror=l.bind(null,t.onerror),t.onload=l.bind(null,t.onload),r&&document.head.appendChild(t)}},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.p="/",n.gca=function(e){return e={17896441:"7918",23200584:"6066",28655793:"1423",35216708:"8756",58753608:"4010",73663191:"7753",96616036:"1689",ed30e49e:"5",da284785:"10","4bfd050d":"11","4a8bd1f6":"24","935f2afb":"53",b4baf230:"60",d972a432:"63","73d377e5":"115",e494340d:"119","1268352f":"122",ff260964:"123","54f44165":"152","6ee89642":"157","1a41bcf4":"166","7c8189eb":"205","2ff57c08":"248","1c4211eb":"253","131f50d0":"289","213de9a1":"325",a1b73db9:"338","3c400ed9":"349",f51846fe:"355","7e9c80a9":"363",c23b53d6:"368",b3c11919:"372",a363edce:"426","07b748cc":"440","95ce3d34":"453",af1e75d9:"478","0187783a":"520","196689c8":"534","7fa58592":"609",cb952911:"622","87cc2ef4":"637",ffb1bb68:"643",a6fce498:"657","2ba8ffb1":"659",f69994f3:"663","3cef618a":"678",a386696c:"724",dca334c0:"741","35534a6f":"762",d67b6402:"771","816774dc":"792",eba79e96:"796","6beda70c":"833","2956de9a":"879","3d7bb4e0":"906","9dbc92a7":"908","07497906":"931",e39bc689:"937","91c76d4c":"960",c142e639:"975","485f610c":"983",f1ec30d1:"989","035695b8":"1007",b5173ce4:"1059","05c61b00":"1080","313a661a":"1173",f4dc42ca:"1181",bbde899b:"1209",e66d8aa5:"1227",f51baf8e:"1271",edb7b4da:"1293",dd523e5f:"1310","9b42fb08":"1335",f2d60081:"1359","943eb5d2":"1361","9edca4e9":"1401","71605a32":"1406",af30b71e:"1435","421258aa":"1441","41168d35":"1467",a19a348a:"1488","896baf8c":"1493","2afb7445":"1514",cfc9ccfa:"1527","2b1d6972":"1536","7917e5c5":"1573","4808995b":"1594","739e861c":"1614","4e6f80aa":"1626","48e6979d":"1631",f9a3b6b7:"1666",fca08244:"1682","724151f0":"1708","78cfffe1":"1717","213d6dd2":"1744","7e8ff14f":"1751",b3100f29:"1765",aede75d4:"1831",a3335d39:"1845","7cefa220":"1870","2d24b11b":"1896","4cd56fdb":"1898","4882bd62":"1922","818526b6":"1948","0d53d5be":"1951","62a0d553":"1963","724e3ad7":"2009","52fd9c79":"2018",ac63e720:"2047",f47db9e6:"2049",f2d5ac7e:"2057","7bf77d86":"2128","257152cd":"2179","4a224a91":"2207",effdd252:"2211","31b6813e":"2215",a7a77925:"2253",f1c1c644:"2279","5ae0edee":"2288","662da30f":"2320","30c186c7":"2329","3a07cdee":"2354","4f98aae6":"2370","561b6265":"2407","9e5743fa":"2418",cb881008:"2422","3f883def":"2442",e151506d:"2493","492440dc":"2561",c93357d8:"2572","985bff7a":"2575","561c0d70":"2609","7b3ed863":"2657",c34c1aa0:"2662",e52fe1ed:"2682",e1797e98:"2686",d1a9d15c:"2824",e0128c32:"2855","772e10c8":"2867","4831039f":"2882",db40a819:"2893","9fedf7e0":"2913",df1f2a65:"2974","1bb26576":"2993",ba628d47:"3011",dff2692f:"3012",aa2b1be2:"3035",ea5d6149:"3066","1f391b9e":"3085","089cefec":"3096","7589009a":"3132",b2f83641:"3133","6ff4dfcf":"3159","4d70f3cf":"3164","1e033391":"3171","4bf870c6":"3200","79615c67":"3209",d2113218:"3239","43a0a41f":"3258",d8aef0aa:"3310","8b73681b":"3323","7e8a1336":"3331","0d2aa02e":"3349","5ccf8bb0":"3351","8cc504e2":"3390",c53b1d90:"3391","46fd0908":"3404","824fb3c0":"3413",bbef9193:"3498",d91115c6:"3508","8d5383ff":"3515","70ab0033":"3523","342215bd":"3577","65650ba2":"3609","8e8026e2":"3615","59304d55":"3617","8e901aa8":"3641","1b641edf":"3676","09c5a1ad":"3690","0537c41d":"3699","83e74c48":"3757","3cff1016":"3758","0aaf5a35":"3782","685312ca":"3786","1e371f09":"3845","5a1d798c":"3852",e2a8767f:"3877",fb18728e:"3898",d96302cc:"3902",f74a5a7b:"3912",b7fafd37:"3937","5f20ae4e":"3958","951f283b":"4014",bc5400c9:"4026","0d0fc48b":"4050","7537e02a":"4051","61a001f8":"4061","3d9fe30f":"4107","7472e927":"4110",f963ea94:"4123","84741dfb":"4138","20c15017":"4150","9f61d8e1":"4152","7dcbb8ba":"4186",c4f5d8e4:"4195","3bd732bb":"4203","39a4b53d":"4258",e2886f4d:"4377","9ca9b220":"4378",d1db332c:"4380",c56769ee:"4392","1791646b":"4539","9a9953e7":"4546",e526d9fb:"4579","8fde3252":"4592",e64000bb:"4612",be9b1ba5:"4624","65df3d35":"4643","6cdfbbfb":"4651","86a6f4a6":"4670","0d73263b":"4696",c9cfd710:"4756",caa6cc64:"4779","9c4aba92":"4840",a43fb5c1:"4845",ebba64f8:"4846","6b366f12":"4849",e6a6cdb5:"4869","91a9c488":"4871","8ef2f9fb":"4876","9260b226":"4887",bc29171d:"4900","3f753b27":"4923",ba18db30:"4980",fd1c180b:"5056","83a4731b":"5156","0843cb03":"5178","3ec050b2":"5181",c767f061:"5211","86ab4954":"5221",ea0aa512:"5232",ef3f5cc8:"5251","40712b22":"5268","97cfc084":"5297","037dd35f":"5446","9c5aab0e":"5451","1d91761b":"5500","04da809a":"5578","87d8598c":"5585","8af1d301":"5593",d0a2eb8e:"5616",f6025ed5:"5617","50f3a74f":"5631","7f23633c":"5638",d09aafa8:"5646",f7a674b2:"5694","00099f85":"5701","9a26ec38":"5729","13a7da5f":"5733","064c7463":"5777","5e6a0b05":"5792",c78e0dfd:"5848",bd384662:"5860","76097a60":"5866","1c223750":"5870","6f4e447b":"5904","137061ef":"5947","34dce56b":"6004",f6ba9a4b:"6016","638e6f40":"6055","014f04cc":"6057","03f88f06":"6082",bbd70f53:"6111","425c25af":"6114","22d76b2d":"6146",c3917577:"6174",beeb3fc3:"6181","5b25eae8":"6187",b54aa47d:"6192","736b32a3":"6197",e54bfd1f:"6268",f35ad539:"6303",c25ed854:"6324","612db47a":"6346","2e50ccc4":"6395","331b2a3d":"6405","72c0ad31":"6406","850e3a3d":"6415",ca9e19a0:"6469","5684741f":"6522",c87023c4:"6525","136f9a14":"6552","14a50b22":"6572","0012aeda":"6583",d9c8eb9a:"6643","1fe02719":"6657","2440862d":"6669","1ecfc0b9":"6696","1cb4afcc":"6763","6766c2ba":"6775",d78c0d88:"6783","2cc56763":"6820",b7d359f1:"6885",c2065ba5:"6902","24e8d336":"6950","7a19cc40":"6960","1ac84465":"6994",b68c61f5:"7030","11829f95":"7031",e0d9e15f:"7053","8df24095":"7055",bf29d81a:"7068","66ba8f65":"7071",de2333f9:"7106","0c3f6a2e":"7150",cb1fb814:"7211",b217b1df:"7218",b9567f41:"7281","93eb8f00":"7285","14609be1":"7307","3044fa47":"7322","634aee6c":"7356",a5854c89:"7367","3bb6078f":"7374",c29dbf77:"7378","976110e4":"7397",deffa85b:"7399",da8fb6e6:"7406","8d306d14":"7474","69138a9b":"7590",db1d00c4:"7595","7ef71a47":"7599","33c915ea":"7626","14da3ce7":"7666",b672ebd6:"7732","5d50bbf1":"7741",c0fb62f3:"7743",f440e5d3:"7764",b929e89b:"7781",abb3dda4:"7844",a4f4c0c8:"7845","026a1d69":"7886",b218484e:"7903","7b3ecbf1":"7909","7815c2d3":"7916","5acc7ccb":"7934",fcea3b45:"7942","3592d2f2":"7992","6789c389":"8001",e2a686c7:"8031","186b8a18":"8037",ed08832e:"8049","7f6538f4":"8095",c3a4d6bc:"8108",ded32efe:"8130","80055ea8":"8136",a647d08a:"8173","21e4306c":"8211","0066c128":"8262","491836cf":"8282",e94dfc49:"8308","5531b81f":"8335",ee8b4f50:"8339","4ce92582":"8342","2ec0be4c":"8351","3411c643":"8357",d70b4d73:"8385",c4b0d767:"8441","6eb9aa01":"8461",d86f913f:"8473",a9e28e86:"8502",b800115e:"8522","9050039c":"8540","8607f33a":"8550",c90cac61:"8562","05d43200":"8598","11433b40":"8629","1ddcee41":"8654",ffbf113e:"8663",f61db2e5:"8669",c6ff1e84:"8682","17b33b39":"8687","730767f4":"8743","5cf2c6e0":"8791",f8bf4ac5:"8805",a363e5d2:"8846","7c48a47e":"8859",f9a9d4c2:"8951",b022ea46:"8969","2246c66d":"8986","3f48ad20":"8991","17fed085":"9006","87726f30":"9023",a34b52ce:"9035","0e2af38d":"9041","8372258a":"9076","4cf33c28":"9084",bf69fc30:"9113",c7f18df2:"9122",abbc0c33:"9138","6e0bb75c":"9178",ebf8c8a4:"9192","629b6576":"9196","3f07749a":"9199",cf9c4b04:"9211","0a998885":"9232",cbfa528b:"9249",e1e94bbc:"9263","2c6e2254":"9272",b6c885a5:"9290",ee4ead70:"9295","92fa1062":"9342","25be17b9":"9389",ae4d2163:"9412",b26f55a5:"9418","7381f606":"9421","318dfdf9":"9433","94320cd8":"9441","7b53c4c5":"9444","1be78505":"9514",a47a33ba:"9521",dc0ec182:"9522",bb7ded3b:"9547",ef1ef56c:"9550","58efeb0f":"9552","76831a2f":"9562",ca99f506:"9578",a3d44527:"9609","5b83d837":"9632","1547da37":"9685",df9d0e7b:"9693","1020a002":"9694","87d315c4":"9716","4698369b":"9773","286c567a":"9782","07c6cf68":"9815","3630fad3":"9861","2d2c1853":"9877","3521ddbf":"9905","0de1e94b":"9940","8296c7ad":"9946",d288ceb1:"9999"}[e]||e,n.p+n.u(e)},function(){var e={1303:0,532:0};n.f.j=function(f,c){var a=n.o(e,f)?e[f]:void 0;if(0!==a)if(a)c.push(a[2]);else if(/^(1303|532)$/.test(f))e[f]=0;else{var b=new Promise((function(c,b){a=e[f]=[c,b]}));c.push(a[2]=b);var d=n.p+n.u(f),t=new Error;n.l(d,(function(c){if(n.o(e,f)&&(0!==(a=e[f])&&(e[f]=void 0),a)){var b=c&&("load"===c.type?"missing":c.type),d=c&&c.target&&c.target.src;t.message="Loading chunk "+f+" failed.\n("+b+": "+d+")",t.name="ChunkLoadError",t.type=b,t.request=d,a[1](t)}}),"chunk-"+f,f)}},n.O.j=function(f){return 0===e[f]};var f=function(f,c){var a,b,d=c[0],t=c[1],r=c[2],o=0;if(d.some((function(f){return 0!==e[f]}))){for(a in t)n.o(t,a)&&(n.m[a]=t[a]);if(r)var u=r(n)}for(f&&f(c);o<d.length;o++)b=d[o],n.o(e,b)&&e[b]&&e[b][0](),e[b]=0;return n.O(u)},c=self.webpackChunksite_3=self.webpackChunksite_3||[];c.forEach(f.bind(null,0)),c.push=f.bind(null,c.push.bind(c))}()}();
\ No newline at end of file
diff --git a/content/bps/BP-20-github-workflow-for-bookkeeper-proposals/index.html b/content/bps/BP-20-github-workflow-for-bookkeeper-proposals/index.html
index eeebbf2..d3dc1f9 100644
--- a/content/bps/BP-20-github-workflow-for-bookkeeper-proposals/index.html
+++ b/content/bps/BP-20-github-workflow-for-bookkeeper-proposals/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-20: github workflow for bookkeeper proposals | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-20-github-workflow-for-bookkeeper-proposals"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-20: github workflow for bookkeeper proposals | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-20-github-workflow-for-bookkeeper-proposals"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-20-github-workflow-for-bookkeeper-proposals" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-20-github-workflow-for-bookkeeper-proposals" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-21-new-api-close-inconsistencies/index.html b/content/bps/BP-21-new-api-close-inconsistencies/index.html
index 7211480..fa27554 100644
--- a/content/bps/BP-21-new-api-close-inconsistencies/index.html
+++ b/content/bps/BP-21-new-api-close-inconsistencies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-21: New API close inconsistencies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-21-new-api-close-inconsistencies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-21: New API close inconsistencies | Apache BookKeeper"><meta data-rh="true" name="description" content="Rejected due to lack of agreement that the issues raised in the motivation are valid."><meta data-rh="true" property="og:description" content="Rejected due to lack of agreement that the issues raised in the motivation are valid."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-21-new-api-close-inconsistencies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-21-new-api-close-inconsistencies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-21-new-api-close-inconsistencies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-22-separate-closing-ledgers-from-opening-ledgers/index.html b/content/bps/BP-22-separate-closing-ledgers-from-opening-ledgers/index.html
index f8517d2..b22d739 100644
--- a/content/bps/BP-22-separate-closing-ledgers-from-opening-ledgers/index.html
+++ b/content/bps/BP-22-separate-closing-ledgers-from-opening-ledgers/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-22: Separate closing ledgers from opening ledgers | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-22-separate-closing-ledgers-from-opening-ledgers"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-22: Separate closing ledgers from opening ledgers | Apache BookKeeper"><meta data-rh="true" name="description" content="Rejected due to lack of agreement that the issues raised in the motivation are valid."><meta data-rh="true" property="og:description" content="Rejected due to lack of agreement that the issues raised in the motivation are valid."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-22-separate-closing-ledgers-from-opening-ledgers"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-22-separate-closing-ledgers-from-opening-ledgers" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-22-separate-closing-ledgers-from-opening-ledgers" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-25-MovingChecksumToProto/index.html b/content/bps/BP-25-MovingChecksumToProto/index.html
index 2ea4c32..14ab94e 100644
--- a/content/bps/BP-25-MovingChecksumToProto/index.html
+++ b/content/bps/BP-25-MovingChecksumToProto/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-25: MovingChecksumToProto--Refactor the checksum part of bookkeeper | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-25-MovingChecksumToProto"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-25: MovingChecksumToProto--Refactor the checksum part of bookkeeper | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-25-MovingChecksumToProto"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-25-MovingChecksumToProto" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-25-MovingChecksumToProto" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-26-move-distributedlog-core-library/index.html b/content/bps/BP-26-move-distributedlog-core-library/index.html
index 727ac80..f07c8b5 100644
--- a/content/bps/BP-26-move-distributedlog-core-library/index.html
+++ b/content/bps/BP-26-move-distributedlog-core-library/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-26: Move distributedlog library as part of bookkeeper | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-26-move-distributedlog-core-library"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-26: Move distributedlog library as part of bookkeeper | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-26-move-distributedlog-core-library"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-26-move-distributedlog-core-library" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-26-move-distributedlog-core-library" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-27-new-bookkeeper-cli/index.html b/content/bps/BP-27-new-bookkeeper-cli/index.html
index 8cb26e8..126de4c 100644
--- a/content/bps/BP-27-new-bookkeeper-cli/index.html
+++ b/content/bps/BP-27-new-bookkeeper-cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-27: New BookKeeper CLI | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-27-new-bookkeeper-cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-27: New BookKeeper CLI | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-27-new-bookkeeper-cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-27-new-bookkeeper-cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-27-new-bookkeeper-cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-28-etcd-as-metadata-store/index.html b/content/bps/BP-28-etcd-as-metadata-store/index.html
index b38b56b..c46aa93 100644
--- a/content/bps/BP-28-etcd-as-metadata-store/index.html
+++ b/content/bps/BP-28-etcd-as-metadata-store/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-28: use etcd as metadata store | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-28-etcd-as-metadata-store"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-28: use etcd as metadata store | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-28-etcd-as-metadata-store"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-28-etcd-as-metadata-store" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-28-etcd-as-metadata-store" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-29-metadata-store-api-module/index.html b/content/bps/BP-29-metadata-store-api-module/index.html
index c6eaa7d..9f3380c 100644
--- a/content/bps/BP-29-metadata-store-api-module/index.html
+++ b/content/bps/BP-29-metadata-store-api-module/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-29: Metadata API module | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-29-metadata-store-api-module"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-29: Metadata API module | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-29-metadata-store-api-module"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-29-metadata-store-api-module" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-29-metadata-store-api-module" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -39,7 +39,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-31-durability/index.html b/content/bps/BP-31-durability/index.html
index a1177b9..f04da0a 100644
--- a/content/bps/BP-31-durability/index.html
+++ b/content/bps/BP-31-durability/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-31: BookKeeper Durability (Anchor) | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-31-durability"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-31: BookKeeper Durability (Anchor) | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-31-durability"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-31-durability" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-31-durability" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-32-advisory-write-close/index.html b/content/bps/BP-32-advisory-write-close/index.html
index 2228281..3da3421 100644
--- a/content/bps/BP-32-advisory-write-close/index.html
+++ b/content/bps/BP-32-advisory-write-close/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-32: Advisory (optimistic) write close | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-32-advisory-write-close"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-32: Advisory (optimistic) write close | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-32-advisory-write-close"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-32-advisory-write-close" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-32-advisory-write-close" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-33-building-official-docker-imags/index.html b/content/bps/BP-33-building-official-docker-imags/index.html
index e4decda..11512d6 100644
--- a/content/bps/BP-33-building-official-docker-imags/index.html
+++ b/content/bps/BP-33-building-official-docker-imags/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-33: Move releasing official docker images out of main repo | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-33-building-official-docker-imags"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-33: Move releasing official docker images out of main repo | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-33-building-official-docker-imags"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-33-building-official-docker-imags" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-33-building-official-docker-imags" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-34-cluster-metadata-checker/index.html b/content/bps/BP-34-cluster-metadata-checker/index.html
index e04cb73..c615aad 100644
--- a/content/bps/BP-34-cluster-metadata-checker/index.html
+++ b/content/bps/BP-34-cluster-metadata-checker/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-34: Cluster Metadata Checker | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-34-cluster-metadata-checker"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-34: Cluster Metadata Checker | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-34-cluster-metadata-checker"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-34-cluster-metadata-checker" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-34-cluster-metadata-checker" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-35-128-bits-support/index.html b/content/bps/BP-35-128-bits-support/index.html
index b32013f..b73c4a5 100644
--- a/content/bps/BP-35-128-bits-support/index.html
+++ b/content/bps/BP-35-128-bits-support/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-35: 128 bits support | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-35-128-bits-support"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-35: 128 bits support | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-35-128-bits-support"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-35-128-bits-support" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-35-128-bits-support" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -85,7 +85,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-36-stats-documentation-annotation/index.html b/content/bps/BP-36-stats-documentation-annotation/index.html
index 4a8d29a..af7846b 100644
--- a/content/bps/BP-36-stats-documentation-annotation/index.html
+++ b/content/bps/BP-36-stats-documentation-annotation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-36: Stats documentation annotation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-36-stats-documentation-annotation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-36: Stats documentation annotation | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-36-stats-documentation-annotation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-36-stats-documentation-annotation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-36-stats-documentation-annotation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-37-conf-documentation/index.html b/content/bps/BP-37-conf-documentation/index.html
index 360f9d8..d0d24cf 100644
--- a/content/bps/BP-37-conf-documentation/index.html
+++ b/content/bps/BP-37-conf-documentation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-37: Improve configuration management for better documentation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-37-conf-documentation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-37: Improve configuration management for better documentation | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-37-conf-documentation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-37-conf-documentation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-37-conf-documentation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -36,7 +36,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-38-bookie-endpoint-discovery/index.html b/content/bps/BP-38-bookie-endpoint-discovery/index.html
index 3e5b545..b6cfcfd 100644
--- a/content/bps/BP-38-bookie-endpoint-discovery/index.html
+++ b/content/bps/BP-38-bookie-endpoint-discovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-38: Publish Bookie Service Info on Metadata Service | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-38-bookie-endpoint-discovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-38: Publish Bookie Service Info on Metadata Service | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-38-bookie-endpoint-discovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-38-bookie-endpoint-discovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-38-bookie-endpoint-discovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -40,7 +40,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-41-bookieid/index.html b/content/bps/BP-41-bookieid/index.html
index 74a9806..30c397f 100644
--- a/content/bps/BP-41-bookieid/index.html
+++ b/content/bps/BP-41-bookieid/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-41: Separate BookieId from Bookie Network Address | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-41-bookieid"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-41: Separate BookieId from Bookie Network Address | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-41-bookieid"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-41-bookieid" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-41-bookieid" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -48,7 +48,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-42-new-api-list-ledgers/index.html b/content/bps/BP-42-new-api-list-ledgers/index.html
index e8c79d5..27c567d 100644
--- a/content/bps/BP-42-new-api-list-ledgers/index.html
+++ b/content/bps/BP-42-new-api-list-ledgers/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-42: New Client API - list ledgers | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-42-new-api-list-ledgers"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-42: New Client API - list ledgers | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-42-new-api-list-ledgers"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-42-new-api-list-ledgers" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-42-new-api-list-ledgers" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-43-gradle-migration/index.html b/content/bps/BP-43-gradle-migration/index.html
index a69ff84..a6e609d 100644
--- a/content/bps/BP-43-gradle-migration/index.html
+++ b/content/bps/BP-43-gradle-migration/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-43: Gradle migration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-43-gradle-migration"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-43: Gradle migration | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-43-gradle-migration"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-43-gradle-migration" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-43-gradle-migration" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-44-use-metrics/index.html b/content/bps/BP-44-use-metrics/index.html
index 2775ebb..9456407 100644
--- a/content/bps/BP-44-use-metrics/index.html
+++ b/content/bps/BP-44-use-metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-44: USE metrics | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-44-use-metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-44: USE metrics | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-44-use-metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-44-use-metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-44-use-metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-46-run-without-journal/index.html b/content/bps/BP-46-run-without-journal/index.html
index b51a8a0..26280c3 100644
--- a/content/bps/BP-46-run-without-journal/index.html
+++ b/content/bps/BP-46-run-without-journal/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-46: Running without the journal | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-46-run-without-journal"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-46: Running without the journal | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-46-run-without-journal"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-46-run-without-journal" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-46-run-without-journal" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-62-new-API-for-batched-reads/index.html b/content/bps/BP-62-new-API-for-batched-reads/index.html
index dc915b0..71bf6a4 100644
--- a/content/bps/BP-62-new-API-for-batched-reads/index.html
+++ b/content/bps/BP-62-new-API-for-batched-reads/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-62 New API for batched reads | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-62-new-API-for-batched-reads"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-62 New API for batched reads | Apache BookKeeper"><meta data-rh="true" name="description" content="The BookKeeper client has provided an API [0] that allows for the efficient reading of entries [1] from bookies."><meta data-rh="true" property="og:description" content="The BookKeeper client has provided an API [0] that allows for the efficient reading of entries [1] from bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-62-new-API-for-batched-reads"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-62-new-API-for-batched-reads" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-62-new-API-for-batched-reads" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -109,7 +109,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication/index.html b/content/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication/index.html
index 53c241d..cffa2ed 100644
--- a/content/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication/index.html
+++ b/content/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-66: support throttling for zookeeper read during rereplication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-66: support throttling for zookeeper read during rereplication | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-66-support-throttling-for-zookeeper-read-during-rereplication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -30,7 +30,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/bps/BP-template/index.html b/content/bps/BP-template/index.html
index 0fc5cab..4e4180b 100644
--- a/content/bps/BP-template/index.html
+++ b/content/bps/BP-template/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BP-XYZ: caption of bookkeeper proposal | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/bps/BP-template"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BP-XYZ: caption of bookkeeper proposal | Apache BookKeeper"><meta data-rh="true" name="description" content="Motivation"><meta data-rh="true" property="og:description" content="Motivation"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/bps/BP-template"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-template" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/bps/BP-template" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/bookkeeper-proposals/index.html b/content/community/bookkeeper-proposals/index.html
index 4567c22..89d2a11 100644
--- a/content/community/bookkeeper-proposals/index.html
+++ b/content/community/bookkeeper-proposals/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Proposals | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/bookkeeper-proposals"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="BookKeeper Proposals | Apache BookKeeper"><meta data-rh="true" name="description" content="This page describes a proposed BookKeeper Proposal (BP) process for proposing a major change to BookKeeper."><meta data-rh="true" property="og:description" content="This page describes a proposed BookKeeper Proposal (BP) process for proposing a major change to BookKeeper."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/bookkeeper-proposals"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/bookkeeper-proposals" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/bookkeeper-proposals" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/coding-guide/index.html b/content/community/coding-guide/index.html
index 174e5ae..8c40699 100644
--- a/content/community/coding-guide/index.html
+++ b/content/community/coding-guide/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Coding guide | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/coding-guide"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Coding guide | Apache BookKeeper"><meta data-rh="true" name="description" content="These guidelines are meant to encourage consistency and best practices among people working on Apache BookKeeper code base."><meta data-rh="true" property="og:description" content="These guidelines are meant to encourage consistency and best practices among people working on Apache BookKeeper code base."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/coding-guide"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/coding-guide" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/coding-guide" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/contributing/index.html b/content/community/contributing/index.html
index 7dae618..621f4c5 100644
--- a/content/community/contributing/index.html
+++ b/content/community/contributing/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Contribution guide | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/contributing"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Contribution guide | Apache BookKeeper"><meta data-rh="true" name="description" content="The Apache BookKeeper community welcomes contributions from anyone with a passion for distributed systems! BookKeeper has many different opportunities for contributions --"><meta data-rh="true" property="og:description" content="The Apache BookKeeper community welcomes contributions from anyone with a passion for distributed systems! BookKeeper has many different opportunities for contributions --"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/contributing"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/contributing" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/contributing" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -37,7 +37,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/issue-report/index.html b/content/community/issue-report/index.html
index 47bcecc..2cf6e15 100644
--- a/content/community/issue-report/index.html
+++ b/content/community/issue-report/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Issue report | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/issue-report"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Issue report | Apache BookKeeper"><meta data-rh="true" name="description" content="To report an issue, you will need to create a New Issue."><meta data-rh="true" property="og:description" content="To report an issue, you will need to create a New Issue."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/issue-report"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/issue-report" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/issue-report" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -26,7 +26,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/licensing/index.html b/content/community/licensing/index.html
index 0af52a8..3e7c2fb 100644
--- a/content/community/licensing/index.html
+++ b/content/community/licensing/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Third party dependencies and licensing | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/licensing"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Third party dependencies and licensing | Apache BookKeeper"><meta data-rh="true" name="description" content="The bookkeeper project ships one source distribution and two binary distributions."><meta data-rh="true" property="og:description" content="The bookkeeper project ships one source distribution and two binary distributions."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/licensing"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/licensing" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/licensing" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/mailing-lists/index.html b/content/community/mailing-lists/index.html
index 2f36098..3e8e4b3 100644
--- a/content/community/mailing-lists/index.html
+++ b/content/community/mailing-lists/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Mailing lists | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/mailing-lists"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Mailing lists | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper has several mailing lists that you can participate in."><meta data-rh="true" property="og:description" content="Apache BookKeeper has several mailing lists that you can participate in."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/mailing-lists"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/mailing-lists" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/mailing-lists" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/meeting/index.html b/content/community/meeting/index.html
index 15e1642..eadeeeb 100644
--- a/content/community/meeting/index.html
+++ b/content/community/meeting/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Community meetings | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/meeting"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Community meetings | Apache BookKeeper"><meta data-rh="true" name="description" content="The community meeting runs bi-weekly on Thursday 8am - 9am PST."><meta data-rh="true" property="og:description" content="The community meeting runs bi-weekly on Thursday 8am - 9am PST."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/meeting"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/meeting" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/meeting" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/presentations/index.html b/content/community/presentations/index.html
index cec0089..221d835 100644
--- a/content/community/presentations/index.html
+++ b/content/community/presentations/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Papers and Presentations | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/presentations"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Papers and Presentations | Apache BookKeeper"><meta data-rh="true" name="description" content="Papers"><meta data-rh="true" property="og:description" content="Papers"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/presentations"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/presentations" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/presentations" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/release-guide/index.html b/content/community/release-guide/index.html
index 4f1cadf..594371c 100644
--- a/content/community/release-guide/index.html
+++ b/content/community/release-guide/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper Release Guide | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/release-guide"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Apache BookKeeper Release Guide | Apache BookKeeper"><meta data-rh="true" name="description" content="This page documents the procedure to make an Apache BookKeeper release."><meta data-rh="true" property="og:description" content="This page documents the procedure to make an Apache BookKeeper release."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/release-guide"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/release-guide" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/release-guide" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -51,7 +51,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/releases/index.html b/content/community/releases/index.html
index b35eb43..0770797 100644
--- a/content/community/releases/index.html
+++ b/content/community/releases/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Release Management | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/releases"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Release Management | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper community adopts Time Based Release Plan starting from 4.6.0."><meta data-rh="true" property="og:description" content="Apache BookKeeper community adopts Time Based Release Plan starting from 4.6.0."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/releases"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/releases" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/releases" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/slack/index.html b/content/community/slack/index.html
index 23002ef..8758e4c 100644
--- a/content/community/slack/index.html
+++ b/content/community/slack/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Slack | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/slack"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Slack | Apache BookKeeper"><meta data-rh="true" name="description" content="There is an Apache BookKeeper channel that is used for informal discussions for BookKeeper developers and users."><meta data-rh="true" property="og:description" content="There is an Apache BookKeeper channel that is used for informal discussions for BookKeeper developers and users."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/slack"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/slack" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/slack" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/community/testing/index.html b/content/community/testing/index.html
index a5b88ca..4baaed0 100644
--- a/content/community/testing/index.html
+++ b/content/community/testing/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Testing guide | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/community/testing"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Testing guide | Apache BookKeeper"><meta data-rh="true" name="description" content="Overview"><meta data-rh="true" property="og:description" content="Overview"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/community/testing"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/testing" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/community/testing" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -32,7 +32,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/autorecovery/index.html b/content/docs/4.10.0/admin/autorecovery/index.html
index 9a5e382..7ad6beb 100644
--- a/content/docs/4.10.0/admin/autorecovery/index.html
+++ b/content/docs/4.10.0/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/bookies/index.html b/content/docs/4.10.0/admin/bookies/index.html
index 9435591..3fafd6b 100644
--- a/content/docs/4.10.0/admin/bookies/index.html
+++ b/content/docs/4.10.0/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/geo-replication/index.html b/content/docs/4.10.0/admin/geo-replication/index.html
index c60fbaa..cf0a5ea 100644
--- a/content/docs/4.10.0/admin/geo-replication/index.html
+++ b/content/docs/4.10.0/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/http/index.html b/content/docs/4.10.0/admin/http/index.html
index 2ee7912..3d30ac1 100644
--- a/content/docs/4.10.0/admin/http/index.html
+++ b/content/docs/4.10.0/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/metrics/index.html b/content/docs/4.10.0/admin/metrics/index.html
index f4ced47..d366e53 100644
--- a/content/docs/4.10.0/admin/metrics/index.html
+++ b/content/docs/4.10.0/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/perf/index.html b/content/docs/4.10.0/admin/perf/index.html
index 99aecb5..7bc7deb 100644
--- a/content/docs/4.10.0/admin/perf/index.html
+++ b/content/docs/4.10.0/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/placement/index.html b/content/docs/4.10.0/admin/placement/index.html
index 1335c37..8e9a0af 100644
--- a/content/docs/4.10.0/admin/placement/index.html
+++ b/content/docs/4.10.0/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/admin/upgrade/index.html b/content/docs/4.10.0/admin/upgrade/index.html
index bbb2803..5800120 100644
--- a/content/docs/4.10.0/admin/upgrade/index.html
+++ b/content/docs/4.10.0/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/api/distributedlog-api/index.html b/content/docs/4.10.0/api/distributedlog-api/index.html
index a7a1998..0452c28 100644
--- a/content/docs/4.10.0/api/distributedlog-api/index.html
+++ b/content/docs/4.10.0/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/api/ledger-adv-api/index.html b/content/docs/4.10.0/api/ledger-adv-api/index.html
index b3b9de6..3e0bd37 100644
--- a/content/docs/4.10.0/api/ledger-adv-api/index.html
+++ b/content/docs/4.10.0/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/api/ledger-api/index.html b/content/docs/4.10.0/api/ledger-api/index.html
index fef6fa1..7602a50 100644
--- a/content/docs/4.10.0/api/ledger-api/index.html
+++ b/content/docs/4.10.0/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/api/overview/index.html b/content/docs/4.10.0/api/overview/index.html
index f9aad41..5acdd40 100644
--- a/content/docs/4.10.0/api/overview/index.html
+++ b/content/docs/4.10.0/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/deployment/kubernetes/index.html b/content/docs/4.10.0/deployment/kubernetes/index.html
index 3dbbeb7..0e2380d 100644
--- a/content/docs/4.10.0/deployment/kubernetes/index.html
+++ b/content/docs/4.10.0/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.10.0/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.10.0/overview/">4.10.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.10.0/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.10.0/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.10.0/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.10.0/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.10.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.10.0/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.10.0/overview/">4.10.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.10.0/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.10.0/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.10.0/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.10.0/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.10.0/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.10.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/deployment/manual/index.html b/content/docs/4.10.0/deployment/manual/index.html
index 2aa67dc..867bc0e 100644
--- a/content/docs/4.10.0/deployment/manual/index.html
+++ b/content/docs/4.10.0/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/development/codebase/index.html b/content/docs/4.10.0/development/codebase/index.html
index c5a629b..958fa06 100644
--- a/content/docs/4.10.0/development/codebase/index.html
+++ b/content/docs/4.10.0/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/development/protocol/index.html b/content/docs/4.10.0/development/protocol/index.html
index a87ac8b..cbbaeb1 100644
--- a/content/docs/4.10.0/development/protocol/index.html
+++ b/content/docs/4.10.0/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/getting-started/concepts/index.html b/content/docs/4.10.0/getting-started/concepts/index.html
index dbfd313..002cb4a 100644
--- a/content/docs/4.10.0/getting-started/concepts/index.html
+++ b/content/docs/4.10.0/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/getting-started/installation/index.html b/content/docs/4.10.0/getting-started/installation/index.html
index ffed41c..88aee16 100644
--- a/content/docs/4.10.0/getting-started/installation/index.html
+++ b/content/docs/4.10.0/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/getting-started/run-locally/index.html b/content/docs/4.10.0/getting-started/run-locally/index.html
index 55245a6..8821493 100644
--- a/content/docs/4.10.0/getting-started/run-locally/index.html
+++ b/content/docs/4.10.0/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/overview/index.html b/content/docs/4.10.0/overview/index.html
index 77cb4b9..ad1d086 100644
--- a/content/docs/4.10.0/overview/index.html
+++ b/content/docs/4.10.0/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.10.0 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.10.0 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/reference/cli/index.html b/content/docs/4.10.0/reference/cli/index.html
index 8026e42..c3948f0 100644
--- a/content/docs/4.10.0/reference/cli/index.html
+++ b/content/docs/4.10.0/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/reference/config/index.html b/content/docs/4.10.0/reference/config/index.html
index 5fc63ad..72c3dd8 100644
--- a/content/docs/4.10.0/reference/config/index.html
+++ b/content/docs/4.10.0/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/reference/metrics/index.html b/content/docs/4.10.0/reference/metrics/index.html
index 01bd007..0d678c5 100644
--- a/content/docs/4.10.0/reference/metrics/index.html
+++ b/content/docs/4.10.0/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/security/overview/index.html b/content/docs/4.10.0/security/overview/index.html
index 5502fb6..85b3741 100644
--- a/content/docs/4.10.0/security/overview/index.html
+++ b/content/docs/4.10.0/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/security/sasl/index.html b/content/docs/4.10.0/security/sasl/index.html
index 8cd5668..a55b979 100644
--- a/content/docs/4.10.0/security/sasl/index.html
+++ b/content/docs/4.10.0/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/security/tls/index.html b/content/docs/4.10.0/security/tls/index.html
index 31b9386..ba19401 100644
--- a/content/docs/4.10.0/security/tls/index.html
+++ b/content/docs/4.10.0/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.10.0/security/zookeeper/index.html b/content/docs/4.10.0/security/zookeeper/index.html
index e6b7e7a..ad6eae7 100644
--- a/content/docs/4.10.0/security/zookeeper/index.html
+++ b/content/docs/4.10.0/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.10.0/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.10.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" name="docsearch:version" content="4.10.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.10.0"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.10.0/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.10.0/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/autorecovery/index.html b/content/docs/4.11.1/admin/autorecovery/index.html
index 31fdd6b..950dc21 100644
--- a/content/docs/4.11.1/admin/autorecovery/index.html
+++ b/content/docs/4.11.1/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/bookies/index.html b/content/docs/4.11.1/admin/bookies/index.html
index 11e3e74..8b8b580 100644
--- a/content/docs/4.11.1/admin/bookies/index.html
+++ b/content/docs/4.11.1/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/decomission/index.html b/content/docs/4.11.1/admin/decomission/index.html
index 17341cd..47eb330 100644
--- a/content/docs/4.11.1/admin/decomission/index.html
+++ b/content/docs/4.11.1/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/geo-replication/index.html b/content/docs/4.11.1/admin/geo-replication/index.html
index bc85e04..1663fcf 100644
--- a/content/docs/4.11.1/admin/geo-replication/index.html
+++ b/content/docs/4.11.1/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/http/index.html b/content/docs/4.11.1/admin/http/index.html
index 38596df..8d3b507 100644
--- a/content/docs/4.11.1/admin/http/index.html
+++ b/content/docs/4.11.1/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/metrics/index.html b/content/docs/4.11.1/admin/metrics/index.html
index 8e01c11..73c6c29 100644
--- a/content/docs/4.11.1/admin/metrics/index.html
+++ b/content/docs/4.11.1/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/perf/index.html b/content/docs/4.11.1/admin/perf/index.html
index 5437bb3..0c1928e 100644
--- a/content/docs/4.11.1/admin/perf/index.html
+++ b/content/docs/4.11.1/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/placement/index.html b/content/docs/4.11.1/admin/placement/index.html
index e448aab..7a76708 100644
--- a/content/docs/4.11.1/admin/placement/index.html
+++ b/content/docs/4.11.1/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/admin/upgrade/index.html b/content/docs/4.11.1/admin/upgrade/index.html
index c15653b..66ecd0f 100644
--- a/content/docs/4.11.1/admin/upgrade/index.html
+++ b/content/docs/4.11.1/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/api/distributedlog-api/index.html b/content/docs/4.11.1/api/distributedlog-api/index.html
index 345cb77..ce9924c 100644
--- a/content/docs/4.11.1/api/distributedlog-api/index.html
+++ b/content/docs/4.11.1/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/api/ledger-adv-api/index.html b/content/docs/4.11.1/api/ledger-adv-api/index.html
index 4519d49..552e5d5 100644
--- a/content/docs/4.11.1/api/ledger-adv-api/index.html
+++ b/content/docs/4.11.1/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/api/ledger-api/index.html b/content/docs/4.11.1/api/ledger-api/index.html
index 6414569..2c2e42b 100644
--- a/content/docs/4.11.1/api/ledger-api/index.html
+++ b/content/docs/4.11.1/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/api/overview/index.html b/content/docs/4.11.1/api/overview/index.html
index 81ca070..1686e4d 100644
--- a/content/docs/4.11.1/api/overview/index.html
+++ b/content/docs/4.11.1/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/deployment/kubernetes/index.html b/content/docs/4.11.1/deployment/kubernetes/index.html
index 5a997cd..cd6617f 100644
--- a/content/docs/4.11.1/deployment/kubernetes/index.html
+++ b/content/docs/4.11.1/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.11.1/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.11.1/overview/">4.11.1</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.11.1/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.11.1/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.11.1/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.11.1/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.11.1</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.11.1/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.11.1/overview/">4.11.1</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.11.1/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.11.1/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.11.1/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.11.1/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.11.1/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.11.1</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/deployment/manual/index.html b/content/docs/4.11.1/deployment/manual/index.html
index 95a63e9..bc42275 100644
--- a/content/docs/4.11.1/deployment/manual/index.html
+++ b/content/docs/4.11.1/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/development/codebase/index.html b/content/docs/4.11.1/development/codebase/index.html
index 9cde703..dc7b794 100644
--- a/content/docs/4.11.1/development/codebase/index.html
+++ b/content/docs/4.11.1/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/development/protocol/index.html b/content/docs/4.11.1/development/protocol/index.html
index 7ef90b3..745a681 100644
--- a/content/docs/4.11.1/development/protocol/index.html
+++ b/content/docs/4.11.1/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/getting-started/concepts/index.html b/content/docs/4.11.1/getting-started/concepts/index.html
index 19fbb12..eb6d1cd 100644
--- a/content/docs/4.11.1/getting-started/concepts/index.html
+++ b/content/docs/4.11.1/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/getting-started/installation/index.html b/content/docs/4.11.1/getting-started/installation/index.html
index be18d02..b75ac9b 100644
--- a/content/docs/4.11.1/getting-started/installation/index.html
+++ b/content/docs/4.11.1/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/getting-started/run-locally/index.html b/content/docs/4.11.1/getting-started/run-locally/index.html
index 1ce87f6..25ddae7 100644
--- a/content/docs/4.11.1/getting-started/run-locally/index.html
+++ b/content/docs/4.11.1/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/overview/index.html b/content/docs/4.11.1/overview/index.html
index aaadf3c..d36693d 100644
--- a/content/docs/4.11.1/overview/index.html
+++ b/content/docs/4.11.1/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.11.1 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.11.1 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/reference/cli/index.html b/content/docs/4.11.1/reference/cli/index.html
index 95801d2..2c3f9a6 100644
--- a/content/docs/4.11.1/reference/cli/index.html
+++ b/content/docs/4.11.1/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/reference/config/index.html b/content/docs/4.11.1/reference/config/index.html
index 82bccaa..7858d20 100644
--- a/content/docs/4.11.1/reference/config/index.html
+++ b/content/docs/4.11.1/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/reference/metrics/index.html b/content/docs/4.11.1/reference/metrics/index.html
index 0d20ecc..f2b58c3 100644
--- a/content/docs/4.11.1/reference/metrics/index.html
+++ b/content/docs/4.11.1/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/security/overview/index.html b/content/docs/4.11.1/security/overview/index.html
index e555754..cab8496 100644
--- a/content/docs/4.11.1/security/overview/index.html
+++ b/content/docs/4.11.1/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/security/sasl/index.html b/content/docs/4.11.1/security/sasl/index.html
index 4fbaa47..ba3495b 100644
--- a/content/docs/4.11.1/security/sasl/index.html
+++ b/content/docs/4.11.1/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/security/tls/index.html b/content/docs/4.11.1/security/tls/index.html
index 2d1375e..3f15966 100644
--- a/content/docs/4.11.1/security/tls/index.html
+++ b/content/docs/4.11.1/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.11.1/security/zookeeper/index.html b/content/docs/4.11.1/security/zookeeper/index.html
index 73b3923..5126c73 100644
--- a/content/docs/4.11.1/security/zookeeper/index.html
+++ b/content/docs/4.11.1/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.11.1/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.11.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" name="docsearch:version" content="4.11.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.11.1"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.11.1/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.11.1/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/autorecovery/index.html b/content/docs/4.12.1/admin/autorecovery/index.html
index 3d56e1e..a0f1133 100644
--- a/content/docs/4.12.1/admin/autorecovery/index.html
+++ b/content/docs/4.12.1/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/bookies/index.html b/content/docs/4.12.1/admin/bookies/index.html
index 7c251c8..7b87c13 100644
--- a/content/docs/4.12.1/admin/bookies/index.html
+++ b/content/docs/4.12.1/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/decomission/index.html b/content/docs/4.12.1/admin/decomission/index.html
index 1779d80..a7acba0 100644
--- a/content/docs/4.12.1/admin/decomission/index.html
+++ b/content/docs/4.12.1/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/geo-replication/index.html b/content/docs/4.12.1/admin/geo-replication/index.html
index 57b92c5..0bfdfec 100644
--- a/content/docs/4.12.1/admin/geo-replication/index.html
+++ b/content/docs/4.12.1/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/http/index.html b/content/docs/4.12.1/admin/http/index.html
index de6a4e4..ff0966c 100644
--- a/content/docs/4.12.1/admin/http/index.html
+++ b/content/docs/4.12.1/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/metrics/index.html b/content/docs/4.12.1/admin/metrics/index.html
index abf3203..427ca7f 100644
--- a/content/docs/4.12.1/admin/metrics/index.html
+++ b/content/docs/4.12.1/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/perf/index.html b/content/docs/4.12.1/admin/perf/index.html
index 90b4403..0bd98f7 100644
--- a/content/docs/4.12.1/admin/perf/index.html
+++ b/content/docs/4.12.1/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/placement/index.html b/content/docs/4.12.1/admin/placement/index.html
index ec79f63..9da1391 100644
--- a/content/docs/4.12.1/admin/placement/index.html
+++ b/content/docs/4.12.1/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/admin/upgrade/index.html b/content/docs/4.12.1/admin/upgrade/index.html
index 3451317..cce9209 100644
--- a/content/docs/4.12.1/admin/upgrade/index.html
+++ b/content/docs/4.12.1/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/api/distributedlog-api/index.html b/content/docs/4.12.1/api/distributedlog-api/index.html
index 14c7278..46d25ff 100644
--- a/content/docs/4.12.1/api/distributedlog-api/index.html
+++ b/content/docs/4.12.1/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/api/ledger-adv-api/index.html b/content/docs/4.12.1/api/ledger-adv-api/index.html
index 0e236b4..95a1d1c 100644
--- a/content/docs/4.12.1/api/ledger-adv-api/index.html
+++ b/content/docs/4.12.1/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/api/ledger-api/index.html b/content/docs/4.12.1/api/ledger-api/index.html
index f769c10..a2afc22 100644
--- a/content/docs/4.12.1/api/ledger-api/index.html
+++ b/content/docs/4.12.1/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/api/overview/index.html b/content/docs/4.12.1/api/overview/index.html
index 7ccc2e4..beffe44 100644
--- a/content/docs/4.12.1/api/overview/index.html
+++ b/content/docs/4.12.1/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/deployment/kubernetes/index.html b/content/docs/4.12.1/deployment/kubernetes/index.html
index 44f6ecc..29b5aae 100644
--- a/content/docs/4.12.1/deployment/kubernetes/index.html
+++ b/content/docs/4.12.1/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.12.1/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.12.1/overview/">4.12.1</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.12.1/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.12.1/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.12.1/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.12.1/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.12.1</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.12.1/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.12.1/overview/">4.12.1</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.12.1/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.12.1/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.12.1/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.12.1/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.12.1/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.12.1</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/deployment/manual/index.html b/content/docs/4.12.1/deployment/manual/index.html
index c54b437..85d8cc5 100644
--- a/content/docs/4.12.1/deployment/manual/index.html
+++ b/content/docs/4.12.1/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/development/codebase/index.html b/content/docs/4.12.1/development/codebase/index.html
index 0e1d763..e963abe 100644
--- a/content/docs/4.12.1/development/codebase/index.html
+++ b/content/docs/4.12.1/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/development/protocol/index.html b/content/docs/4.12.1/development/protocol/index.html
index eee12cf..acc7b84 100644
--- a/content/docs/4.12.1/development/protocol/index.html
+++ b/content/docs/4.12.1/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/getting-started/concepts/index.html b/content/docs/4.12.1/getting-started/concepts/index.html
index aa92598..5c80fe5 100644
--- a/content/docs/4.12.1/getting-started/concepts/index.html
+++ b/content/docs/4.12.1/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/getting-started/installation/index.html b/content/docs/4.12.1/getting-started/installation/index.html
index b8259f3..ecd2d18 100644
--- a/content/docs/4.12.1/getting-started/installation/index.html
+++ b/content/docs/4.12.1/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/getting-started/run-locally/index.html b/content/docs/4.12.1/getting-started/run-locally/index.html
index 4b95691..6cc0a97 100644
--- a/content/docs/4.12.1/getting-started/run-locally/index.html
+++ b/content/docs/4.12.1/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/overview/index.html b/content/docs/4.12.1/overview/index.html
index 0510fbf..d197693 100644
--- a/content/docs/4.12.1/overview/index.html
+++ b/content/docs/4.12.1/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.12.1 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.12.1 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/reference/cli/index.html b/content/docs/4.12.1/reference/cli/index.html
index 284f382..4004c8a 100644
--- a/content/docs/4.12.1/reference/cli/index.html
+++ b/content/docs/4.12.1/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/reference/config/index.html b/content/docs/4.12.1/reference/config/index.html
index be4221c..990e746 100644
--- a/content/docs/4.12.1/reference/config/index.html
+++ b/content/docs/4.12.1/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/reference/metrics/index.html b/content/docs/4.12.1/reference/metrics/index.html
index 3d89e2c..13c7f5d 100644
--- a/content/docs/4.12.1/reference/metrics/index.html
+++ b/content/docs/4.12.1/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/security/overview/index.html b/content/docs/4.12.1/security/overview/index.html
index dabcca1..e0cb882 100644
--- a/content/docs/4.12.1/security/overview/index.html
+++ b/content/docs/4.12.1/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/security/sasl/index.html b/content/docs/4.12.1/security/sasl/index.html
index 1b97fe0..4438dd9 100644
--- a/content/docs/4.12.1/security/sasl/index.html
+++ b/content/docs/4.12.1/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/security/tls/index.html b/content/docs/4.12.1/security/tls/index.html
index 5a2cd2b..2e203a6 100644
--- a/content/docs/4.12.1/security/tls/index.html
+++ b/content/docs/4.12.1/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.12.1/security/zookeeper/index.html b/content/docs/4.12.1/security/zookeeper/index.html
index bd3baac..cd5680a 100644
--- a/content/docs/4.12.1/security/zookeeper/index.html
+++ b/content/docs/4.12.1/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.12.1/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.12.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" name="docsearch:version" content="4.12.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.12.1"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.12.1/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.12.1/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/autorecovery/index.html b/content/docs/4.13.0/admin/autorecovery/index.html
index fe83698..92bb245 100644
--- a/content/docs/4.13.0/admin/autorecovery/index.html
+++ b/content/docs/4.13.0/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/bookies/index.html b/content/docs/4.13.0/admin/bookies/index.html
index 51d0105..4f0bcfe 100644
--- a/content/docs/4.13.0/admin/bookies/index.html
+++ b/content/docs/4.13.0/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/decomission/index.html b/content/docs/4.13.0/admin/decomission/index.html
index 913dc97..7fde8e9 100644
--- a/content/docs/4.13.0/admin/decomission/index.html
+++ b/content/docs/4.13.0/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/geo-replication/index.html b/content/docs/4.13.0/admin/geo-replication/index.html
index acc52f7..4ab770e 100644
--- a/content/docs/4.13.0/admin/geo-replication/index.html
+++ b/content/docs/4.13.0/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/http/index.html b/content/docs/4.13.0/admin/http/index.html
index e74ad61..a86e124 100644
--- a/content/docs/4.13.0/admin/http/index.html
+++ b/content/docs/4.13.0/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/metrics/index.html b/content/docs/4.13.0/admin/metrics/index.html
index 8c15497..8b1abf0 100644
--- a/content/docs/4.13.0/admin/metrics/index.html
+++ b/content/docs/4.13.0/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/perf/index.html b/content/docs/4.13.0/admin/perf/index.html
index aba21e2..d18f223 100644
--- a/content/docs/4.13.0/admin/perf/index.html
+++ b/content/docs/4.13.0/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/placement/index.html b/content/docs/4.13.0/admin/placement/index.html
index 2e8bc99..6b2dab5 100644
--- a/content/docs/4.13.0/admin/placement/index.html
+++ b/content/docs/4.13.0/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/admin/upgrade/index.html b/content/docs/4.13.0/admin/upgrade/index.html
index 2749180..10bd96d 100644
--- a/content/docs/4.13.0/admin/upgrade/index.html
+++ b/content/docs/4.13.0/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/api/distributedlog-api/index.html b/content/docs/4.13.0/api/distributedlog-api/index.html
index e2b8fa7..b2b4e79 100644
--- a/content/docs/4.13.0/api/distributedlog-api/index.html
+++ b/content/docs/4.13.0/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/api/ledger-adv-api/index.html b/content/docs/4.13.0/api/ledger-adv-api/index.html
index 894bf44..b90b1e9 100644
--- a/content/docs/4.13.0/api/ledger-adv-api/index.html
+++ b/content/docs/4.13.0/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/api/ledger-api/index.html b/content/docs/4.13.0/api/ledger-api/index.html
index f2902ec..b02d993 100644
--- a/content/docs/4.13.0/api/ledger-api/index.html
+++ b/content/docs/4.13.0/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/api/overview/index.html b/content/docs/4.13.0/api/overview/index.html
index 21b40c3..6e686aa 100644
--- a/content/docs/4.13.0/api/overview/index.html
+++ b/content/docs/4.13.0/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/deployment/kubernetes/index.html b/content/docs/4.13.0/deployment/kubernetes/index.html
index aa102d7..d9693b5 100644
--- a/content/docs/4.13.0/deployment/kubernetes/index.html
+++ b/content/docs/4.13.0/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.13.0/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.13.0/overview/">4.13.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.13.0/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.13.0/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.13.0/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.13.0/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.13.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.13.0/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.13.0/overview/">4.13.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.13.0/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.13.0/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.13.0/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.13.0/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.13.0/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.13.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/deployment/manual/index.html b/content/docs/4.13.0/deployment/manual/index.html
index e977139..03f029b 100644
--- a/content/docs/4.13.0/deployment/manual/index.html
+++ b/content/docs/4.13.0/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/development/codebase/index.html b/content/docs/4.13.0/development/codebase/index.html
index 18cd290..041471a 100644
--- a/content/docs/4.13.0/development/codebase/index.html
+++ b/content/docs/4.13.0/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/development/protocol/index.html b/content/docs/4.13.0/development/protocol/index.html
index e668780..9a542d5 100644
--- a/content/docs/4.13.0/development/protocol/index.html
+++ b/content/docs/4.13.0/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/getting-started/concepts/index.html b/content/docs/4.13.0/getting-started/concepts/index.html
index cda2415..9ff870d 100644
--- a/content/docs/4.13.0/getting-started/concepts/index.html
+++ b/content/docs/4.13.0/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/getting-started/installation/index.html b/content/docs/4.13.0/getting-started/installation/index.html
index 8d8deba..f3f77ca 100644
--- a/content/docs/4.13.0/getting-started/installation/index.html
+++ b/content/docs/4.13.0/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/getting-started/run-locally/index.html b/content/docs/4.13.0/getting-started/run-locally/index.html
index bb260cd..8404c13 100644
--- a/content/docs/4.13.0/getting-started/run-locally/index.html
+++ b/content/docs/4.13.0/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/overview/index.html b/content/docs/4.13.0/overview/index.html
index cd34213..db6c512 100644
--- a/content/docs/4.13.0/overview/index.html
+++ b/content/docs/4.13.0/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.13.0 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.13.0 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/reference/cli/index.html b/content/docs/4.13.0/reference/cli/index.html
index 151e083..9c3846c 100644
--- a/content/docs/4.13.0/reference/cli/index.html
+++ b/content/docs/4.13.0/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/reference/config/index.html b/content/docs/4.13.0/reference/config/index.html
index 0cfcbda..63810c8 100644
--- a/content/docs/4.13.0/reference/config/index.html
+++ b/content/docs/4.13.0/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/reference/metrics/index.html b/content/docs/4.13.0/reference/metrics/index.html
index db5e70a..a5b66e6 100644
--- a/content/docs/4.13.0/reference/metrics/index.html
+++ b/content/docs/4.13.0/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/security/overview/index.html b/content/docs/4.13.0/security/overview/index.html
index 30f4123..b249d26 100644
--- a/content/docs/4.13.0/security/overview/index.html
+++ b/content/docs/4.13.0/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/security/sasl/index.html b/content/docs/4.13.0/security/sasl/index.html
index e18b309..39ab4b1 100644
--- a/content/docs/4.13.0/security/sasl/index.html
+++ b/content/docs/4.13.0/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/security/tls/index.html b/content/docs/4.13.0/security/tls/index.html
index ad31716..b909748 100644
--- a/content/docs/4.13.0/security/tls/index.html
+++ b/content/docs/4.13.0/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.13.0/security/zookeeper/index.html b/content/docs/4.13.0/security/zookeeper/index.html
index 010c3a2..022ecf1 100644
--- a/content/docs/4.13.0/security/zookeeper/index.html
+++ b/content/docs/4.13.0/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.13.0/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.13.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" name="docsearch:version" content="4.13.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.13.0"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.13.0/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.13.0/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/autorecovery/index.html b/content/docs/4.14.8/admin/autorecovery/index.html
index a98e645..8053409 100644
--- a/content/docs/4.14.8/admin/autorecovery/index.html
+++ b/content/docs/4.14.8/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/bookies/index.html b/content/docs/4.14.8/admin/bookies/index.html
index c42dd1d..3fd883b 100644
--- a/content/docs/4.14.8/admin/bookies/index.html
+++ b/content/docs/4.14.8/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/decomission/index.html b/content/docs/4.14.8/admin/decomission/index.html
index cdc7dcf..eedd861 100644
--- a/content/docs/4.14.8/admin/decomission/index.html
+++ b/content/docs/4.14.8/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/geo-replication/index.html b/content/docs/4.14.8/admin/geo-replication/index.html
index c5d96c8..e01be2f 100644
--- a/content/docs/4.14.8/admin/geo-replication/index.html
+++ b/content/docs/4.14.8/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/http/index.html b/content/docs/4.14.8/admin/http/index.html
index 7c9850b..2ccbbc4 100644
--- a/content/docs/4.14.8/admin/http/index.html
+++ b/content/docs/4.14.8/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/metrics/index.html b/content/docs/4.14.8/admin/metrics/index.html
index 85f4271..0649aa7 100644
--- a/content/docs/4.14.8/admin/metrics/index.html
+++ b/content/docs/4.14.8/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/perf/index.html b/content/docs/4.14.8/admin/perf/index.html
index 7245f45..6e5bac7 100644
--- a/content/docs/4.14.8/admin/perf/index.html
+++ b/content/docs/4.14.8/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/placement/index.html b/content/docs/4.14.8/admin/placement/index.html
index 4e1894b..55cb53e 100644
--- a/content/docs/4.14.8/admin/placement/index.html
+++ b/content/docs/4.14.8/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/admin/upgrade/index.html b/content/docs/4.14.8/admin/upgrade/index.html
index 08729e0..0c468e7 100644
--- a/content/docs/4.14.8/admin/upgrade/index.html
+++ b/content/docs/4.14.8/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/api/distributedlog-api/index.html b/content/docs/4.14.8/api/distributedlog-api/index.html
index 8212c96..736b945 100644
--- a/content/docs/4.14.8/api/distributedlog-api/index.html
+++ b/content/docs/4.14.8/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/api/ledger-adv-api/index.html b/content/docs/4.14.8/api/ledger-adv-api/index.html
index 44dc557..3ca2763 100644
--- a/content/docs/4.14.8/api/ledger-adv-api/index.html
+++ b/content/docs/4.14.8/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/api/ledger-api/index.html b/content/docs/4.14.8/api/ledger-api/index.html
index 3ea22c3..0da3809 100644
--- a/content/docs/4.14.8/api/ledger-api/index.html
+++ b/content/docs/4.14.8/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/api/overview/index.html b/content/docs/4.14.8/api/overview/index.html
index e1838fd..6de1114 100644
--- a/content/docs/4.14.8/api/overview/index.html
+++ b/content/docs/4.14.8/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/deployment/kubernetes/index.html b/content/docs/4.14.8/deployment/kubernetes/index.html
index 6efe728..5b6fb33 100644
--- a/content/docs/4.14.8/deployment/kubernetes/index.html
+++ b/content/docs/4.14.8/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.14.8/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.14.8/overview/">4.14.8</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.14.8/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.14.8/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.14.8/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.14.8/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.14.8</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.14.8/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.14.8/overview/">4.14.8</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.14.8/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.14.8/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.14.8/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.14.8/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.14.8/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.14.8</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/deployment/manual/index.html b/content/docs/4.14.8/deployment/manual/index.html
index c705193..8fac1ea 100644
--- a/content/docs/4.14.8/deployment/manual/index.html
+++ b/content/docs/4.14.8/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/development/codebase/index.html b/content/docs/4.14.8/development/codebase/index.html
index 89a264e..c7d682d 100644
--- a/content/docs/4.14.8/development/codebase/index.html
+++ b/content/docs/4.14.8/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/development/protocol/index.html b/content/docs/4.14.8/development/protocol/index.html
index 3129ab2..44d0d1a 100644
--- a/content/docs/4.14.8/development/protocol/index.html
+++ b/content/docs/4.14.8/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/getting-started/concepts/index.html b/content/docs/4.14.8/getting-started/concepts/index.html
index 2ab8bf2..5bf3b54 100644
--- a/content/docs/4.14.8/getting-started/concepts/index.html
+++ b/content/docs/4.14.8/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/getting-started/installation/index.html b/content/docs/4.14.8/getting-started/installation/index.html
index 457cb0e..f03c62e 100644
--- a/content/docs/4.14.8/getting-started/installation/index.html
+++ b/content/docs/4.14.8/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/getting-started/run-locally/index.html b/content/docs/4.14.8/getting-started/run-locally/index.html
index 6e547ef..4bda2b4 100644
--- a/content/docs/4.14.8/getting-started/run-locally/index.html
+++ b/content/docs/4.14.8/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/overview/index.html b/content/docs/4.14.8/overview/index.html
index 298919c..dcfe840 100644
--- a/content/docs/4.14.8/overview/index.html
+++ b/content/docs/4.14.8/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.14.8 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.14.8 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/reference/cli/index.html b/content/docs/4.14.8/reference/cli/index.html
index b5c697f..85e308c 100644
--- a/content/docs/4.14.8/reference/cli/index.html
+++ b/content/docs/4.14.8/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/reference/config/index.html b/content/docs/4.14.8/reference/config/index.html
index 85c2858..818c521 100644
--- a/content/docs/4.14.8/reference/config/index.html
+++ b/content/docs/4.14.8/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/reference/metrics/index.html b/content/docs/4.14.8/reference/metrics/index.html
index b048079..a746970 100644
--- a/content/docs/4.14.8/reference/metrics/index.html
+++ b/content/docs/4.14.8/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/security/overview/index.html b/content/docs/4.14.8/security/overview/index.html
index 2155f27..0347008 100644
--- a/content/docs/4.14.8/security/overview/index.html
+++ b/content/docs/4.14.8/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/security/sasl/index.html b/content/docs/4.14.8/security/sasl/index.html
index 87229c7..bfc3932 100644
--- a/content/docs/4.14.8/security/sasl/index.html
+++ b/content/docs/4.14.8/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/security/tls/index.html b/content/docs/4.14.8/security/tls/index.html
index 4f8726c..719789b 100644
--- a/content/docs/4.14.8/security/tls/index.html
+++ b/content/docs/4.14.8/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.14.8/security/zookeeper/index.html b/content/docs/4.14.8/security/zookeeper/index.html
index 1bbb1ad..a57d38d 100644
--- a/content/docs/4.14.8/security/zookeeper/index.html
+++ b/content/docs/4.14.8/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.14.8/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.14.8"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" name="docsearch:version" content="4.14.8"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.14.8"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.14.8/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.14.8/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/autorecovery/index.html b/content/docs/4.15.5/admin/autorecovery/index.html
index 707086f..133e2f8 100644
--- a/content/docs/4.15.5/admin/autorecovery/index.html
+++ b/content/docs/4.15.5/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/bookies/index.html b/content/docs/4.15.5/admin/bookies/index.html
index 9d1fc4b..13319f6 100644
--- a/content/docs/4.15.5/admin/bookies/index.html
+++ b/content/docs/4.15.5/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/decomission/index.html b/content/docs/4.15.5/admin/decomission/index.html
index 35e56cc..0b3a771 100644
--- a/content/docs/4.15.5/admin/decomission/index.html
+++ b/content/docs/4.15.5/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/geo-replication/index.html b/content/docs/4.15.5/admin/geo-replication/index.html
index 8f73d87..8c72809 100644
--- a/content/docs/4.15.5/admin/geo-replication/index.html
+++ b/content/docs/4.15.5/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/http/index.html b/content/docs/4.15.5/admin/http/index.html
index 8d47eeb..3a4cd43 100644
--- a/content/docs/4.15.5/admin/http/index.html
+++ b/content/docs/4.15.5/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/metrics/index.html b/content/docs/4.15.5/admin/metrics/index.html
index 1853dc6..15bbbee 100644
--- a/content/docs/4.15.5/admin/metrics/index.html
+++ b/content/docs/4.15.5/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/perf/index.html b/content/docs/4.15.5/admin/perf/index.html
index b7d04fc..be069f9 100644
--- a/content/docs/4.15.5/admin/perf/index.html
+++ b/content/docs/4.15.5/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/placement/index.html b/content/docs/4.15.5/admin/placement/index.html
index 2e3ca7e..18ca6e1 100644
--- a/content/docs/4.15.5/admin/placement/index.html
+++ b/content/docs/4.15.5/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/admin/upgrade/index.html b/content/docs/4.15.5/admin/upgrade/index.html
index 57d95c2..338b288 100644
--- a/content/docs/4.15.5/admin/upgrade/index.html
+++ b/content/docs/4.15.5/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/api/distributedlog-api/index.html b/content/docs/4.15.5/api/distributedlog-api/index.html
index 5f69a05..7f28d75 100644
--- a/content/docs/4.15.5/api/distributedlog-api/index.html
+++ b/content/docs/4.15.5/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/api/ledger-adv-api/index.html b/content/docs/4.15.5/api/ledger-adv-api/index.html
index 252fe8b..a3089bf 100644
--- a/content/docs/4.15.5/api/ledger-adv-api/index.html
+++ b/content/docs/4.15.5/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/api/ledger-api/index.html b/content/docs/4.15.5/api/ledger-api/index.html
index 86baa61..053e8f3 100644
--- a/content/docs/4.15.5/api/ledger-api/index.html
+++ b/content/docs/4.15.5/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/api/overview/index.html b/content/docs/4.15.5/api/overview/index.html
index ecb644b..de2d862 100644
--- a/content/docs/4.15.5/api/overview/index.html
+++ b/content/docs/4.15.5/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/deployment/kubernetes/index.html b/content/docs/4.15.5/deployment/kubernetes/index.html
index 6e6a16a..6c36a34 100644
--- a/content/docs/4.15.5/deployment/kubernetes/index.html
+++ b/content/docs/4.15.5/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.15.5/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.15.5/overview/">4.15.5</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.15.5/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.15.5/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.15.5/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.15.5/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.15.5</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.15.5/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.15.5/overview/">4.15.5</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.15.5/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.15.5/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.15.5/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.15.5/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.15.5/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.15.5</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/deployment/manual/index.html b/content/docs/4.15.5/deployment/manual/index.html
index 5216af9..4a46e10 100644
--- a/content/docs/4.15.5/deployment/manual/index.html
+++ b/content/docs/4.15.5/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/development/codebase/index.html b/content/docs/4.15.5/development/codebase/index.html
index 4c3a4f8..f7c2765 100644
--- a/content/docs/4.15.5/development/codebase/index.html
+++ b/content/docs/4.15.5/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/development/protocol/index.html b/content/docs/4.15.5/development/protocol/index.html
index a63a2af..55652bb 100644
--- a/content/docs/4.15.5/development/protocol/index.html
+++ b/content/docs/4.15.5/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/getting-started/concepts/index.html b/content/docs/4.15.5/getting-started/concepts/index.html
index fdcd4d8..0ab5a77 100644
--- a/content/docs/4.15.5/getting-started/concepts/index.html
+++ b/content/docs/4.15.5/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/getting-started/installation/index.html b/content/docs/4.15.5/getting-started/installation/index.html
index 5294075..ef50d42 100644
--- a/content/docs/4.15.5/getting-started/installation/index.html
+++ b/content/docs/4.15.5/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/getting-started/run-locally/index.html b/content/docs/4.15.5/getting-started/run-locally/index.html
index e63abd1..9a30434 100644
--- a/content/docs/4.15.5/getting-started/run-locally/index.html
+++ b/content/docs/4.15.5/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/overview/index.html b/content/docs/4.15.5/overview/index.html
index 4774be8..fa86459 100644
--- a/content/docs/4.15.5/overview/index.html
+++ b/content/docs/4.15.5/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.15.5 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.15.5 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/reference/cli/index.html b/content/docs/4.15.5/reference/cli/index.html
index 9d890b4..ad8705a 100644
--- a/content/docs/4.15.5/reference/cli/index.html
+++ b/content/docs/4.15.5/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/reference/config/index.html b/content/docs/4.15.5/reference/config/index.html
index 1f32d96..999f63b 100644
--- a/content/docs/4.15.5/reference/config/index.html
+++ b/content/docs/4.15.5/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/security/overview/index.html b/content/docs/4.15.5/security/overview/index.html
index 452651d..74217e3 100644
--- a/content/docs/4.15.5/security/overview/index.html
+++ b/content/docs/4.15.5/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/security/sasl/index.html b/content/docs/4.15.5/security/sasl/index.html
index a0c18cd..b6d8b63 100644
--- a/content/docs/4.15.5/security/sasl/index.html
+++ b/content/docs/4.15.5/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/security/tls/index.html b/content/docs/4.15.5/security/tls/index.html
index 891fa79..cda4569 100644
--- a/content/docs/4.15.5/security/tls/index.html
+++ b/content/docs/4.15.5/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.15.5/security/zookeeper/index.html b/content/docs/4.15.5/security/zookeeper/index.html
index f1931d0..1945372 100644
--- a/content/docs/4.15.5/security/zookeeper/index.html
+++ b/content/docs/4.15.5/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.15.5/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.15.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" name="docsearch:version" content="4.15.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.15.5"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.15.5/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.15.5/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/autorecovery/index.html b/content/docs/4.16.5/admin/autorecovery/index.html
index f6859f3..04b86be 100644
--- a/content/docs/4.16.5/admin/autorecovery/index.html
+++ b/content/docs/4.16.5/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/bookies/index.html b/content/docs/4.16.5/admin/bookies/index.html
index 72e67af..c6801ca 100644
--- a/content/docs/4.16.5/admin/bookies/index.html
+++ b/content/docs/4.16.5/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/decomission/index.html b/content/docs/4.16.5/admin/decomission/index.html
index ba2f8b4..716313c 100644
--- a/content/docs/4.16.5/admin/decomission/index.html
+++ b/content/docs/4.16.5/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/geo-replication/index.html b/content/docs/4.16.5/admin/geo-replication/index.html
index 62170d7..515d0ea 100644
--- a/content/docs/4.16.5/admin/geo-replication/index.html
+++ b/content/docs/4.16.5/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/http/index.html b/content/docs/4.16.5/admin/http/index.html
index 71cd3b2..2ed5df9 100644
--- a/content/docs/4.16.5/admin/http/index.html
+++ b/content/docs/4.16.5/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/metrics/index.html b/content/docs/4.16.5/admin/metrics/index.html
index 79a9eb5..67e056d 100644
--- a/content/docs/4.16.5/admin/metrics/index.html
+++ b/content/docs/4.16.5/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/perf/index.html b/content/docs/4.16.5/admin/perf/index.html
index 00bc0f6..c5a69dd 100644
--- a/content/docs/4.16.5/admin/perf/index.html
+++ b/content/docs/4.16.5/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/placement/index.html b/content/docs/4.16.5/admin/placement/index.html
index 0716791..72caf0f 100644
--- a/content/docs/4.16.5/admin/placement/index.html
+++ b/content/docs/4.16.5/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/admin/upgrade/index.html b/content/docs/4.16.5/admin/upgrade/index.html
index f550059..0554ca7 100644
--- a/content/docs/4.16.5/admin/upgrade/index.html
+++ b/content/docs/4.16.5/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/api/distributedlog-api/index.html b/content/docs/4.16.5/api/distributedlog-api/index.html
index a3a3ade..b95fa78 100644
--- a/content/docs/4.16.5/api/distributedlog-api/index.html
+++ b/content/docs/4.16.5/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/api/ledger-adv-api/index.html b/content/docs/4.16.5/api/ledger-adv-api/index.html
index 449c23d..90fc680 100644
--- a/content/docs/4.16.5/api/ledger-adv-api/index.html
+++ b/content/docs/4.16.5/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/api/ledger-api/index.html b/content/docs/4.16.5/api/ledger-api/index.html
index ea91731..8e528da 100644
--- a/content/docs/4.16.5/api/ledger-api/index.html
+++ b/content/docs/4.16.5/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/api/overview/index.html b/content/docs/4.16.5/api/overview/index.html
index cb564d9..46f7174 100644
--- a/content/docs/4.16.5/api/overview/index.html
+++ b/content/docs/4.16.5/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/deployment/kubernetes/index.html b/content/docs/4.16.5/deployment/kubernetes/index.html
index 82e19a8..6c2e833 100644
--- a/content/docs/4.16.5/deployment/kubernetes/index.html
+++ b/content/docs/4.16.5/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.16.5/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.16.5/overview/">4.16.5</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.16.5/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.16.5/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.16.5/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.16.5/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.16.5</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.16.5/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.16.5/overview/">4.16.5</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.16.5/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.16.5/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.16.5/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.16.5/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.16.5/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.16.5</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/deployment/manual/index.html b/content/docs/4.16.5/deployment/manual/index.html
index 9e3a67a..04b9588 100644
--- a/content/docs/4.16.5/deployment/manual/index.html
+++ b/content/docs/4.16.5/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/development/codebase/index.html b/content/docs/4.16.5/development/codebase/index.html
index 80975cf..868efb4 100644
--- a/content/docs/4.16.5/development/codebase/index.html
+++ b/content/docs/4.16.5/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/development/protocol/index.html b/content/docs/4.16.5/development/protocol/index.html
index 097e7e0..a4dde2f 100644
--- a/content/docs/4.16.5/development/protocol/index.html
+++ b/content/docs/4.16.5/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/getting-started/concepts/index.html b/content/docs/4.16.5/getting-started/concepts/index.html
index 768544d..37f14de 100644
--- a/content/docs/4.16.5/getting-started/concepts/index.html
+++ b/content/docs/4.16.5/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/getting-started/installation/index.html b/content/docs/4.16.5/getting-started/installation/index.html
index d47ca6e..7f2480a 100644
--- a/content/docs/4.16.5/getting-started/installation/index.html
+++ b/content/docs/4.16.5/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/getting-started/run-locally/index.html b/content/docs/4.16.5/getting-started/run-locally/index.html
index 00a3ee3..70fadc4 100644
--- a/content/docs/4.16.5/getting-started/run-locally/index.html
+++ b/content/docs/4.16.5/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/overview/index.html b/content/docs/4.16.5/overview/index.html
index 0e117bc..e10ae01 100644
--- a/content/docs/4.16.5/overview/index.html
+++ b/content/docs/4.16.5/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.16.5 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.16.5 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/reference/cli/index.html b/content/docs/4.16.5/reference/cli/index.html
index 25daf22..89d2ef6 100644
--- a/content/docs/4.16.5/reference/cli/index.html
+++ b/content/docs/4.16.5/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/reference/config/index.html b/content/docs/4.16.5/reference/config/index.html
index 2633e61..9a69e16 100644
--- a/content/docs/4.16.5/reference/config/index.html
+++ b/content/docs/4.16.5/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/security/overview/index.html b/content/docs/4.16.5/security/overview/index.html
index a2ddb66..49b88cc 100644
--- a/content/docs/4.16.5/security/overview/index.html
+++ b/content/docs/4.16.5/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/security/sasl/index.html b/content/docs/4.16.5/security/sasl/index.html
index 3b0cd45..f538897 100644
--- a/content/docs/4.16.5/security/sasl/index.html
+++ b/content/docs/4.16.5/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/security/tls/index.html b/content/docs/4.16.5/security/tls/index.html
index 8550f89..ffdac35 100644
--- a/content/docs/4.16.5/security/tls/index.html
+++ b/content/docs/4.16.5/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.16.5/security/zookeeper/index.html b/content/docs/4.16.5/security/zookeeper/index.html
index 6ea08b8..dd41268 100644
--- a/content/docs/4.16.5/security/zookeeper/index.html
+++ b/content/docs/4.16.5/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.16.5/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.16.5"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" name="docsearch:version" content="4.16.5"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.16.5"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.16.5/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.16.5/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/autorecovery/index.html b/content/docs/4.5.1/admin/autorecovery/index.html
index 53f3f27..a314fe6 100644
--- a/content/docs/4.5.1/admin/autorecovery/index.html
+++ b/content/docs/4.5.1/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/bookies/index.html b/content/docs/4.5.1/admin/bookies/index.html
index 82c4303..e6bed0d 100644
--- a/content/docs/4.5.1/admin/bookies/index.html
+++ b/content/docs/4.5.1/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/geo-replication/index.html b/content/docs/4.5.1/admin/geo-replication/index.html
index 8f5518c..db1d000 100644
--- a/content/docs/4.5.1/admin/geo-replication/index.html
+++ b/content/docs/4.5.1/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/metrics/index.html b/content/docs/4.5.1/admin/metrics/index.html
index 5546eda..4107493 100644
--- a/content/docs/4.5.1/admin/metrics/index.html
+++ b/content/docs/4.5.1/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/perf/index.html b/content/docs/4.5.1/admin/perf/index.html
index e5d0c1e..e814a50 100644
--- a/content/docs/4.5.1/admin/perf/index.html
+++ b/content/docs/4.5.1/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/placement/index.html b/content/docs/4.5.1/admin/placement/index.html
index e09f668..38ddee7 100644
--- a/content/docs/4.5.1/admin/placement/index.html
+++ b/content/docs/4.5.1/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/admin/upgrade/index.html b/content/docs/4.5.1/admin/upgrade/index.html
index 347eea4..5f9c577 100644
--- a/content/docs/4.5.1/admin/upgrade/index.html
+++ b/content/docs/4.5.1/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/api/distributedlog-api/index.html b/content/docs/4.5.1/api/distributedlog-api/index.html
index fdff030..1ba5809 100644
--- a/content/docs/4.5.1/api/distributedlog-api/index.html
+++ b/content/docs/4.5.1/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/api/ledger-adv-api/index.html b/content/docs/4.5.1/api/ledger-adv-api/index.html
index 84ee6d6..c08e639 100644
--- a/content/docs/4.5.1/api/ledger-adv-api/index.html
+++ b/content/docs/4.5.1/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/api/ledger-api/index.html b/content/docs/4.5.1/api/ledger-api/index.html
index d5c68ea..274e50a 100644
--- a/content/docs/4.5.1/api/ledger-api/index.html
+++ b/content/docs/4.5.1/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -26,7 +26,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/api/overview/index.html b/content/docs/4.5.1/api/overview/index.html
index 387a034..a4d5b95 100644
--- a/content/docs/4.5.1/api/overview/index.html
+++ b/content/docs/4.5.1/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/deployment/kubernetes/index.html b/content/docs/4.5.1/deployment/kubernetes/index.html
index 0727e6f..6aab2f2 100644
--- a/content/docs/4.5.1/deployment/kubernetes/index.html
+++ b/content/docs/4.5.1/deployment/kubernetes/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Deploying BookKeeper on Kubernetes | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/deployment/manual/index.html b/content/docs/4.5.1/deployment/manual/index.html
index cea0c93..36c1d68 100644
--- a/content/docs/4.5.1/deployment/manual/index.html
+++ b/content/docs/4.5.1/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/development/codebase/index.html b/content/docs/4.5.1/development/codebase/index.html
index f4bebc2..0ae7c01 100644
--- a/content/docs/4.5.1/development/codebase/index.html
+++ b/content/docs/4.5.1/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/development/protocol/index.html b/content/docs/4.5.1/development/protocol/index.html
index ab59ecd..4923384 100644
--- a/content/docs/4.5.1/development/protocol/index.html
+++ b/content/docs/4.5.1/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/getting-started/concepts/index.html b/content/docs/4.5.1/getting-started/concepts/index.html
index e483382..f5d303d 100644
--- a/content/docs/4.5.1/getting-started/concepts/index.html
+++ b/content/docs/4.5.1/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/getting-started/installation/index.html b/content/docs/4.5.1/getting-started/installation/index.html
index f3c054e..020c3f9 100644
--- a/content/docs/4.5.1/getting-started/installation/index.html
+++ b/content/docs/4.5.1/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/getting-started/run-locally/index.html b/content/docs/4.5.1/getting-started/run-locally/index.html
index 0130b45..d41a8ba 100644
--- a/content/docs/4.5.1/getting-started/run-locally/index.html
+++ b/content/docs/4.5.1/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/overview/index.html b/content/docs/4.5.1/overview/index.html
index 7f55da3..1be2166 100644
--- a/content/docs/4.5.1/overview/index.html
+++ b/content/docs/4.5.1/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.5.1 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.5.1 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/reference/cli/index.html b/content/docs/4.5.1/reference/cli/index.html
index e4f7f24..c0d2fb2 100644
--- a/content/docs/4.5.1/reference/cli/index.html
+++ b/content/docs/4.5.1/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/reference/config/index.html b/content/docs/4.5.1/reference/config/index.html
index da57357..772034e 100644
--- a/content/docs/4.5.1/reference/config/index.html
+++ b/content/docs/4.5.1/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/reference/metrics/index.html b/content/docs/4.5.1/reference/metrics/index.html
index 9776452..d55eaed 100644
--- a/content/docs/4.5.1/reference/metrics/index.html
+++ b/content/docs/4.5.1/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/security/overview/index.html b/content/docs/4.5.1/security/overview/index.html
index c8eb2c3..1ea20e3 100644
--- a/content/docs/4.5.1/security/overview/index.html
+++ b/content/docs/4.5.1/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/security/sasl/index.html b/content/docs/4.5.1/security/sasl/index.html
index fe4628e..0c3cd3f 100644
--- a/content/docs/4.5.1/security/sasl/index.html
+++ b/content/docs/4.5.1/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/security/tls/index.html b/content/docs/4.5.1/security/tls/index.html
index e67326a..b6122c0 100644
--- a/content/docs/4.5.1/security/tls/index.html
+++ b/content/docs/4.5.1/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.5.1/security/zookeeper/index.html b/content/docs/4.5.1/security/zookeeper/index.html
index 1640f9c..b3032ce 100644
--- a/content/docs/4.5.1/security/zookeeper/index.html
+++ b/content/docs/4.5.1/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.5.1/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.5.1"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" name="docsearch:version" content="4.5.1"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.5.1"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.5.1/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.5.1/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/autorecovery/index.html b/content/docs/4.6.2/admin/autorecovery/index.html
index fa7f291..3bcec08 100644
--- a/content/docs/4.6.2/admin/autorecovery/index.html
+++ b/content/docs/4.6.2/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/bookies/index.html b/content/docs/4.6.2/admin/bookies/index.html
index 96ce975..60da439 100644
--- a/content/docs/4.6.2/admin/bookies/index.html
+++ b/content/docs/4.6.2/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/geo-replication/index.html b/content/docs/4.6.2/admin/geo-replication/index.html
index d45535d..64a97f1 100644
--- a/content/docs/4.6.2/admin/geo-replication/index.html
+++ b/content/docs/4.6.2/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/http/index.html b/content/docs/4.6.2/admin/http/index.html
index 45570f5..091cc64 100644
--- a/content/docs/4.6.2/admin/http/index.html
+++ b/content/docs/4.6.2/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/metrics/index.html b/content/docs/4.6.2/admin/metrics/index.html
index a18562f..27bdf8c 100644
--- a/content/docs/4.6.2/admin/metrics/index.html
+++ b/content/docs/4.6.2/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/perf/index.html b/content/docs/4.6.2/admin/perf/index.html
index 49aef0a..5aacce9 100644
--- a/content/docs/4.6.2/admin/perf/index.html
+++ b/content/docs/4.6.2/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/placement/index.html b/content/docs/4.6.2/admin/placement/index.html
index 515ace9..f344362 100644
--- a/content/docs/4.6.2/admin/placement/index.html
+++ b/content/docs/4.6.2/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/admin/upgrade/index.html b/content/docs/4.6.2/admin/upgrade/index.html
index 2eed558..bcd352f 100644
--- a/content/docs/4.6.2/admin/upgrade/index.html
+++ b/content/docs/4.6.2/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/api/distributedlog-api/index.html b/content/docs/4.6.2/api/distributedlog-api/index.html
index 9ad5839..65b5b7f 100644
--- a/content/docs/4.6.2/api/distributedlog-api/index.html
+++ b/content/docs/4.6.2/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/api/ledger-adv-api/index.html b/content/docs/4.6.2/api/ledger-adv-api/index.html
index f6e9b9c..4304026 100644
--- a/content/docs/4.6.2/api/ledger-adv-api/index.html
+++ b/content/docs/4.6.2/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/api/ledger-api/index.html b/content/docs/4.6.2/api/ledger-api/index.html
index ee06eae..c69f519 100644
--- a/content/docs/4.6.2/api/ledger-api/index.html
+++ b/content/docs/4.6.2/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -39,7 +39,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/api/overview/index.html b/content/docs/4.6.2/api/overview/index.html
index 16efa60..f0bdfbe 100644
--- a/content/docs/4.6.2/api/overview/index.html
+++ b/content/docs/4.6.2/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/deployment/kubernetes/index.html b/content/docs/4.6.2/deployment/kubernetes/index.html
index b171d19..a9ffe47 100644
--- a/content/docs/4.6.2/deployment/kubernetes/index.html
+++ b/content/docs/4.6.2/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.6.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.6.2/overview/">4.6.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.6.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.6.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.6.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.6.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.6.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.6.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.6.2/overview/">4.6.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.6.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.6.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.6.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.6.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.6.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.6.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/deployment/manual/index.html b/content/docs/4.6.2/deployment/manual/index.html
index 7d0ac5d..56cf9d6 100644
--- a/content/docs/4.6.2/deployment/manual/index.html
+++ b/content/docs/4.6.2/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/development/codebase/index.html b/content/docs/4.6.2/development/codebase/index.html
index 6cc198a..176896d 100644
--- a/content/docs/4.6.2/development/codebase/index.html
+++ b/content/docs/4.6.2/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/development/protocol/index.html b/content/docs/4.6.2/development/protocol/index.html
index 3924cbb..06653e5 100644
--- a/content/docs/4.6.2/development/protocol/index.html
+++ b/content/docs/4.6.2/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/getting-started/concepts/index.html b/content/docs/4.6.2/getting-started/concepts/index.html
index bdd6bbf..935509b 100644
--- a/content/docs/4.6.2/getting-started/concepts/index.html
+++ b/content/docs/4.6.2/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/getting-started/installation/index.html b/content/docs/4.6.2/getting-started/installation/index.html
index 6b0daea..763d15b 100644
--- a/content/docs/4.6.2/getting-started/installation/index.html
+++ b/content/docs/4.6.2/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/getting-started/run-locally/index.html b/content/docs/4.6.2/getting-started/run-locally/index.html
index 54acc08..c8db85c 100644
--- a/content/docs/4.6.2/getting-started/run-locally/index.html
+++ b/content/docs/4.6.2/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/overview/index.html b/content/docs/4.6.2/overview/index.html
index b6deb5e..3cedb29 100644
--- a/content/docs/4.6.2/overview/index.html
+++ b/content/docs/4.6.2/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.6.2 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.6.2 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/reference/cli/index.html b/content/docs/4.6.2/reference/cli/index.html
index 0f10067..ad0c64c 100644
--- a/content/docs/4.6.2/reference/cli/index.html
+++ b/content/docs/4.6.2/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/reference/config/index.html b/content/docs/4.6.2/reference/config/index.html
index 85cee62..9d211aa 100644
--- a/content/docs/4.6.2/reference/config/index.html
+++ b/content/docs/4.6.2/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/reference/metrics/index.html b/content/docs/4.6.2/reference/metrics/index.html
index 26407fe..758df4a 100644
--- a/content/docs/4.6.2/reference/metrics/index.html
+++ b/content/docs/4.6.2/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/security/overview/index.html b/content/docs/4.6.2/security/overview/index.html
index e52ab99..4f075fc 100644
--- a/content/docs/4.6.2/security/overview/index.html
+++ b/content/docs/4.6.2/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/security/sasl/index.html b/content/docs/4.6.2/security/sasl/index.html
index 1146c31..693f2d9 100644
--- a/content/docs/4.6.2/security/sasl/index.html
+++ b/content/docs/4.6.2/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/security/tls/index.html b/content/docs/4.6.2/security/tls/index.html
index 868eddd..6e1d1f6 100644
--- a/content/docs/4.6.2/security/tls/index.html
+++ b/content/docs/4.6.2/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.6.2/security/zookeeper/index.html b/content/docs/4.6.2/security/zookeeper/index.html
index 4a9d7e3..783f74d 100644
--- a/content/docs/4.6.2/security/zookeeper/index.html
+++ b/content/docs/4.6.2/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.6.2/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.6.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" name="docsearch:version" content="4.6.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.6.2"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.6.2/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.6.2/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/autorecovery/index.html b/content/docs/4.7.3/admin/autorecovery/index.html
index 6e81966..22369ac 100644
--- a/content/docs/4.7.3/admin/autorecovery/index.html
+++ b/content/docs/4.7.3/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/bookies/index.html b/content/docs/4.7.3/admin/bookies/index.html
index 737c92d..36e6201 100644
--- a/content/docs/4.7.3/admin/bookies/index.html
+++ b/content/docs/4.7.3/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/geo-replication/index.html b/content/docs/4.7.3/admin/geo-replication/index.html
index 593fd74..9ed6f68 100644
--- a/content/docs/4.7.3/admin/geo-replication/index.html
+++ b/content/docs/4.7.3/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/http/index.html b/content/docs/4.7.3/admin/http/index.html
index ffe464d..284f170 100644
--- a/content/docs/4.7.3/admin/http/index.html
+++ b/content/docs/4.7.3/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/metrics/index.html b/content/docs/4.7.3/admin/metrics/index.html
index 27f0b97..b531c3c 100644
--- a/content/docs/4.7.3/admin/metrics/index.html
+++ b/content/docs/4.7.3/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/perf/index.html b/content/docs/4.7.3/admin/perf/index.html
index af65a70..28a375f 100644
--- a/content/docs/4.7.3/admin/perf/index.html
+++ b/content/docs/4.7.3/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/placement/index.html b/content/docs/4.7.3/admin/placement/index.html
index 9f4ece4..6e06314 100644
--- a/content/docs/4.7.3/admin/placement/index.html
+++ b/content/docs/4.7.3/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/admin/upgrade/index.html b/content/docs/4.7.3/admin/upgrade/index.html
index 53f3cab..fbc0ceb 100644
--- a/content/docs/4.7.3/admin/upgrade/index.html
+++ b/content/docs/4.7.3/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/api/distributedlog-api/index.html b/content/docs/4.7.3/api/distributedlog-api/index.html
index 8127e60..e196859 100644
--- a/content/docs/4.7.3/api/distributedlog-api/index.html
+++ b/content/docs/4.7.3/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/api/ledger-adv-api/index.html b/content/docs/4.7.3/api/ledger-adv-api/index.html
index ac133f5..0035774 100644
--- a/content/docs/4.7.3/api/ledger-adv-api/index.html
+++ b/content/docs/4.7.3/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/api/ledger-api/index.html b/content/docs/4.7.3/api/ledger-api/index.html
index 4a53320..69f20d6 100644
--- a/content/docs/4.7.3/api/ledger-api/index.html
+++ b/content/docs/4.7.3/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -38,7 +38,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/api/overview/index.html b/content/docs/4.7.3/api/overview/index.html
index 532128c..9276159 100644
--- a/content/docs/4.7.3/api/overview/index.html
+++ b/content/docs/4.7.3/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/deployment/kubernetes/index.html b/content/docs/4.7.3/deployment/kubernetes/index.html
index 8cead5d..796027c 100644
--- a/content/docs/4.7.3/deployment/kubernetes/index.html
+++ b/content/docs/4.7.3/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.7.3/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.7.3/overview/">4.7.3</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.7.3/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.7.3/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.7.3/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.7.3/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.7.3</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.7.3/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.7.3/overview/">4.7.3</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.7.3/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.7.3/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.7.3/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.7.3/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.7.3/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.7.3</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/deployment/manual/index.html b/content/docs/4.7.3/deployment/manual/index.html
index cdab8d3..5b1f188 100644
--- a/content/docs/4.7.3/deployment/manual/index.html
+++ b/content/docs/4.7.3/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/development/codebase/index.html b/content/docs/4.7.3/development/codebase/index.html
index ea12e96..04d6024 100644
--- a/content/docs/4.7.3/development/codebase/index.html
+++ b/content/docs/4.7.3/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/development/protocol/index.html b/content/docs/4.7.3/development/protocol/index.html
index 5abba8f..4394044 100644
--- a/content/docs/4.7.3/development/protocol/index.html
+++ b/content/docs/4.7.3/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/getting-started/concepts/index.html b/content/docs/4.7.3/getting-started/concepts/index.html
index 0536ce6..d023775 100644
--- a/content/docs/4.7.3/getting-started/concepts/index.html
+++ b/content/docs/4.7.3/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/getting-started/installation/index.html b/content/docs/4.7.3/getting-started/installation/index.html
index 8f60a4d..981a0ea 100644
--- a/content/docs/4.7.3/getting-started/installation/index.html
+++ b/content/docs/4.7.3/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/getting-started/run-locally/index.html b/content/docs/4.7.3/getting-started/run-locally/index.html
index 1aea0e0..ff6b60b 100644
--- a/content/docs/4.7.3/getting-started/run-locally/index.html
+++ b/content/docs/4.7.3/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/overview/index.html b/content/docs/4.7.3/overview/index.html
index b46391a..bced99a 100644
--- a/content/docs/4.7.3/overview/index.html
+++ b/content/docs/4.7.3/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.7.3 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.7.3 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/reference/cli/index.html b/content/docs/4.7.3/reference/cli/index.html
index da670f9..5133030 100644
--- a/content/docs/4.7.3/reference/cli/index.html
+++ b/content/docs/4.7.3/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/reference/config/index.html b/content/docs/4.7.3/reference/config/index.html
index aefe96e..6e7dfef 100644
--- a/content/docs/4.7.3/reference/config/index.html
+++ b/content/docs/4.7.3/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/reference/metrics/index.html b/content/docs/4.7.3/reference/metrics/index.html
index 2ce5160..d41db9e 100644
--- a/content/docs/4.7.3/reference/metrics/index.html
+++ b/content/docs/4.7.3/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/security/overview/index.html b/content/docs/4.7.3/security/overview/index.html
index d8e8919..43eb6a8 100644
--- a/content/docs/4.7.3/security/overview/index.html
+++ b/content/docs/4.7.3/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/security/sasl/index.html b/content/docs/4.7.3/security/sasl/index.html
index 02fdb01..53c5343 100644
--- a/content/docs/4.7.3/security/sasl/index.html
+++ b/content/docs/4.7.3/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/security/tls/index.html b/content/docs/4.7.3/security/tls/index.html
index 5202a47..ebf1bfb 100644
--- a/content/docs/4.7.3/security/tls/index.html
+++ b/content/docs/4.7.3/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.7.3/security/zookeeper/index.html b/content/docs/4.7.3/security/zookeeper/index.html
index b8ec59c..7b77f94 100644
--- a/content/docs/4.7.3/security/zookeeper/index.html
+++ b/content/docs/4.7.3/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.7.3/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.7.3"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" name="docsearch:version" content="4.7.3"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.7.3"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.7.3/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.7.3/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/autorecovery/index.html b/content/docs/4.8.2/admin/autorecovery/index.html
index 3f33d9c..1a1e6de 100644
--- a/content/docs/4.8.2/admin/autorecovery/index.html
+++ b/content/docs/4.8.2/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/bookies/index.html b/content/docs/4.8.2/admin/bookies/index.html
index f6af2c7..15d0573 100644
--- a/content/docs/4.8.2/admin/bookies/index.html
+++ b/content/docs/4.8.2/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/geo-replication/index.html b/content/docs/4.8.2/admin/geo-replication/index.html
index 06545d0..68e6e5e 100644
--- a/content/docs/4.8.2/admin/geo-replication/index.html
+++ b/content/docs/4.8.2/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/http/index.html b/content/docs/4.8.2/admin/http/index.html
index d54ce68..718850a 100644
--- a/content/docs/4.8.2/admin/http/index.html
+++ b/content/docs/4.8.2/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/metrics/index.html b/content/docs/4.8.2/admin/metrics/index.html
index c731221..5bd5d0f 100644
--- a/content/docs/4.8.2/admin/metrics/index.html
+++ b/content/docs/4.8.2/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/perf/index.html b/content/docs/4.8.2/admin/perf/index.html
index b3e8d93..552f06a 100644
--- a/content/docs/4.8.2/admin/perf/index.html
+++ b/content/docs/4.8.2/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/placement/index.html b/content/docs/4.8.2/admin/placement/index.html
index a3b1dd5..6327946 100644
--- a/content/docs/4.8.2/admin/placement/index.html
+++ b/content/docs/4.8.2/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/admin/upgrade/index.html b/content/docs/4.8.2/admin/upgrade/index.html
index 32cf772..93e6850 100644
--- a/content/docs/4.8.2/admin/upgrade/index.html
+++ b/content/docs/4.8.2/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/api/distributedlog-api/index.html b/content/docs/4.8.2/api/distributedlog-api/index.html
index c7118ed..bd7508e 100644
--- a/content/docs/4.8.2/api/distributedlog-api/index.html
+++ b/content/docs/4.8.2/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/api/ledger-adv-api/index.html b/content/docs/4.8.2/api/ledger-adv-api/index.html
index 20ad5e4..9ae109e 100644
--- a/content/docs/4.8.2/api/ledger-adv-api/index.html
+++ b/content/docs/4.8.2/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/api/ledger-api/index.html b/content/docs/4.8.2/api/ledger-api/index.html
index cee9aa6..0d8a802 100644
--- a/content/docs/4.8.2/api/ledger-api/index.html
+++ b/content/docs/4.8.2/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/api/overview/index.html b/content/docs/4.8.2/api/overview/index.html
index 6fd5e55..d6b0702 100644
--- a/content/docs/4.8.2/api/overview/index.html
+++ b/content/docs/4.8.2/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/deployment/kubernetes/index.html b/content/docs/4.8.2/deployment/kubernetes/index.html
index 9fe2c53..600c2ec 100644
--- a/content/docs/4.8.2/deployment/kubernetes/index.html
+++ b/content/docs/4.8.2/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.8.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.8.2/overview/">4.8.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.8.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.8.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.8.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.8.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.8.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.8.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.8.2/overview/">4.8.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.8.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.8.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.8.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.8.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.8.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.8.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/deployment/manual/index.html b/content/docs/4.8.2/deployment/manual/index.html
index dfa35c4..afc6fa3 100644
--- a/content/docs/4.8.2/deployment/manual/index.html
+++ b/content/docs/4.8.2/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/development/codebase/index.html b/content/docs/4.8.2/development/codebase/index.html
index 652ea7d..981d84b 100644
--- a/content/docs/4.8.2/development/codebase/index.html
+++ b/content/docs/4.8.2/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/development/protocol/index.html b/content/docs/4.8.2/development/protocol/index.html
index edc87bb..a410e80 100644
--- a/content/docs/4.8.2/development/protocol/index.html
+++ b/content/docs/4.8.2/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/getting-started/concepts/index.html b/content/docs/4.8.2/getting-started/concepts/index.html
index 74a3e8f..c51c468 100644
--- a/content/docs/4.8.2/getting-started/concepts/index.html
+++ b/content/docs/4.8.2/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/getting-started/installation/index.html b/content/docs/4.8.2/getting-started/installation/index.html
index 30c3c28..24a95d3 100644
--- a/content/docs/4.8.2/getting-started/installation/index.html
+++ b/content/docs/4.8.2/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/getting-started/run-locally/index.html b/content/docs/4.8.2/getting-started/run-locally/index.html
index dacf3c6..cb8cf80 100644
--- a/content/docs/4.8.2/getting-started/run-locally/index.html
+++ b/content/docs/4.8.2/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/overview/index.html b/content/docs/4.8.2/overview/index.html
index 75eb6e8..f0cf5b1 100644
--- a/content/docs/4.8.2/overview/index.html
+++ b/content/docs/4.8.2/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.8.2 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.8.2 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/reference/cli/index.html b/content/docs/4.8.2/reference/cli/index.html
index 1b0fa90..3d799e3 100644
--- a/content/docs/4.8.2/reference/cli/index.html
+++ b/content/docs/4.8.2/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/reference/config/index.html b/content/docs/4.8.2/reference/config/index.html
index e41f7fc..3ad9c12 100644
--- a/content/docs/4.8.2/reference/config/index.html
+++ b/content/docs/4.8.2/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/reference/metrics/index.html b/content/docs/4.8.2/reference/metrics/index.html
index 8c12689..90a31bf 100644
--- a/content/docs/4.8.2/reference/metrics/index.html
+++ b/content/docs/4.8.2/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/security/overview/index.html b/content/docs/4.8.2/security/overview/index.html
index 4d2ee60..b8f9164 100644
--- a/content/docs/4.8.2/security/overview/index.html
+++ b/content/docs/4.8.2/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/security/sasl/index.html b/content/docs/4.8.2/security/sasl/index.html
index 23e35fd..75eede5 100644
--- a/content/docs/4.8.2/security/sasl/index.html
+++ b/content/docs/4.8.2/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/security/tls/index.html b/content/docs/4.8.2/security/tls/index.html
index ee0505c..9ec68a0 100644
--- a/content/docs/4.8.2/security/tls/index.html
+++ b/content/docs/4.8.2/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.8.2/security/zookeeper/index.html b/content/docs/4.8.2/security/zookeeper/index.html
index 863b3e6..ee37013 100644
--- a/content/docs/4.8.2/security/zookeeper/index.html
+++ b/content/docs/4.8.2/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.8.2/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.8.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" name="docsearch:version" content="4.8.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.8.2"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.8.2/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.8.2/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/autorecovery/index.html b/content/docs/4.9.2/admin/autorecovery/index.html
index 03f93fb..f455002 100644
--- a/content/docs/4.9.2/admin/autorecovery/index.html
+++ b/content/docs/4.9.2/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/bookies/index.html b/content/docs/4.9.2/admin/bookies/index.html
index c4d395e..624be95 100644
--- a/content/docs/4.9.2/admin/bookies/index.html
+++ b/content/docs/4.9.2/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/geo-replication/index.html b/content/docs/4.9.2/admin/geo-replication/index.html
index 1629695..b546449 100644
--- a/content/docs/4.9.2/admin/geo-replication/index.html
+++ b/content/docs/4.9.2/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/http/index.html b/content/docs/4.9.2/admin/http/index.html
index 1c8c9ce..f82ddae 100644
--- a/content/docs/4.9.2/admin/http/index.html
+++ b/content/docs/4.9.2/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/metrics/index.html b/content/docs/4.9.2/admin/metrics/index.html
index 6153df5..e15d8a0 100644
--- a/content/docs/4.9.2/admin/metrics/index.html
+++ b/content/docs/4.9.2/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/perf/index.html b/content/docs/4.9.2/admin/perf/index.html
index f463844..aac15b8 100644
--- a/content/docs/4.9.2/admin/perf/index.html
+++ b/content/docs/4.9.2/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/placement/index.html b/content/docs/4.9.2/admin/placement/index.html
index 2d607ae..ffc3595 100644
--- a/content/docs/4.9.2/admin/placement/index.html
+++ b/content/docs/4.9.2/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/admin/upgrade/index.html b/content/docs/4.9.2/admin/upgrade/index.html
index 76df692..ff7d9ab 100644
--- a/content/docs/4.9.2/admin/upgrade/index.html
+++ b/content/docs/4.9.2/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/api/distributedlog-api/index.html b/content/docs/4.9.2/api/distributedlog-api/index.html
index 0e52369..7408dee 100644
--- a/content/docs/4.9.2/api/distributedlog-api/index.html
+++ b/content/docs/4.9.2/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/api/ledger-adv-api/index.html b/content/docs/4.9.2/api/ledger-adv-api/index.html
index 7b78e9c..44d1d52 100644
--- a/content/docs/4.9.2/api/ledger-adv-api/index.html
+++ b/content/docs/4.9.2/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/api/ledger-api/index.html b/content/docs/4.9.2/api/ledger-api/index.html
index 28e8910..209e0c1 100644
--- a/content/docs/4.9.2/api/ledger-api/index.html
+++ b/content/docs/4.9.2/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/api/overview/index.html b/content/docs/4.9.2/api/overview/index.html
index 60ff5ee..d2fafe6 100644
--- a/content/docs/4.9.2/api/overview/index.html
+++ b/content/docs/4.9.2/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/deployment/kubernetes/index.html b/content/docs/4.9.2/deployment/kubernetes/index.html
index f46c284..f4c3861 100644
--- a/content/docs/4.9.2/deployment/kubernetes/index.html
+++ b/content/docs/4.9.2/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.9.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.9.2/overview/">4.9.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.9.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.9.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.9.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.9.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.9.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/4.9.2/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/4.9.2/overview/">4.9.2</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/4.9.2/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/4.9.2/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/4.9.2/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/4.9.2/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/4.9.2/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.9.2</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/deployment/manual/index.html b/content/docs/4.9.2/deployment/manual/index.html
index a929c96..74cf4f4 100644
--- a/content/docs/4.9.2/deployment/manual/index.html
+++ b/content/docs/4.9.2/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/development/codebase/index.html b/content/docs/4.9.2/development/codebase/index.html
index e8a6393..dac4313 100644
--- a/content/docs/4.9.2/development/codebase/index.html
+++ b/content/docs/4.9.2/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/development/protocol/index.html b/content/docs/4.9.2/development/protocol/index.html
index ca6d7a9a..ea0ada7 100644
--- a/content/docs/4.9.2/development/protocol/index.html
+++ b/content/docs/4.9.2/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/getting-started/concepts/index.html b/content/docs/4.9.2/getting-started/concepts/index.html
index 905805f..2849b14 100644
--- a/content/docs/4.9.2/getting-started/concepts/index.html
+++ b/content/docs/4.9.2/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/getting-started/installation/index.html b/content/docs/4.9.2/getting-started/installation/index.html
index 74fb507..1905900 100644
--- a/content/docs/4.9.2/getting-started/installation/index.html
+++ b/content/docs/4.9.2/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/getting-started/run-locally/index.html b/content/docs/4.9.2/getting-started/run-locally/index.html
index fd38db6..a797d8b 100644
--- a/content/docs/4.9.2/getting-started/run-locally/index.html
+++ b/content/docs/4.9.2/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/overview/index.html b/content/docs/4.9.2/overview/index.html
index 9a3d8ca..177bccd 100644
--- a/content/docs/4.9.2/overview/index.html
+++ b/content/docs/4.9.2/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.9.2 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.9.2 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/reference/cli/index.html b/content/docs/4.9.2/reference/cli/index.html
index e183b12..cc2026f 100644
--- a/content/docs/4.9.2/reference/cli/index.html
+++ b/content/docs/4.9.2/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/reference/config/index.html b/content/docs/4.9.2/reference/config/index.html
index a8e72c8..fe74e95 100644
--- a/content/docs/4.9.2/reference/config/index.html
+++ b/content/docs/4.9.2/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/reference/metrics/index.html b/content/docs/4.9.2/reference/metrics/index.html
index c3f6df0..5ca277e 100644
--- a/content/docs/4.9.2/reference/metrics/index.html
+++ b/content/docs/4.9.2/reference/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper metrics reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/reference/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper metrics reference | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/reference/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/reference/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/security/overview/index.html b/content/docs/4.9.2/security/overview/index.html
index 5b69749..fe0c5f3 100644
--- a/content/docs/4.9.2/security/overview/index.html
+++ b/content/docs/4.9.2/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/security/sasl/index.html b/content/docs/4.9.2/security/sasl/index.html
index 0ecb0f2..65c92f6 100644
--- a/content/docs/4.9.2/security/sasl/index.html
+++ b/content/docs/4.9.2/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/security/tls/index.html b/content/docs/4.9.2/security/tls/index.html
index a73ac8e..256134f 100644
--- a/content/docs/4.9.2/security/tls/index.html
+++ b/content/docs/4.9.2/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/4.9.2/security/zookeeper/index.html b/content/docs/4.9.2/security/zookeeper/index.html
index 3b62d2b..f37a60c 100644
--- a/content/docs/4.9.2/security/zookeeper/index.html
+++ b/content/docs/4.9.2/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/4.9.2/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.9.2"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" name="docsearch:version" content="4.9.2"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.9.2"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/4.9.2/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/4.9.2/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/autorecovery/index.html b/content/docs/admin/autorecovery/index.html
index a8cf52e..9bc5c69 100644
--- a/content/docs/admin/autorecovery/index.html
+++ b/content/docs/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/bookies/index.html b/content/docs/admin/bookies/index.html
index 9bef98b..d99c197 100644
--- a/content/docs/admin/bookies/index.html
+++ b/content/docs/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/decomission/index.html b/content/docs/admin/decomission/index.html
index d528ada..cabc524 100644
--- a/content/docs/admin/decomission/index.html
+++ b/content/docs/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/geo-replication/index.html b/content/docs/admin/geo-replication/index.html
index 27d6dd1..14a6da6 100644
--- a/content/docs/admin/geo-replication/index.html
+++ b/content/docs/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/http/index.html b/content/docs/admin/http/index.html
index 56bbec3..d079afa 100644
--- a/content/docs/admin/http/index.html
+++ b/content/docs/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -25,7 +25,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/metrics/index.html b/content/docs/admin/metrics/index.html
index e24f454..38ffcfa 100644
--- a/content/docs/admin/metrics/index.html
+++ b/content/docs/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/perf/index.html b/content/docs/admin/perf/index.html
index a2fc62c..229c8fc 100644
--- a/content/docs/admin/perf/index.html
+++ b/content/docs/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/placement/index.html b/content/docs/admin/placement/index.html
index 0fa09d0..eed4967 100644
--- a/content/docs/admin/placement/index.html
+++ b/content/docs/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/admin/upgrade/index.html b/content/docs/admin/upgrade/index.html
index 5119b89..3392d22 100644
--- a/content/docs/admin/upgrade/index.html
+++ b/content/docs/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/api/distributedlog-api/index.html b/content/docs/api/distributedlog-api/index.html
index 6d66be8..9a720a5 100644
--- a/content/docs/api/distributedlog-api/index.html
+++ b/content/docs/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/api/ledger-adv-api/index.html b/content/docs/api/ledger-adv-api/index.html
index 884eb2b..c5ed338 100644
--- a/content/docs/api/ledger-adv-api/index.html
+++ b/content/docs/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/api/ledger-api/index.html b/content/docs/api/ledger-api/index.html
index c53fb8e..16fb9fe 100644
--- a/content/docs/api/ledger-api/index.html
+++ b/content/docs/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/api/overview/index.html b/content/docs/api/overview/index.html
index 111ec8f..3701fdf 100644
--- a/content/docs/api/overview/index.html
+++ b/content/docs/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/deployment/kubernetes/index.html b/content/docs/deployment/kubernetes/index.html
index 33d5f9f..2ea6b81 100644
--- a/content/docs/deployment/kubernetes/index.html
+++ b/content/docs/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/overview/">4.17.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.17.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/overview/">4.17.0</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/docs/next/deployment/kubernetes">Next</a></li><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: 4.17.0</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/deployment/manual/index.html b/content/docs/deployment/manual/index.html
index 8ed721e..dec7de3 100644
--- a/content/docs/deployment/manual/index.html
+++ b/content/docs/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/development/codebase/index.html b/content/docs/development/codebase/index.html
index c8445bf..2e0d8be 100644
--- a/content/docs/development/codebase/index.html
+++ b/content/docs/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/development/protocol/index.html b/content/docs/development/protocol/index.html
index cea0c52..4ed80ed 100644
--- a/content/docs/development/protocol/index.html
+++ b/content/docs/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/getting-started/concepts/index.html b/content/docs/getting-started/concepts/index.html
index 34b8b2d..b7246ad 100644
--- a/content/docs/getting-started/concepts/index.html
+++ b/content/docs/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/getting-started/installation/index.html b/content/docs/getting-started/installation/index.html
index a69a655..996c120 100644
--- a/content/docs/getting-started/installation/index.html
+++ b/content/docs/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/getting-started/run-locally/index.html b/content/docs/getting-started/run-locally/index.html
index 47b5a9c..cf2ae7f 100644
--- a/content/docs/getting-started/run-locally/index.html
+++ b/content/docs/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/latest/api/javadoc/member-search-index.zip b/content/docs/latest/api/javadoc/member-search-index.zip
index aca028b..77830ed 100644
--- a/content/docs/latest/api/javadoc/member-search-index.zip
+++ b/content/docs/latest/api/javadoc/member-search-index.zip
Binary files differ
diff --git a/content/docs/latest/api/javadoc/package-search-index.zip b/content/docs/latest/api/javadoc/package-search-index.zip
index d2d7372..d0acddb 100644
--- a/content/docs/latest/api/javadoc/package-search-index.zip
+++ b/content/docs/latest/api/javadoc/package-search-index.zip
Binary files differ
diff --git a/content/docs/latest/api/javadoc/type-search-index.zip b/content/docs/latest/api/javadoc/type-search-index.zip
index 0c448c5..333f7a4 100644
--- a/content/docs/latest/api/javadoc/type-search-index.zip
+++ b/content/docs/latest/api/javadoc/type-search-index.zip
Binary files differ
diff --git a/content/docs/next/admin/autorecovery/index.html b/content/docs/next/admin/autorecovery/index.html
index 0f028f4..a5e53bc 100644
--- a/content/docs/next/admin/autorecovery/index.html
+++ b/content/docs/next/admin/autorecovery/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Using AutoRecovery | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/autorecovery"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Using AutoRecovery | Apache BookKeeper"><meta data-rh="true" name="description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><meta data-rh="true" property="og:description" content="When a bookie crashes, all ledgers on that bookie become under-replicated. In order to bring all ledgers in your BookKeeper cluster back to full replication, you&#x27;ll need to recover the data from any offline bookies. There are two ways to recover bookies&#x27; data:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/autorecovery"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/autorecovery" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/autorecovery" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/bookies/index.html b/content/docs/next/admin/bookies/index.html
index 98a65a7..f8a9f53 100644
--- a/content/docs/next/admin/bookies/index.html
+++ b/content/docs/next/admin/bookies/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper administration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/bookies"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper administration | Apache BookKeeper"><meta data-rh="true" name="description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><meta data-rh="true" property="og:description" content="This document is a guide to deploying, administering, and maintaining BookKeeper. It also discusses best practices and common problems."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/bookies"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/bookies" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/bookies" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/decomission/index.html b/content/docs/next/admin/decomission/index.html
index 4f14acb..f1a6a5a 100644
--- a/content/docs/next/admin/decomission/index.html
+++ b/content/docs/next/admin/decomission/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Decommission Bookies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/decomission"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Decommission Bookies | Apache BookKeeper"><meta data-rh="true" name="description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><meta data-rh="true" property="og:description" content="In case the user wants to decommission a bookie, the following process is useful to follow in order to verify if the"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/decomission"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/decomission" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/decomission" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -33,7 +33,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/geo-replication/index.html b/content/docs/next/admin/geo-replication/index.html
index 2adcd35..62fc21e 100644
--- a/content/docs/next/admin/geo-replication/index.html
+++ b/content/docs/next/admin/geo-replication/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Geo-replication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/geo-replication"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Geo-replication | Apache BookKeeper"><meta data-rh="true" name="description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><meta data-rh="true" property="og:description" content="Geo-replication is the replication of data across BookKeeper clusters. In order to enable geo-replication for a group of BookKeeper clusters,"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/geo-replication"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/geo-replication" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/geo-replication" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/http/index.html b/content/docs/next/admin/http/index.html
index 85a5baf..c6168ea 100644
--- a/content/docs/next/admin/http/index.html
+++ b/content/docs/next/admin/http/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Admin REST API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/http"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper Admin REST API | Apache BookKeeper"><meta data-rh="true" name="description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><meta data-rh="true" property="og:description" content="This document introduces BookKeeper HTTP endpoints, which can be used for BookKeeper administration."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/http"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/http" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/http" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/metrics/index.html b/content/docs/next/admin/metrics/index.html
index 1a7023a..d107591 100644
--- a/content/docs/next/admin/metrics/index.html
+++ b/content/docs/next/admin/metrics/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Metric collection | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/metrics"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Metric collection | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper enables metrics collection through a variety of stats providers."><meta data-rh="true" property="og:description" content="BookKeeper enables metrics collection through a variety of stats providers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/metrics"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/metrics" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/metrics" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/perf/index.html b/content/docs/next/admin/perf/index.html
index b9f8262..c2791c7 100644
--- a/content/docs/next/admin/perf/index.html
+++ b/content/docs/next/admin/perf/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Performance tuning | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/perf"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Performance tuning | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/perf"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/perf" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/perf" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/placement/index.html b/content/docs/next/admin/placement/index.html
index 5e35c2a..2af200e 100644
--- a/content/docs/next/admin/placement/index.html
+++ b/content/docs/next/admin/placement/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Customized placement policies | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/placement"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Customized placement policies | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/placement"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/placement" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/placement" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/admin/upgrade/index.html b/content/docs/next/admin/upgrade/index.html
index a07d543..568e42c 100644
--- a/content/docs/next/admin/upgrade/index.html
+++ b/content/docs/next/admin/upgrade/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Upgrade | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/admin/upgrade"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Upgrade | Apache BookKeeper"><meta data-rh="true" name="description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><meta data-rh="true" property="og:description" content="If you have questions about upgrades (or need help), please feel free to reach out to us by mailing list or Slack Channel."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/admin/upgrade"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/upgrade" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/admin/upgrade" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -64,7 +64,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/api/distributedlog-api/index.html b/content/docs/next/api/distributedlog-api/index.html
index c3dab8c..3f89805 100644
--- a/content/docs/next/api/distributedlog-api/index.html
+++ b/content/docs/next/api/distributedlog-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">DistributedLog | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/api/distributedlog-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="DistributedLog | Apache BookKeeper"><meta data-rh="true" name="description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><meta data-rh="true" property="og:description" content="DistributedLog began its life as a separate project under the Apache Foundation. It was merged into BookKeeper in 2017."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/api/distributedlog-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/distributedlog-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/distributedlog-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/api/ledger-adv-api/index.html b/content/docs/next/api/ledger-adv-api/index.html
index d953caf..76ec51b 100644
--- a/content/docs/next/api/ledger-adv-api/index.html
+++ b/content/docs/next/api/ledger-adv-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Advanced Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/api/ledger-adv-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="The Advanced Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><meta data-rh="true" property="og:description" content="In release 4.5.0, Apache BookKeeper introduces a few advanced API for advanced usage."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/api/ledger-adv-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/ledger-adv-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/ledger-adv-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -27,7 +27,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/api/ledger-api/index.html b/content/docs/next/api/ledger-api/index.html
index 5b7c811..04cfc78 100644
--- a/content/docs/next/api/ledger-api/index.html
+++ b/content/docs/next/api/ledger-api/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The Ledger API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/api/ledger-api"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="The Ledger API | Apache BookKeeper"><meta data-rh="true" name="description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><meta data-rh="true" property="og:description" content="The ledger API is a lower-level API for BookKeeper that enables you to interact with ledgers directly."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/api/ledger-api"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/ledger-api" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/ledger-api" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -46,7 +46,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/api/overview/index.html b/content/docs/next/api/overview/index.html
index b5930bc..da07ca0 100644
--- a/content/docs/next/api/overview/index.html
+++ b/content/docs/next/api/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper API | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/api/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper API | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><meta data-rh="true" property="og:description" content="BookKeeper offers a few APIs that applications can use to interact with it:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/api/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/api/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/deployment/kubernetes/index.html b/content/docs/next/deployment/kubernetes/index.html
index 786445b..ba525f8 100644
--- a/content/docs/next/deployment/kubernetes/index.html
+++ b/content/docs/next/deployment/kubernetes/index.html
@@ -4,12 +4,12 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/deployment/kubernetes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Deploying Apache BookKeeper on Kubernetes | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><meta data-rh="true" property="og:description" content="Apache BookKeeper can be easily deployed in Kubernetes clusters. The managed clusters on Google Container Engine is the most convenient way."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/deployment/kubernetes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/deployment/kubernetes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/deployment/kubernetes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
 <script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){var t=null;try{t=new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}return t}()||function(){var t=null;try{t=localStorage.getItem("theme")}catch(t){}return t}();t(null!==e?e:"light")}()</script><div id="__docusaurus">
-<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/next/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/next/overview/">Next</a><ul class="dropdown__menu"><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/next/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/next/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/next/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/next/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: Next</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/container-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
+<div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--light_HNdA"><img src="/img/bk-logo.svg" alt="Apache Bookkeeper" class="themedImage_ToTc themedImage--dark_i4oU"></div><b class="navbar__title text--truncate">Apache BookKeeper</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/docs/next/overview/">Documentation</a><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Community</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/community/mailing-lists">Mailing lists</a></li><li><a class="dropdown__link" href="/community/slack">Slack</a></li><li><a href="https://github.com/apache/bookkeeper/issues" target="_blank" rel="noopener noreferrer" class="dropdown__link">Github issues<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/community/releases">Release management</a></li><li><a class="dropdown__link" href="/community/meeting">Community meetings</a></li><li><a class="dropdown__link" href="/community/contributing">Contribution guide</a></li><li><a class="dropdown__link" href="/community/coding-guide">Coding guide</a></li><li><a class="dropdown__link" href="/community/testing">Testing guide</a></li><li><a class="dropdown__link" href="/community/issue-report">Issue report guide</a></li><li><a class="dropdown__link" href="/community/release-guide">Release guide</a></li><li><a class="dropdown__link" href="/community/presentations">Presentations</a></li><li><a class="dropdown__link" href="/community/bookkeeper-proposals">BookKeeper proposals (BP)</a></li></ul></div><div class="navbar__item dropdown dropdown--hoverable"><a href="#" aria-haspopup="true" aria-expanded="false" role="button" class="navbar__link">Project</a><ul class="dropdown__menu"><li><a class="dropdown__link" href="/project/who">Who are we?</a></li><li><a class="dropdown__link" href="/project/bylaws">Bylaws</a></li><li><a href="https://apache.org/licenses" target="_blank" rel="noopener noreferrer" class="dropdown__link">License<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a class="dropdown__link" href="/project/privacy">Privacy policy</a></li><li><a href="https://www.apache.org/foundation/sponsorship.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Sponsorship<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li><li><a href="https://www.apache.org/foundation/thanks.html" target="_blank" rel="noopener noreferrer" class="dropdown__link">Thanks<svg width="12" height="12" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a></li></ul></div></div><div class="navbar__items navbar__items--right"><div class="navbar__item dropdown dropdown--hoverable dropdown--right"><a class="navbar__link" aria-haspopup="true" aria-expanded="false" role="button" href="/docs/next/overview/">Next</a><ul class="dropdown__menu"><li><a aria-current="page" class="dropdown__link dropdown__link--active" href="/docs/next/deployment/kubernetes">Next</a></li><li><a class="dropdown__link" href="/docs/deployment/kubernetes">4.17.0</a></li><li><a class="dropdown__link" href="/docs/4.16.5/deployment/kubernetes">4.16.5</a></li><li><a class="dropdown__link" href="/docs/4.15.5/deployment/kubernetes">4.15.5</a></li><li><a class="dropdown__link" href="/docs/4.14.8/deployment/kubernetes">4.14.8</a></li><li><a class="dropdown__link" href="/docs/4.13.0/deployment/kubernetes">4.13.0</a></li><li><a class="dropdown__link" href="/docs/4.12.1/deployment/kubernetes">4.12.1</a></li><li><a class="dropdown__link" href="/docs/4.11.1/deployment/kubernetes">4.11.1</a></li><li><a class="dropdown__link" href="/docs/4.10.0/deployment/kubernetes">4.10.0</a></li><li><a class="dropdown__link" href="/docs/4.9.2/deployment/kubernetes">4.9.2</a></li><li><a class="dropdown__link" href="/docs/4.8.2/deployment/kubernetes">4.8.2</a></li><li><a class="dropdown__link" href="/docs/4.7.3/deployment/kubernetes">4.7.3</a></li><li><a class="dropdown__link" href="/docs/4.6.2/deployment/kubernetes">4.6.2</a></li><li><a class="dropdown__link" href="/docs/4.5.1/deployment/kubernetes">4.5.1</a></li></ul></div><a class="navbar__item navbar__link" href="/releases">Download</a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="searchBox_ZlJk"></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0 docsWrapper_BCFX"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_sjWU" type="button"></button><div class="docPage__5DB"><aside class="theme-doc-sidebar-container docSidebarContainer_b6E3"><div class="sidebarViewport_Xe31"><div class="sidebar_njMd"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_SIkG"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/docs/next/overview/">Overview</a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/getting-started/installation">Getting started</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret menu__link--active" aria-expanded="true" href="/docs/next/deployment/manual">Deployment</a></div><ul style="display:block;overflow:visible;height:auto" class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/docs/next/deployment/manual">Manual deployment</a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/docs/next/deployment/kubernetes">BookKeeper on Kubernetes</a></li></ul></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/admin/bookies">Administration</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/api/overview">API</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/security/overview">Security</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/development/protocol">Development</a></div></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="menu__link menu__link--sublist menu__link--sublist-caret" aria-expanded="false" href="/docs/next/reference/config">Reference</a></div></li></ul></nav></div></div></aside><main class="docMainContainer_gTbr"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_VOVn"><div class="docItemContainer_Djhp"><article><span class="theme-doc-version-badge badge badge--secondary">Version: Next</span><div class="tocCollapsible_ETCw theme-doc-toc-mobile tocMobile_ITEo"><button type="button" class="clean-btn tocCollapsibleButton_TO0P">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Deploying Apache BookKeeper on Kubernetes</h1></header><p>Apache BookKeeper can be easily deployed in <a href="https://kubernetes.io/" target="_blank" rel="noopener noreferrer">Kubernetes</a> clusters. The managed clusters on <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Container Engine</a> is the most convenient way.</p><p>The deployment method shown in this guide relies on <a href="http://yaml.org/" target="_blank" rel="noopener noreferrer">YAML</a> definitions for Kubernetes <a href="https://kubernetes.io/docs/resources-reference/v1.6/" target="_blank" rel="noopener noreferrer">resources</a>. The <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> subdirectory holds resource definitions for:</p><ul><li>A three-node ZooKeeper cluster</li><li>A BookKeeper cluster with a bookie runs on each node.</li></ul><h2 class="anchor anchorWithStickyNavbar_LWe7" id="setup-on-google-container-engine">Setup on Google Container Engine<a href="#setup-on-google-container-engine" class="hash-link" aria-label="Direct link to Setup on Google Container Engine" title="Direct link to Setup on Google Container Engine">​</a></h2><p>To get started, get source code of <a href="https://github.com/apache/bookkeeper/tree/master/deploy/kubernetes" target="_blank" rel="noopener noreferrer"><code>kubernetes</code></a> from github by git clone.</p><p>If you&#x27;d like to change the number of bookies,  or ZooKeeper nodes in your BookKeeper cluster, modify the <code>replicas</code> parameter in the <code>spec</code> section of the appropriate <a href="https://kubernetes.io/docs/concepts/workloads/controllers/deployment/" target="_blank" rel="noopener noreferrer"><code>Deployment</code></a> or <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer"><code>StatefulSet</code></a> resource.</p><p><a href="https://cloud.google.com/kubernetes-engine" target="_blank" rel="noopener noreferrer">Google Container Engine</a> (GKE) automates the creation and management of Kubernetes clusters in <a href="https://cloud.google.com/compute/" target="_blank" rel="noopener noreferrer">Google Compute Engine</a> (GCE).</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="prerequisites">Prerequisites<a href="#prerequisites" class="hash-link" aria-label="Direct link to Prerequisites" title="Direct link to Prerequisites">​</a></h3><p>To get started, you&#x27;ll need:</p><ul><li>A Google Cloud Platform account, which you can sign up for at <a href="https://cloud.google.com" target="_blank" rel="noopener noreferrer">cloud.google.com</a></li><li>An existing Cloud Platform project</li><li>The <a href="https://cloud.google.com/sdk/downloads" target="_blank" rel="noopener noreferrer">Google Cloud SDK</a> (in particular the <a href="https://cloud.google.com/sdk/gcloud/" target="_blank" rel="noopener noreferrer"><code>gcloud</code></a> and <a href="https://kubernetes.io/docs/tasks/tools/" target="_blank" rel="noopener noreferrer"><code>kubectl</code></a> tools).</li></ul><h3 class="anchor anchorWithStickyNavbar_LWe7" id="create-a-new-kubernetes-cluster">Create a new Kubernetes cluster<a href="#create-a-new-kubernetes-cluster" class="hash-link" aria-label="Direct link to Create a new Kubernetes cluster" title="Direct link to Create a new Kubernetes cluster">​</a></h3><p>You can create a new GKE cluster using the <a href="https://cloud.google.com/sdk/gcloud/reference/container/clusters/create" target="_blank" rel="noopener noreferrer"><code>container clusters create</code></a> command for <code>gcloud</code>. This command enables you to specify the number of nodes in the cluster, the machine types of those nodes, and more.</p><p>As an example, we&#x27;ll create a new GKE cluster for Kubernetes version <a href="https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG.md#v164" target="_blank" rel="noopener noreferrer">1.6.4</a> in the <a href="https://cloud.google.com/compute/docs/regions-zones/regions-zones#available" target="_blank" rel="noopener noreferrer">us-central1-a</a> zone. The cluster will be named <code>bookkeeper-gke-cluster</code> and will consist of three VMs, each using two locally attached SSDs and running on <a href="https://cloud.google.com/compute/docs/machine-types" target="_blank" rel="noopener noreferrer">n1-standard-8</a> machines. These SSDs will be used by Bookie instances, one for the BookKeeper journal and the other for storing the actual data.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> compute/zone us-central1-a</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud config </span><span class="token builtin class-name">set</span><span class="token plain"> project your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters create bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --machine-type</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">n1-standard-8 </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --num-nodes</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">3</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --local-ssd-count</span><span class="token operator" style="color:#393A34">=</span><span class="token number" style="color:#36acaa">2</span><span class="token plain"> </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --enable-kubernetes-alpha</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, bookies will run on all the machines that have locally attached SSD disks. In this example, all of those machines will have two SSDs, but you can add different types of machines to the cluster later. You can control which machines host bookie servers using <a href="https://kubernetes.io/docs/concepts/overview/working-with-objects/labels" target="_blank" rel="noopener noreferrer">labels</a>.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="dashboard">Dashboard<a href="#dashboard" class="hash-link" aria-label="Direct link to Dashboard" title="Direct link to Dashboard">​</a></h3><p>You can observe your cluster in the <a href="https://kubernetes.io/docs/tasks/access-application-cluster/web-ui-dashboard/" target="_blank" rel="noopener noreferrer">Kubernetes Dashboard</a> by downloading the credentials for your Kubernetes cluster and opening up a proxy to the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ gcloud container clusters get-credentials bookkeeper-gke-cluster </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --zone</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">us-central1-a </span><span class="token punctuation" style="color:#393A34">\</span><span class="token plain"></span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">  --project</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">your-project-name</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl proxy</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>By default, the proxy will be opened on port 8001. Now you can navigate to <a href="http://localhost:8001/ui" target="_blank" rel="noopener noreferrer">localhost:8001/ui</a> in your browser to access the dashboard. At first your GKE cluster will be empty, but that will change as you begin deploying.</p><p>When you create a cluster, your <code>kubectl</code> config in <code>~/.kube/config</code> (on MacOS and Linux) will be updated for you, so you probably won&#x27;t need to change your configuration. Nonetheless, you can ensure that <code>kubectl</code> can interact with your cluster by listing the nodes in the cluster:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get nodes</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>If <code>kubectl</code> is working with your cluster, you can proceed to deploy ZooKeeper and Bookies.</p><h3 class="anchor anchorWithStickyNavbar_LWe7" id="zookeeper">ZooKeeper<a href="#zookeeper" class="hash-link" aria-label="Direct link to ZooKeeper" title="Direct link to ZooKeeper">​</a></h3><p>You <em>must</em> deploy ZooKeeper as the first component, as it is a dependency for the others.</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl apply -f zookeeper.yaml</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>Wait until all three ZooKeeper server pods are up and have the status <code>Running</code>. You can check on the status of the ZooKeeper pods at any time:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl get pods -l </span><span class="token assign-left variable" style="color:#36acaa">component</span><span class="token operator" style="color:#393A34">=</span><span class="token plain">zookeeper</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">NAME      READY     STATUS             RESTARTS   AGE</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-0      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          18m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-1      </span><span class="token number" style="color:#36acaa">1</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">          17m</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">zk-2      </span><span class="token number" style="color:#36acaa">0</span><span class="token plain">/1       Running            </span><span class="token number" style="color:#36acaa">6</span><span class="token plain">          15m</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><p>This step may take several minutes, as Kubernetes needs to download the Docker image on the VMs.</p><p>If you want to connect to one of the remote zookeeper server, you can use<a href="https://github.com/rgs1/zk_shell" target="_blank" rel="noopener noreferrer">zk-shell</a>, you need to forward a local port to the
 remote zookeeper server:</p><div class="language-bash codeBlockContainer_Ckt0 theme-code-block" style="--prism-color:#393A34;--prism-background-color:#f6f8fa"><div class="codeBlockContent_biex"><pre tabindex="0" class="prism-code language-bash codeBlock_bY9V thin-scrollbar"><code class="codeBlockLines_e6Vv"><span class="token-line" style="color:#393A34"><span class="token plain">$ kubectl port-forward zk-0 </span><span class="token number" style="color:#36acaa">2181</span><span class="token plain">:2181</span><br></span><span class="token-line" style="color:#393A34"><span class="token plain">$ zk-shell localhost </span><span class="token number" style="color:#36acaa">2181</span><br></span></code></pre><div class="buttonGroup__atx"><button type="button" aria-label="Copy code to clipboard" title="Copy" class="clean-btn"><span class="copyButtonIcons_eSgA" aria-hidden="true"><svg class="copyButtonIcon_y97N" viewBox="0 0 24 24"><path d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"></path></svg><svg class="copyButtonSuccessIcon_LjdS" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z"></path></svg></span></button></div></div></div><h3 class="anchor anchorWithStickyNavbar_LWe7" id="deploy-bookies">Deploy Bookies<a href="#deploy-bookies" class="hash-link" aria-label="Direct link to Deploy Bookies" title="Direct link to Deploy Bookies">​</a></h3><p>Once ZooKeeper cluster is Running, you can then deploy the bookies. You can deploy the bookies either using a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/" target="_blank" rel="noopener noreferrer">DaemonSet</a> or a <a href="https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/" target="_blank" rel="noopener noreferrer">StatefulSet</a>.</p><blockquote><p>NOTE: <em>DaemonSet</em> vs <em>StatefulSet</em></p><p>A <em>DaemonSet</em> ensures that all (or some) nodes run a pod of bookie instance. As nodes are added to the cluster, bookie pods are added automatically to them. As nodes are removed from the
 cluster, those bookie pods are garbage collected. The bookies deployed in a DaemonSet stores data on the local disks on those nodes. So it doesn&#x27;t require any external storage for Persistent
 Volumes.</p><p>A <em>StatefulSet</em> maintains a sticky identity for the pods that it runs and manages. It provides stable and unique network identifiers, and stable and persistent storage for each pod. The pods
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/deployment/manual/index.html b/content/docs/next/deployment/manual/index.html
index c05a1ef..f4c28e6 100644
--- a/content/docs/next/deployment/manual/index.html
+++ b/content/docs/next/deployment/manual/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Manual deployment | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/deployment/manual"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Manual deployment | Apache BookKeeper"><meta data-rh="true" name="description" content="A BookKeeper cluster consists of two main components:"><meta data-rh="true" property="og:description" content="A BookKeeper cluster consists of two main components:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/deployment/manual"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/deployment/manual" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/deployment/manual" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/development/codebase/index.html b/content/docs/next/development/codebase/index.html
index 5c12cf6..1931755 100644
--- a/content/docs/next/development/codebase/index.html
+++ b/content/docs/next/development/codebase/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper codebase | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/development/codebase"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="The BookKeeper codebase | Apache BookKeeper"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/development/codebase"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/development/codebase" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/development/codebase" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/development/protocol/index.html b/content/docs/next/development/protocol/index.html
index ede1c99..b934c1a 100644
--- a/content/docs/next/development/protocol/index.html
+++ b/content/docs/next/development/protocol/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">The BookKeeper protocol | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/development/protocol"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="The BookKeeper protocol | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><meta data-rh="true" property="og:description" content="BookKeeper uses a special replication protocol for guaranteeing persistent storage of entries in an ensemble of bookies."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/development/protocol"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/development/protocol" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/development/protocol" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/getting-started/concepts/index.html b/content/docs/next/getting-started/concepts/index.html
index 2a295a2..175da34 100644
--- a/content/docs/next/getting-started/concepts/index.html
+++ b/content/docs/next/getting-started/concepts/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper concepts and architecture | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/getting-started/concepts"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper concepts and architecture | Apache BookKeeper"><meta data-rh="true" name="description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><meta data-rh="true" property="og:description" content="BookKeeper is a service that provides persistent storage of streams of log entries---aka records---in sequences called ledgers. BookKeeper replicates stored entries across multiple servers."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/getting-started/concepts"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/concepts" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/concepts" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/getting-started/installation/index.html b/content/docs/next/getting-started/installation/index.html
index c7c9268..d1c6414 100644
--- a/content/docs/next/getting-started/installation/index.html
+++ b/content/docs/next/getting-started/installation/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper installation | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/getting-started/installation"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper installation | Apache BookKeeper"><meta data-rh="true" name="description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><meta data-rh="true" property="og:description" content="You can install BookKeeper either by downloading a GZipped tarball package, using the Docker image or cloning the BookKeeper repository."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/getting-started/installation"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/installation" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/installation" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/getting-started/run-locally/index.html b/content/docs/next/getting-started/run-locally/index.html
index 1d62484..31606f5 100644
--- a/content/docs/next/getting-started/run-locally/index.html
+++ b/content/docs/next/getting-started/run-locally/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Run bookies locally | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/getting-started/run-locally"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Run bookies locally | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><meta data-rh="true" property="og:description" content="Bookies are individual BookKeeper servers. You can run an ensemble of bookies locally on a single machine using the localbookie command of the bookkeeper CLI tool and specifying the number of bookies you&#x27;d like to include in the ensemble."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/getting-started/run-locally"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/run-locally" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/getting-started/run-locally" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/overview/index.html b/content/docs/next/overview/index.html
index 814ff62..c6a82f0 100644
--- a/content/docs/next/overview/index.html
+++ b/content/docs/next/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.18.0-SNAPSHOT | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.18.0-SNAPSHOT | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/reference/cli/index.html b/content/docs/next/reference/cli/index.html
index 4302eb8..dbd84ed 100644
--- a/content/docs/next/reference/cli/index.html
+++ b/content/docs/next/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/reference/config/index.html b/content/docs/next/reference/config/index.html
index 01bf5f3..2785abb 100644
--- a/content/docs/next/reference/config/index.html
+++ b/content/docs/next/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/security/overview/index.html b/content/docs/next/security/overview/index.html
index 2c9c3f4..07e1ea4 100644
--- a/content/docs/next/security/overview/index.html
+++ b/content/docs/next/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/security/sasl/index.html b/content/docs/next/security/sasl/index.html
index 3f5b941..8c5ef37 100644
--- a/content/docs/next/security/sasl/index.html
+++ b/content/docs/next/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/security/tls/index.html b/content/docs/next/security/tls/index.html
index 9583982..1862e25 100644
--- a/content/docs/next/security/tls/index.html
+++ b/content/docs/next/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/next/security/zookeeper/index.html b/content/docs/next/security/zookeeper/index.html
index 2ab9284..a9e7d33 100644
--- a/content/docs/next/security/zookeeper/index.html
+++ b/content/docs/next/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/next/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/next/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/next/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/overview/index.html b/content/docs/overview/index.html
index 07847a3..3b96766 100644
--- a/content/docs/overview/index.html
+++ b/content/docs/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper 4.17.0 | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/overview/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Apache BookKeeper 4.17.0 | Apache BookKeeper"><meta data-rh="true" name="description" content="&lt;!--"><meta data-rh="true" property="og:description" content="&lt;!--"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/overview/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/overview/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/overview/" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -24,7 +24,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/reference/cli/index.html b/content/docs/reference/cli/index.html
index 22356de..6d0203d 100644
--- a/content/docs/reference/cli/index.html
+++ b/content/docs/reference/cli/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper CLI tool reference | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/reference/cli"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper CLI tool reference | Apache BookKeeper"><meta data-rh="true" name="description" content="bookkeeper command"><meta data-rh="true" property="og:description" content="bookkeeper command"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/reference/cli"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/reference/cli" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/reference/cli" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/reference/config/index.html b/content/docs/reference/config/index.html
index cff4da8..c14140a 100644
--- a/content/docs/reference/config/index.html
+++ b/content/docs/reference/config/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper configuration | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/reference/config"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper configuration | Apache BookKeeper"><meta data-rh="true" name="description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><meta data-rh="true" property="og:description" content="The table below lists parameters that you can set to configure bookies. All configuration takes place in the bk_server.conf file in the bookkeeper-server/conf directory of your BookKeeper installation."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/reference/config"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/reference/config" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/reference/config" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/security/overview/index.html b/content/docs/security/overview/index.html
index 5db3ff9..618f19a 100644
--- a/content/docs/security/overview/index.html
+++ b/content/docs/security/overview/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">BookKeeper Security | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/security/overview"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="BookKeeper Security | Apache BookKeeper"><meta data-rh="true" name="description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><meta data-rh="true" property="og:description" content="In the 4.5.0 release, the BookKeeper community added a number of features that can be used, together or separately, to secure a BookKeeper cluster."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/security/overview"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/overview" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/overview" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -23,7 +23,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/security/sasl/index.html b/content/docs/security/sasl/index.html
index d0c46ed..6371af2 100644
--- a/content/docs/security/sasl/index.html
+++ b/content/docs/security/sasl/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Authentication using SASL | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/security/sasl"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Authentication using SASL | Apache BookKeeper"><meta data-rh="true" name="description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><meta data-rh="true" property="og:description" content="Bookies support client authentication via SASL. Currently we only support GSSAPI (Kerberos). We will start"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/security/sasl"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/sasl" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/sasl" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -45,7 +45,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/security/tls/index.html b/content/docs/security/tls/index.html
index 897c3eb..c332356 100644
--- a/content/docs/security/tls/index.html
+++ b/content/docs/security/tls/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Encryption and Authentication using TLS | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/security/tls"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="Encryption and Authentication using TLS | Apache BookKeeper"><meta data-rh="true" name="description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><meta data-rh="true" property="og:description" content="Apache BookKeeper allows clients and autorecovery daemons to communicate over TLS, although this is not enabled by default."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/security/tls"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/tls" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/tls" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -53,7 +53,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/docs/security/zookeeper/index.html b/content/docs/security/zookeeper/index.html
index 814acc2..754aa88 100644
--- a/content/docs/security/zookeeper/index.html
+++ b/content/docs/security/zookeeper/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">ZooKeeper Authentication | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/docs/security/zookeeper"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docusaurus_version" content="4.17.0"><meta data-rh="true" name="docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" name="docsearch:version" content="4.17.0"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-4.17.0"><meta data-rh="true" property="og:title" content="ZooKeeper Authentication | Apache BookKeeper"><meta data-rh="true" name="description" content="New Clusters"><meta data-rh="true" property="og:description" content="New Clusters"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/docs/security/zookeeper"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/zookeeper" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/docs/security/zookeeper" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -29,7 +29,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/index.html b/content/index.html
index c932e81..f5f785c 100644
--- a/content/index.html
+++ b/content/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Hello from Apache BookKeeper | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Hello from Apache BookKeeper | Apache BookKeeper"><meta data-rh="true" name="description" content="A scalable, fault-tolerant, and low-latency storage service optimized for real-time workloads&gt;"><meta data-rh="true" property="og:description" content="A scalable, fault-tolerant, and low-latency storage service optimized for real-time workloads&gt;"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/" hreflang="x-default"><script data-rh="true">function maybeInsertBanner(){window.__DOCUSAURUS_INSERT_BASEURL_BANNER&&insertBanner()}function insertBanner(){var n=document.getElementById("docusaurus-base-url-issue-banner-container");if(n){n.innerHTML='\n<div id="docusaurus-base-url-issue-banner" style="border: thick solid red; background-color: rgb(255, 230, 179); margin: 20px; padding: 20px; font-size: 20px;">\n   <p style="font-weight: bold; font-size: 30px;">Your Docusaurus site did not load properly.</p>\n   <p>A very common reason is a wrong site <a href="https://docusaurus.io/docs/docusaurus.config.js/#baseUrl" style="font-weight: bold;">baseUrl configuration</a>.</p>\n   <p>Current configured baseUrl = <span style="font-weight: bold; color: red;">/</span>  (default value)</p>\n   <p>We suggest trying baseUrl = <span id="docusaurus-base-url-issue-banner-suggestion-container" style="font-weight: bold; color: green;"></span></p>\n</div>\n';var e=document.getElementById("docusaurus-base-url-issue-banner-suggestion-container"),s=window.location.pathname,r="/"===s.substr(-1)?s:s+"/";e.innerHTML=r}}window.__DOCUSAURUS_INSERT_BASEURL_BANNER=!0,document.addEventListener("DOMContentLoaded",maybeInsertBanner)</script><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/project/bylaws/index.html b/content/project/bylaws/index.html
index e06800d..8ff0a8c 100644
--- a/content/project/bylaws/index.html
+++ b/content/project/bylaws/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Bylaws | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/project/bylaws"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Bylaws | Apache BookKeeper"><meta data-rh="true" name="description" content="This is version 1 of the bylaws. The BookKeeper PMC ratified these bylaws by a 2/3 majority vote on 2014/12/11."><meta data-rh="true" property="og:description" content="This is version 1 of the bylaws. The BookKeeper PMC ratified these bylaws by a 2/3 majority vote on 2014/12/11."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/project/bylaws"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/bylaws" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/bylaws" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/project/privacy/index.html b/content/project/privacy/index.html
index 48d6604..aa74db7 100644
--- a/content/project/privacy/index.html
+++ b/content/project/privacy/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Privacy policy | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/project/privacy"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Privacy policy | Apache BookKeeper"><meta data-rh="true" name="description" content="Information about your use of this website is collected using server access logs and a tracking cookie. The collected information consists of the following:"><meta data-rh="true" property="og:description" content="Information about your use of this website is collected using server access logs and a tracking cookie. The collected information consists of the following:"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/project/privacy"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/privacy" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/privacy" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/project/who/index.html b/content/project/who/index.html
index 0178e2b..8d8d90a 100644
--- a/content/project/who/index.html
+++ b/content/project/who/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Who are we? | Apache BookKeeper</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/project/who"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Who are we? | Apache BookKeeper"><meta data-rh="true" name="description" content="PMC members"><meta data-rh="true" property="og:description" content="PMC members"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/project/who"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/who" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/project/who" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -22,7 +22,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/release-notes/index.html b/content/release-notes/index.html
index 4ba593a..f56c0f1 100644
--- a/content/release-notes/index.html
+++ b/content/release-notes/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper</title><meta data-rh="true" property="og:title" content="Apache BookKeeper"><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/release-notes"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" name="description" content="4.17.0"><meta data-rh="true" property="og:description" content="4.17.0"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/release-notes"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/release-notes" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/release-notes" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -163,7 +163,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
diff --git a/content/releases/index.html b/content/releases/index.html
index e74ac79..7801482 100644
--- a/content/releases/index.html
+++ b/content/releases/index.html
@@ -4,7 +4,7 @@
 <meta charset="UTF-8">
 <meta name="generator" content="Docusaurus v2.4.0">
 <title data-rh="true">Apache BookKeeper</title><meta data-rh="true" property="og:title" content="Apache BookKeeper"><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://bookkeeper.apache.org/releases"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" name="description" content="Version 4.17.0 is the latest release of BookKeeper. The current stable version is 4.16.5."><meta data-rh="true" property="og:description" content="Version 4.17.0 is the latest release of BookKeeper. The current stable version is 4.16.5."><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://bookkeeper.apache.org/releases"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/releases" hreflang="en"><link data-rh="true" rel="alternate" href="https://bookkeeper.apache.org/releases" hreflang="x-default"><link rel="stylesheet" href="/assets/css/styles.49914aab.css">
-<link rel="preload" href="/assets/js/runtime~main.26cc152e.js" as="script">
+<link rel="preload" href="/assets/js/runtime~main.94f37568.js" as="script">
 <link rel="preload" href="/assets/js/main.3c90c5ad.js" as="script">
 </head>
 <body class="navigation-with-keyboard">
@@ -62,7 +62,7 @@
         </div>
       </footer>
       </div></div></div></footer></div>
-<script src="/assets/js/runtime~main.26cc152e.js"></script>
+<script src="/assets/js/runtime~main.94f37568.js"></script>
 <script src="/assets/js/main.3c90c5ad.js"></script>
 </body>
 </html>
\ No newline at end of file
