blob: 1946d50efaf9341eeb1e53e1ba29c0f638354992 [file] [log] [blame]
/*! For license information please see 0b8045ed.498fe089.js.LICENSE.txt */
(self.webpackChunkwebsite=self.webpackChunkwebsite||[]).push([[7550],{4137:function(e,t,r){"use strict";r.d(t,{Zo:function(){return u},kt:function(){return d}});var n=r(7294);function a(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function o(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function l(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?o(Object(r),!0).forEach((function(t){a(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):o(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}function i(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var A=n.createContext({}),s=function(e){var t=n.useContext(A),r=t;return e&&(r="function"==typeof e?e(t):l(l({},t),e)),r},u=function(e){var t=s(e.components);return n.createElement(A.Provider,{value:t},e.children)},c={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},p=n.forwardRef((function(e,t){var r=e.components,a=e.mdxType,o=e.originalType,A=e.parentName,u=i(e,["components","mdxType","originalType","parentName"]),p=s(r),d=a,m=p["".concat(A,".").concat(d)]||p[d]||c[d]||o;return r?n.createElement(m,l(l({ref:t},u),{},{components:r})):n.createElement(m,l({ref:t},u))}));function d(e,t){var r=arguments,a=t&&t.mdxType;if("string"==typeof e||a){var o=r.length,l=new Array(o);l[0]=p;var i={};for(var A in t)hasOwnProperty.call(t,A)&&(i[A]=t[A]);i.originalType=e,i.mdxType="string"==typeof e?e:a,l[1]=i;for(var s=2;s<o;s++)l[s]=r[s];return n.createElement.apply(null,l)}return n.createElement.apply(null,r)}p.displayName="MDXCreateElement"},8448:function(e,t,r){"use strict";var n=r(7294);t.Z=function(e){var t=e.children,r=e.hidden,a=e.className;return n.createElement("div",{role:"tabpanel",hidden:r,className:a},t)}},7358:function(e,t,r){"use strict";r.d(t,{Z:function(){return c}});var n=r(7294),a=r(2713);var o=function(){var e=(0,n.useContext)(a.Z);if(null==e)throw new Error('"useUserPreferencesContext" is used outside of "Layout" component.');return e},l=r(6010),i="tabItem_1uMI",A="tabItemActive_2DSg";var s=37,u=39;var c=function(e){var t=e.lazy,r=e.block,a=e.defaultValue,c=e.values,p=e.groupId,d=e.className,m=o(),k=m.tabGroupChoices,f=m.setTabGroupChoices,b=(0,n.useState)(a),h=b[0],v=b[1],S=n.Children.toArray(e.children),y=[];if(null!=p){var N=k[p];null!=N&&N!==h&&c.some((function(e){return e.value===N}))&&v(N)}var Z=function(e){var t=e.currentTarget,r=y.indexOf(t),n=c[r].value;v(n),null!=p&&(f(p,n),setTimeout((function(){var e,r,n,a,o,l,i,s;(e=t.getBoundingClientRect(),r=e.top,n=e.left,a=e.bottom,o=e.right,l=window,i=l.innerHeight,s=l.innerWidth,r>=0&&o<=s&&a<=i&&n>=0)||(t.scrollIntoView({block:"center",behavior:"smooth"}),t.classList.add(A),setTimeout((function(){return t.classList.remove(A)}),2e3))}),150))},R=function(e){var t,r;switch(e.keyCode){case u:var n=y.indexOf(e.target)+1;r=y[n]||y[0];break;case s:var a=y.indexOf(e.target)-1;r=y[a]||y[y.length-1]}null==(t=r)||t.focus()};return n.createElement("div",{className:"tabs-container"},n.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:(0,l.Z)("tabs",{"tabs--block":r},d)},c.map((function(e){var t=e.value,r=e.label;return n.createElement("li",{role:"tab",tabIndex:h===t?0:-1,"aria-selected":h===t,className:(0,l.Z)("tabs__item",i,{"tabs__item--active":h===t}),key:t,ref:function(e){return y.push(e)},onKeyDown:R,onFocus:Z,onClick:Z},r)}))),t?(0,n.cloneElement)(S.filter((function(e){return e.props.value===h}))[0],{className:"margin-vert--md"}):n.createElement("div",{className:"margin-vert--md"},S.map((function(e,t){return(0,n.cloneElement)(e,{key:t,hidden:e.props.value!==h})}))))}},2713:function(e,t,r){"use strict";var n=(0,r(7294).createContext)(void 0);t.Z=n},6261:function(e,t,r){"use strict";var n=r(7294),a=r(4184),o=r.n(a);t.Z=function(e){var t=e.children,r=e.classNames,a=e.fill,l=e.icon,i=e.type,A=null;switch(i){case"danger":A="alert-triangle";break;case"success":A="check-circle";break;case"warning":A="alert-triangle";break;default:A="info"}return n.createElement("div",{className:o()(r,"alert","alert--"+i,{"alert--fill":a,"alert--icon":!1!==l}),role:"alert"},!1!==l&&n.createElement("i",{className:o()("feather","icon-"+(l||A))}),t)}},9152:function(e,t,r){"use strict";r.r(t),r.d(t,{frontMatter:function(){return u},contentTitle:function(){return c},metadata:function(){return p},toc:function(){return d},default:function(){return k}});var n=r(7462),a=r(3366),o=r(7294),l=r(4137),i=(r(6261),r(7358)),A=r(8448),s=["components"],u={title:"Cluster",sidebar_label:"cluster",description:"Cluster",draft:!0},c=void 0,p={unversionedId:"components/cluster",id:"components/cluster",isDocsHomePage:!1,title:"Cluster",description:"Cluster",source:"@site/docs/components/cluster.md",sourceDirName:"components",slug:"/components/cluster",permalink:"/docs/components/cluster",editUrl:"https://github.com/apache/pinot/edit/master/website/docs/components/cluster.md",version:"current",frontMatter:{title:"Cluster",sidebar_label:"cluster",description:"Cluster",draft:!0},sidebar:"docs",previous:{title:"broker",permalink:"/docs/components/broker"},next:{title:"PQL",permalink:"/docs/components/controller"}},d=[{value:"Cluster components",id:"cluster-components",children:[{value:"Participant",id:"participant",children:[]},{value:"Spectator",id:"spectator",children:[]},{value:"Controller",id:"controller",children:[]}]},{value:"Logical view",id:"logical-view",children:[]},{value:"Setup a Pinot Cluster",id:"setup-a-pinot-cluster",children:[{value:"Using docker images",id:"using-docker-images",children:[]}]}],m={toc:d};function k(e){var t=e.components,u=(0,a.Z)(e,s);return(0,l.kt)("wrapper",(0,n.Z)({},m,u,{components:t,mdxType:"MDXLayout"}),(0,l.kt)("p",null,"Cluster is a set a nodes comprising of servers, brokers, controllers and minions."),(0,l.kt)("p",null,"Pinot leverages ",(0,l.kt)("a",{parentName:"p",href:"http://helix.apache.org"},"Apache Helix")," for cluster management. Helix is a cluster management framework to manage replicated, partitioned resources in a distributed system. Helix uses Zookeeper to store cluster state and metadata."),(0,l.kt)("p",null,(0,l.kt)("img",{alt:"Cluster Components",src:r(817).Z})),(0,l.kt)("h2",{id:"cluster-components"},"Cluster components"),(0,l.kt)("p",null,"Briefly, Helix divides nodes into three logical components based on their responsibilities"),(0,l.kt)("h3",{id:"participant"},"Participant"),(0,l.kt)("p",null,"The nodes that host distributed, partitioned resources"),(0,l.kt)("h3",{id:"spectator"},"Spectator"),(0,l.kt)("p",null,"The nodes that observe the current state of each Participant and use that information to access the resources. Spectators are notified of state changes in the cluster (state of a participant, or that of a partition in a participant)."),(0,l.kt)("h3",{id:"controller"},"Controller"),(0,l.kt)("p",null,"The node that observes and controls the Participant nodes. It is responsible for coordinating all transitions in the cluster and ensuring that state constraints are satisfied while maintaining cluster stability."),(0,l.kt)("ul",null,(0,l.kt)("li",{parentName:"ul"},"Pinot Servers are modeled as Participants, more details about server nodes can be found in ",(0,l.kt)("a",{parentName:"li",href:"../../docs/components/server"},"Server")),(0,l.kt)("li",{parentName:"ul"},"Pinot Brokers are modeled as Spectators, more details about broker nodes can be found in ",(0,l.kt)("a",{parentName:"li",href:"../../docs/components/broker"},"Broker")),(0,l.kt)("li",{parentName:"ul"},"Pinot Controllers are modeled as Controllers, more details about controller nodes can be found in ",(0,l.kt)("a",{parentName:"li",href:"../../docs/components/controller"},"Controller"))),(0,l.kt)("h2",{id:"logical-view"},"Logical view"),(0,l.kt)("p",null,"Another way to visualize the cluster is a logical view, wherein a cluster contains ",(0,l.kt)("a",{parentName:"p",href:"../../docs/components/segments"},"tenants"),", tenants contain ",(0,l.kt)("a",{parentName:"p",href:"../../docs/components/tables"},"tables"),", and tables contain ",(0,l.kt)("a",{parentName:"p",href:"../../docs/components/segments"},"segments"),"."),(0,l.kt)("p",null,(0,l.kt)("img",{alt:"Logical View",src:r(664).Z})),(0,l.kt)("h2",{id:"setup-a-pinot-cluster"},"Setup a Pinot Cluster"),(0,l.kt)("p",null,"Typically, there is only cluster per environment/data center. There is no needed to create multiple Pinot clusters since Pinot supports the concept of ",(0,l.kt)("a",{parentName:"p",href:"../../docs/components/tenants"},"tenants"),"."),(0,l.kt)("p",null,"At LinkedIn, the largest Pinot cluster consists of 1000+ nodes."),(0,l.kt)("p",null,"To setup a Pinot cluster, we need to first start Zookeeper:"),(0,l.kt)(i.Z,{className:"Install",defaultValue:"Using launcher scripts",values:[{label:(0,l.kt)(o.Fragment,null,(0,l.kt)("i",{className:"Using docker images"})," Using docker images"),value:"docker"},{label:(0,l.kt)(o.Fragment,null,(0,l.kt)("i",{className:"Using launcher scripts"})," Using launcher scripts"),value:"launcer"}],mdxType:"Tabs"},(0,l.kt)(A.Z,{value:"docker",mdxType:"TabItem"},(0,l.kt)("ol",null,(0,l.kt)("li",{parentName:"ol"},"Create a Network\nCreate an isolated bridge network in docker")),(0,l.kt)("pre",null,(0,l.kt)("code",{parentName:"pre",className:"language-bash"},"docker network create -d bridge pinot-demo\n")),(0,l.kt)("ol",{start:2},(0,l.kt)("li",{parentName:"ol"},"Start Zookeeper")),(0,l.kt)("p",null,"Start Zookeeper in daemon."),(0,l.kt)("pre",null,(0,l.kt)("code",{parentName:"pre",className:"language-bash"},"docker run \\\n --network=pinot-demo \\\n --name pinot-zookeeper \\\n --restart always \\\n -p 2181:2181 \\\n -d zookeeper:3.5.6\n")),(0,l.kt)("ol",{start:3},(0,l.kt)("li",{parentName:"ol"},"Start Zookeeper UI\nStart ZKUI to browse Zookeeper data at http://localhost:9090.")),(0,l.kt)("pre",null,(0,l.kt)("code",{parentName:"pre",className:"language-bash"},"docker run \\\n --network pinot-demo --name=zkui \\\n -p 9090:9090 \\\n -e ZK_SERVER=pinot-zookeeper:2181 \\\n -d qnib/plain-zkui:latest\n")),(0,l.kt)("ol",{start:4},(0,l.kt)("li",{parentName:"ol"}))),(0,l.kt)(A.Z,{value:"launcer",mdxType:"TabItem"},(0,l.kt)("p",null,"Download Pinot Distribution using instructions in Download"),(0,l.kt)("p",null,"Start Zookeeper"),(0,l.kt)("pre",null,(0,l.kt)("code",{parentName:"pre",className:"language-bash"},"bin/pinot-admin.sh StartZookeeper\n")),(0,l.kt)("ol",{start:2},(0,l.kt)("li",{parentName:"ol"},"Start Zooinspector")),(0,l.kt)("p",null,"Install ",(0,l.kt)("a",{parentName:"p",href:"https://github.com/jfim/zooinspector"},"zooinspector")," to view the data in Zookeeper, and connect to localhost:2181"))),(0,l.kt)("p",null,"Once we've started Zookeeper, we can start other components to join this cluster. If you're using docker, pull the latest ",(0,l.kt)("inlineCode",{parentName:"p"},"apachepinot/pinot")," image."),(0,l.kt)("h3",{id:"using-docker-images"},"Using docker images"),(0,l.kt)("h4",{id:"pull-pinot-docker-image"},"Pull pinot docker image"),(0,l.kt)("p",null,"(Optional) You can also follow the instructions here to build your own images.",(0,l.kt)("br",null)),(0,l.kt)("p",null,"You can try out pre-built Pinot all-in-one docker image."),(0,l.kt)("pre",null,(0,l.kt)("code",{parentName:"pre",className:"language-sql"},"export PINOT_VERSION=0.3.0-SNAPSHOT\nexport PINOT_IMAGE=apachepinot/pinot:${PINOT_VERSION}\ndocker pull ${PINOT_IMAGE}\n")),(0,l.kt)("p",null,"To start other components to join the cluster"),(0,l.kt)("ul",null,(0,l.kt)("li",{parentName:"ul"},"Start Controller"),(0,l.kt)("li",{parentName:"ul"},"Start Broker"),(0,l.kt)("li",{parentName:"ul"},"Start Server")),(0,l.kt)("p",null,"Explore your cluster via Pinot Data Explorer"))}k.isMDXComponent=!0},4184:function(e,t){var r;!function(){"use strict";var n={}.hasOwnProperty;function a(){for(var e=[],t=0;t<arguments.length;t++){var r=arguments[t];if(r){var o=typeof r;if("string"===o||"number"===o)e.push(r);else if(Array.isArray(r)){if(r.length){var l=a.apply(null,r);l&&e.push(l)}}else if("object"===o)if(r.toString===Object.prototype.toString)for(var i in r)n.call(r,i)&&r[i]&&e.push(i);else e.push(r.toString())}}return e.join(" ")}e.exports?(a.default=a,e.exports=a):void 0===(r=function(){return a}.apply(t,[]))||(e.exports=r)}()},6010:function(e,t,r){"use strict";function n(e){var t,r,a="";if("string"==typeof e||"number"==typeof e)a+=e;else if("object"==typeof e)if(Array.isArray(e))for(t=0;t<e.length;t++)e[t]&&(r=n(e[t]))&&(a&&(a+=" "),a+=r);else for(t in e)e[t]&&(a&&(a+=" "),a+=t);return a}function a(){for(var e,t,r=0,a="";r<arguments.length;)(e=arguments[r++])&&(t=n(e))&&(a&&(a+=" "),a+=t);return a}r.d(t,{Z:function(){return a}})},664:function(e,t,r){"use strict";t.Z=r.p+"assets/images/ClusterLogical-a82f8d136804e81aa069c9cb7f1f53ec.png"},817:function(e,t){"use strict";t.Z=""}}]);