blob: 87afe28ca200620e19be4b9bdc8cbb3ae7c1ffb1 [file] [log] [blame]
/*! For license information please see 0b8045ed.252069de.js.LICENSE.txt */
(window.webpackJsonp=window.webpackJsonp||[]).push([[4],{113:function(e,t,n){"use strict";n.d(t,"a",(function(){return u})),n.d(t,"b",(function(){return d}));var r=n(0),a=n.n(r);function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function l(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function A(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?l(Object(n),!0).forEach((function(t){o(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):l(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function c(e,t){if(null==e)return{};var n,r,a=function(e,t){if(null==e)return{};var n,r,a={},o=Object.keys(e);for(r=0;r<o.length;r++)n=o[r],t.indexOf(n)>=0||(a[n]=e[n]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r<o.length;r++)n=o[r],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(a[n]=e[n])}return a}var i=a.a.createContext({}),s=function(e){var t=a.a.useContext(i),n=t;return e&&(n="function"==typeof e?e(t):A(A({},t),e)),n},u=function(e){var t=s(e.components);return a.a.createElement(i.Provider,{value:t},e.children)},p={inlineCode:"code",wrapper:function(e){var t=e.children;return a.a.createElement(a.a.Fragment,{},t)}},b=a.a.forwardRef((function(e,t){var n=e.components,r=e.mdxType,o=e.originalType,l=e.parentName,i=c(e,["components","mdxType","originalType","parentName"]),u=s(n),b=r,d=u["".concat(l,".").concat(b)]||u[b]||p[b]||o;return n?a.a.createElement(d,A(A({ref:t},i),{},{components:n})):a.a.createElement(d,A({ref:t},i))}));function d(e,t){var n=arguments,r=t&&t.mdxType;if("string"==typeof e||r){var o=n.length,l=new Array(o);l[0]=b;var A={};for(var c in t)hasOwnProperty.call(t,c)&&(A[c]=t[c]);A.originalType=e,A.mdxType="string"==typeof e?e:r,l[1]=A;for(var i=2;i<o;i++)l[i]=n[i];return a.a.createElement.apply(null,l)}return a.a.createElement.apply(null,n)}b.displayName="MDXCreateElement"},115:function(e,t,n){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)&&r.length){var l=a.apply(null,r);l&&e.push(l)}else if("object"===o)for(var A in r)n.call(r,A)&&r[A]&&e.push(A)}}return e.join(" ")}e.exports?(a.default=a,e.exports=a):void 0===(r=function(){return a}.apply(t,[]))||(e.exports=r)}()},119:function(e,t,n){"use strict";function r(e){var t,n,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]&&(n=r(e[t]))&&(a&&(a+=" "),a+=n);else for(t in e)e[t]&&(a&&(a+=" "),a+=t);return a}t.a=function(){for(var e,t,n=0,a="";n<arguments.length;)(e=arguments[n++])&&(t=r(e))&&(a&&(a+=" "),a+=t);return a}},121:function(e,t,n){"use strict";var r=n(0),a=n.n(r),o=n(115),l=n.n(o);n(49);t.a=function(e){var t=e.children,n=e.classNames,r=e.fill,o=e.icon,A=e.type,c=null;switch(A){case"danger":c="alert-triangle";break;case"success":c="check-circle";break;case"warning":c="alert-triangle";break;default:c="info"}return a.a.createElement("div",{className:l()(n,"alert","alert--"+A,{"alert--fill":r,"alert--icon":!1!==o}),role:"alert"},!1!==o&&a.a.createElement("i",{className:l()("feather","icon-"+(o||c))}),t)}},122:function(e,t,n){"use strict";var r=n(0),a=n(123);t.a=function(){var e=Object(r.useContext)(a.a);if(null==e)throw new Error("`useUserPreferencesContext` is used outside of `Layout` Component.");return e}},123:function(e,t,n){"use strict";var r=n(0),a=Object(r.createContext)(void 0);t.a=a},124:function(e,t,n){"use strict";var r=n(0),a=n.n(r),o=n(122),l=n(119),A=n(50),c=n.n(A),i=37,s=39;t.a=function(e){var t=e.block,n=e.children,A=e.defaultValue,u=e.values,p=e.groupId,b=Object(o.a)(),d=b.tabGroupChoices,m=b.setTabGroupChoices,j=Object(r.useState)(A),f=j[0],O=j[1],h=Object(r.useState)(!1),k=h[0],v=h[1];if(null!=p){var S=d[p];null!=S&&S!==f&&u.some((function(e){return e.value===S}))&&O(S)}var y=function(e){O(e),null!=p&&m(p,e)},N=[],R=function(e){e.metaKey||e.altKey||e.ctrlKey||v(!0)},U=function(){v(!1)};return Object(r.useEffect)((function(){window.addEventListener("keydown",R),window.addEventListener("mousedown",U)}),[]),a.a.createElement("div",null,a.a.createElement("ul",{role:"tablist","aria-orientation":"horizontal",className:Object(l.a)("tabs",{"tabs--block":t})},u.map((function(e){var t=e.value,n=e.label;return a.a.createElement("li",{role:"tab",tabIndex:0,"aria-selected":f===t,className:Object(l.a)("tabs__item",c.a.tabItem,{"tabs__item--active":f===t}),style:k?{}:{outline:"none"},key:t,ref:function(e){return N.push(e)},onKeyDown:function(e){!function(e,t,n){switch(n.keyCode){case s:!function(e,t){var n=e.indexOf(t)+1;e[n]?e[n].focus():e[0].focus()}(e,t);break;case i:!function(e,t){var n=e.indexOf(t)-1;e[n]?e[n].focus():e[e.length-1].focus()}(e,t)}}(N,e.target,e),R(e)},onFocus:function(){return y(t)},onClick:function(){y(t),v(!1)},onPointerDown:function(){return v(!1)}},n)}))),a.a.createElement("div",{role:"tabpanel",className:"margin-vert--md"},r.Children.toArray(n).filter((function(e){return e.props.value===f}))[0]))}},125:function(e,t,n){"use strict";var r=n(0),a=n.n(r);t.a=function(e){return a.a.createElement("div",null,e.children)}},169:function(e,t,n){"use strict";n.r(t),t.default=""},170:function(e,t,n){"use strict";n.r(t),t.default=n.p+"assets/images/ClusterLogical-a82f8d136804e81aa069c9cb7f1f53ec.png"},61:function(e,t,n){"use strict";n.r(t),n.d(t,"frontMatter",(function(){return s})),n.d(t,"metadata",(function(){return u})),n.d(t,"rightToc",(function(){return p})),n.d(t,"default",(function(){return d}));var r=n(2),a=n(6),o=n(0),l=n.n(o),A=n(113),c=(n(121),n(124)),i=n(125),s={title:"Cluster",sidebar_label:"cluster",description:"Cluster"},u={unversionedId:"components/cluster",id:"components/cluster",isDocsHomePage:!1,title:"Cluster",description:"Cluster",source:"@site/docs/components/cluster.md",slug:"/components/cluster",permalink:"/docs/components/cluster",editUrl:"https://github.com/apache/incubator-pinot/edit/master/website/docs/components/cluster.md",version:"current",sidebar_label:"cluster",sidebar:"docs",previous:{title:"Broker",permalink:"/docs/components/broker"},next:{title:"Pinot Query Language (PQL)",permalink:"/docs/components/controller"}},p=[{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:[]}]}],b={rightToc:p};function d(e){var t=e.components,o=Object(a.a)(e,["components"]);return Object(A.b)("wrapper",Object(r.a)({},b,o,{components:t,mdxType:"MDXLayout"}),Object(A.b)("p",null,"Cluster is a set a nodes comprising of servers, brokers, controllers and minions."),Object(A.b)("p",null,"Pinot leverages ",Object(A.b)("a",Object(r.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."),Object(A.b)("p",null,Object(A.b)("img",{alt:"Cluster Components",src:n(169).default})),Object(A.b)("h2",{id:"cluster-components"},"Cluster components"),Object(A.b)("p",null,"Briefly, Helix divides nodes into three logical components based on their responsibilities"),Object(A.b)("h3",{id:"participant"},"Participant"),Object(A.b)("p",null,"The nodes that host distributed, partitioned resources"),Object(A.b)("h3",{id:"spectator"},"Spectator"),Object(A.b)("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)."),Object(A.b)("h3",{id:"controller"},"Controller"),Object(A.b)("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."),Object(A.b)("ul",null,Object(A.b)("li",{parentName:"ul"},"Pinot Servers are modeled as Participants, more details about server nodes can be found in ",Object(A.b)("a",Object(r.a)({parentName:"li"},{href:"../../docs/components/server"}),"Server")),Object(A.b)("li",{parentName:"ul"},"Pinot Brokers are modeled as Spectators, more details about broker nodes can be found in ",Object(A.b)("a",Object(r.a)({parentName:"li"},{href:"../../docs/components/broker"}),"Broker")),Object(A.b)("li",{parentName:"ul"},"Pinot Controllers are modeled as Controllers, more details about controller nodes can be found in ",Object(A.b)("a",Object(r.a)({parentName:"li"},{href:"../../docs/components/controller"}),"Controller"))),Object(A.b)("h2",{id:"logical-view"},"Logical view"),Object(A.b)("p",null,"Another way to visualize the cluster is a logical view, wherein a cluster contains ",Object(A.b)("a",Object(r.a)({parentName:"p"},{href:"../../docs/components/segments"}),"tenants"),", tenants contain ",Object(A.b)("a",Object(r.a)({parentName:"p"},{href:"../../docs/components/tables"}),"tables"),", and tables contain ",Object(A.b)("a",Object(r.a)({parentName:"p"},{href:"../../docs/components/segments"}),"segments"),"."),Object(A.b)("p",null,Object(A.b)("img",{alt:"Logical View",src:n(170).default})),Object(A.b)("h2",{id:"setup-a-pinot-cluster"},"Setup a Pinot Cluster"),Object(A.b)("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 ",Object(A.b)("a",Object(r.a)({parentName:"p"},{href:"../../docs/components/tenants"}),"tenants"),"."),Object(A.b)("p",null,"At LinkedIn, the largest Pinot cluster consists of 1000+ nodes."),Object(A.b)("p",null,"To setup a Pinot cluster, we need to first start Zookeeper:"),Object(A.b)(c.a,{className:"Install",defaultValue:"Using launcher scripts",values:[{label:Object(A.b)(l.a.Fragment,null,Object(A.b)("i",{className:"Using docker images"})," Using docker images"),value:"docker"},{label:Object(A.b)(l.a.Fragment,null,Object(A.b)("i",{className:"Using launcher scripts"})," Using launcher scripts"),value:"launcer"}],mdxType:"Tabs"},Object(A.b)(i.a,{value:"docker",mdxType:"TabItem"},Object(A.b)("ol",null,Object(A.b)("li",{parentName:"ol"},"Create a Network\nCreate an isolated bridge network in docker")),Object(A.b)("pre",null,Object(A.b)("code",Object(r.a)({parentName:"pre"},{className:"language-bash"}),"docker network create -d bridge pinot-demo\n")),Object(A.b)("ol",{start:2},Object(A.b)("li",{parentName:"ol"},"Start Zookeeper")),Object(A.b)("p",null,"Start Zookeeper in daemon."),Object(A.b)("pre",null,Object(A.b)("code",Object(r.a)({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")),Object(A.b)("ol",{start:3},Object(A.b)("li",{parentName:"ol"},"Start Zookeeper UI\nStart ZKUI to browse Zookeeper data at http://localhost:9090.")),Object(A.b)("pre",null,Object(A.b)("code",Object(r.a)({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")),Object(A.b)("ol",{start:4},Object(A.b)("li",{parentName:"ol"}))),Object(A.b)(i.a,{value:"launcer",mdxType:"TabItem"},Object(A.b)("p",null,"Download Pinot Distribution using instructions in Download"),Object(A.b)("p",null,"Start Zookeeper"),Object(A.b)("pre",null,Object(A.b)("code",Object(r.a)({parentName:"pre"},{className:"language-bash"}),"bin/pinot-admin.sh StartZookeeper\n")),Object(A.b)("ol",{start:2},Object(A.b)("li",{parentName:"ol"},"Start Zooinspector")),Object(A.b)("p",null,"Install ",Object(A.b)("a",Object(r.a)({parentName:"p"},{href:"https://github.com/jfim/zooinspector"}),"zooinspector")," to view the data in Zookeeper, and connect to localhost:2181"))),Object(A.b)("p",null,"Once we've started Zookeeper, we can start other components to join this cluster. If you're using docker, pull the latest ",Object(A.b)("inlineCode",{parentName:"p"},"apachepinot/pinot")," image. "),Object(A.b)("h3",{id:"using-docker-images"},"Using docker images"),Object(A.b)("h4",{id:"pull-pinot-docker-image"},"Pull pinot docker image"),Object(A.b)("p",null,"(Optional) You can also follow the instructions here to build your own images.",Object(A.b)("br",null)),Object(A.b)("p",null,"You can try out pre-built Pinot all-in-one docker image."),Object(A.b)("pre",null,Object(A.b)("code",Object(r.a)({parentName:"pre"},{className:"language-sql"}),"export PINOT_VERSION=0.3.0-SNAPSHOT\nexport PINOT_IMAGE=apachepinot/pinot:${PINOT_VERSION}\ndocker pull ${PINOT_IMAGE}\n")),Object(A.b)("p",null,"To start other components to join the cluster"),Object(A.b)("ul",null,Object(A.b)("li",{parentName:"ul"},"Start Controller"),Object(A.b)("li",{parentName:"ul"},"Start Broker"),Object(A.b)("li",{parentName:"ul"},"Start Server")),Object(A.b)("p",null,"Explore your cluster via Pinot Data Explorer"))}d.isMDXComponent=!0}}]);