{"id":1992,"date":"2014-08-21T23:43:08","date_gmt":"2014-08-21T16:43:08","guid":{"rendered":"https:\/\/engineerball.com\/?p=1992"},"modified":"2014-12-16T13:38:58","modified_gmt":"2014-12-16T06:38:58","slug":"how-to-install-redis-cluster","status":"publish","type":"post","link":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html","title":{"rendered":"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster"},"content":{"rendered":"<p>\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster<\/p>\n<p>\u0e15\u0e31\u0e27\u0e2d\u0e22\u0e48\u0e32\u0e07\u0e1c\u0e21\u0e08\u0e30\u0e17\u0e33\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e17\u0e35\u0e48\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e15\u0e31\u0e27\u0e40\u0e2d\u0e07 \u0e41\u0e15\u0e48 start \u0e04\u0e19\u0e25\u0e30 port \u0e40\u0e1e\u0e37\u0e48\u0e2d\u0e17\u0e33\u0e40\u0e1b\u0e47\u0e19 redis server \u0e2b\u0e25\u0e32\u0e22\u0e15\u0e31\u0e27\u0e04\u0e23\u0e31\u0e1a \u0e0b\u0e36\u0e48\u0e07 redis-cluster \u0e19\u0e35\u0e49\u0e08\u0e30\u0e17\u0e33\u0e44\u0e14\u0e49\u0e01\u0e47\u0e15\u0e48\u0e2d\u0e40\u0e21\u0e37\u0e48\u0e2d\u0e43\u0e0a\u0e49\u0e07\u0e32\u0e19 redis version 3.0 \u0e02\u0e36\u0e49\u0e19\u0e44\u0e1b\u0e19\u0e30\u0e04\u0e23\u0e31\u0e1a<br \/>\n\u0e02\u0e31\u0e49\u0e19\u0e15\u0e2d\u0e19\u0e41\u0e23\u0e01\u0e43\u0e2b\u0e49\u0e17\u0e33\u0e01\u0e32\u0e23 download \u0e41\u0e25\u0e30\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07\u0e01\u0e48\u0e2d\u0e19<\/p>\n<p>[shell]<br \/>\nwget <a href=\"https:\/\/github.com\/antirez\/redis\/archive\/3.0.0-beta8.tar.gz\">https:\/\/github.com\/antirez\/redis\/archive\/3.0.0-beta8.tar.gz<\/a><br \/>\ntar xzf 3.0.0-beta8.tar.gz &amp;&amp; cd redis-3.0.0-beta8\/<br \/>\nmake<br \/>\nmake install<br \/>\ncp src\/redis-trib.rb \/usr\/local\/bin\/[\/shell]<\/p>\n<p>\u0e17\u0e33\u0e01\u0e32\u0e23\u0e2a\u0e23\u0e49\u0e32\u0e07 config \u0e02\u0e2d\u0e07 redis-cluster<\/p>\n<pre class=\"lang:sh decode:true \">mkdir \/etc\/redis\/<\/pre>\n<p>\u0e17\u0e33\u0e01\u0e32\u0e23\u0e2a\u0e23\u0e49\u0e32\u0e07 redis-server \u0e21\u0e32\u0e08\u0e33\u0e19\u0e27\u0e19 3 port \u0e43\u0e2b\u0e49\u0e17\u0e33\u0e01\u0e32\u0e23\u0e2a\u0e23\u0e49\u0e32\u0e07\u0e44\u0e1f\u0e25\u0e4c config redis-server 3 \u0e44\u0e1f\u0e25\u0e4c \u0e42\u0e14\u0e22\u0e21\u0e35\u0e40\u0e19\u0e37\u0e49\u0e2d\u0e44\u0e1f\u0e25\u0e4c\u0e14\u0e31\u0e07\u0e19\u0e35\u0e49<\/p>\n<p>[shell]for i in {6379..6381}<br \/>\ndo<br \/>\n  mkdir \/etc\/redis\/redis-$i\/<br \/>\n  cat &gt;&gt; \/etc\/redis\/redis-$i\/redis.conf &lt;&lt;END<br \/>\n  port $i<br \/>\n  cluster-enabled yes<br \/>\n  cluster-config-file \/etc\/redis\/redis-$i\/nodes.conf<br \/>\n  cluster-node-timeout 5000<br \/>\n  appendonly yes<br \/>\n  END<br \/>\ndone<br \/>\n[\/shell]<\/p>\n<p>&nbsp;<\/p>\n<p>\u0e17\u0e33\u0e01\u0e32\u0e23 start redis-server \u0e17\u0e31\u0e31\u0e49\u0e07 3 \u0e15\u0e31\u0e27<\/p>\n<p>[shell]for i in {6379..6381}<br \/>\ndo<br \/>\nredis-server \/etc\/redis\/redis-$i\/redis.conf &amp;<br \/>\ndone[\/shell]<\/p>\n<p>&nbsp;<\/p>\n<p>\u0e17\u0e33\u0e01\u0e32\u0e23\u0e2a\u0e23\u0e49\u0e32\u0e07 cluster<\/p>\n<p>[shell]<br \/>\ngem install redis<br \/>\nredis-trib.rb create 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381<br \/>\n[\/shell]<\/p>\n<p>\u0e08\u0e30\u0e44\u0e14\u0e49 output \u0e14\u0e31\u0e07\u0e19\u0e35\u0e49<\/p>\n<p>[text]&gt;&gt;&gt; Creating cluster<br \/>\nConnecting to node 127.0.0.1:6379: OK<br \/>\nConnecting to node 127.0.0.1:6380: OK<br \/>\nConnecting to node 127.0.0.1:6381: OK<br \/>\n&gt;&gt;&gt; Performing hash slots allocation on 3 nodes&#8230;<br \/>\nUsing 3 masters:<br \/>\n127.0.0.1:6379<br \/>\n127.0.0.1:6380<br \/>\n127.0.0.1:6381<br \/>\nM: 4de3a5b52e8804a278a9670734b7c7e4221610dc 127.0.0.1:6379<br \/>\nslots:0-5460 (5461 slots) master<br \/>\nM: 746b17433de60274834e996dc162c7e38cb634be 127.0.0.1:6380<br \/>\nslots:5461-10922 (5462 slots) master<br \/>\nM: 488a3ec3e0bc78d6709cb9293803cbf1491dbb92 127.0.0.1:6381<br \/>\nslots:10923-16383 (5461 slots) master<br \/>\nCan I set the above configuration? (type &#8216;yes&#8217; to accept): yes<br \/>\n&gt;&gt;&gt;  Nodes configuration updated<br \/>\n&gt;&gt;&gt;  Assign a different config epoch to each node<br \/>\n4533:M 21 Aug 15:56:34.786 # configEpoch set to 1 via CLUSTER SET-CONFIG-EPOCH<br \/>\n4534:M 21 Aug 15:56:34.787 # configEpoch set to 2 via CLUSTER SET-CONFIG-EPOCH<br \/>\n4535:M 21 Aug 15:56:34.787 # configEpoch set to 3 via CLUSTER SET-CONFIG-EPOCH<br \/>\n&gt;&gt;&gt;  Sending CLUSTER MEET messages to join the cluster<br \/>\n4533:M 21 Aug 15:56:34.856 # IP address for this node updated to 127.0.0.1<br \/>\n4533:M 21 Aug 15:56:35.766 # Cluster state changed: ok<br \/>\nWaiting for the cluster to join.4534:M 21 Aug 15:56:35.867 # IP address for this node updated to 127.0.0.1<br \/>\n4535:M 21 Aug 15:56:35.967 # Cluster state changed: ok<br \/>\n.4534:M 21 Aug 15:56:37.789 # Cluster state changed: ok<\/p>\n<p>&gt;&gt;&gt;  Performing Cluster Check (using node 127.0.0.1:6379)<br \/>\nM: 4de3a5b52e8804a278a9670734b7c7e4221610dc 127.0.0.1:6379<br \/>\nslots:0-5460 (5461 slots) master<br \/>\nM: 746b17433de60274834e996dc162c7e38cb634be 127.0.0.1:6380<br \/>\nslots:5461-10922 (5462 slots) master<br \/>\nM: 488a3ec3e0bc78d6709cb9293803cbf1491dbb92 127.0.0.1:6381<br \/>\nslots:10923-16383 (5461 slots) master<br \/>\n[OK] All nodes agree about slots configuration.<br \/>\n&gt;&gt;&gt;  Check for open slots&#8230;<br \/>\n&gt;&gt;&gt;  Check slots coverage&#8230;<br \/>\n[OK] All 16384 slots covered.<br \/>\n[\/text]<\/p>\n<p>\u0e17\u0e33\u0e01\u0e32\u0e23\u0e2a\u0e23\u0e49\u0e32\u0e07 redis-cluster \u0e40\u0e2a\u0e23\u0e47\u0e08\u0e40\u0e23\u0e35\u0e22\u0e1a\u0e23\u0e49\u0e2d\u0e22 \u0e21\u0e32\u0e17\u0e14\u0e2a\u0e2d\u0e1a\u0e01\u0e31\u0e19<\/p>\n<p>[shell]redis-cli -p 6379<br \/>\n127.0.0.1:6379&gt; set foo bar<br \/>\n(error) MOVED 12182 127.0.0.1:6381<br \/>\n127.0.0.1:6379&gt;<br \/>\n[\/shell]<\/p>\n<p>\u0e08\u0e30\u0e40\u0e2b\u0e47\u0e19\u0e27\u0e48\u0e32\u0e40\u0e01\u0e34\u0e14\u0e01\u0e32\u0e23 Error \u0e43\u0e19\u0e01\u0e32\u0e23 move \u0e44\u0e1b\u0e22\u0e31\u0e07 cluster \u0e2d\u0e37\u0e48\u0e19<\/p>\n<p>\u0e40\u0e1e\u0e34\u0e48\u0e21 option -c \u0e40\u0e1e\u0e37\u0e48\u0e2d Enable Cluster mode<\/p>\n<p>[shell] redis-cli -p 6379 -c<br \/>\n127.0.0.1:6379&gt; set foo bar<br \/>\n&gt; Redirected to slot [12182] located at 127.0.0.1:6381<br \/>\nOK<br \/>\n127.0.0.1:6381&gt; get foo<br \/>\n&quot;bar&quot;<br \/>\n[\/shell]<\/p>\n<p>\u0e43\u0e0a\u0e49\u0e07\u0e32\u0e19\u0e44\u0e14\u0e49\u0e41\u0e25\u0e49\u0e27!!! \u0e04\u0e23\u0e32\u0e27\u0e19\u0e35\u0e49\u0e21\u0e32\u0e25\u0e2d\u0e07\u0e22\u0e31\u0e14 data \u0e43\u0e2a\u0e48\u0e01\u0e31\u0e19 \u0e1c\u0e21\u0e44\u0e14\u0e49\u0e19\u0e33 code \u0e15\u0e31\u0e27\u0e2d\u0e22\u0e48\u0e32\u0e07\u0e08\u0e32\u0e01\u0e19\u0e35\u0e49<\/p>\n<p>[shell] cd \/usr\/local\/src\/<br \/>\n git clone <a href=\"https:\/\/github.com\/antirez\/redis-rb-cluster\">https:\/\/github.com\/antirez\/redis-rb-cluster<\/a><br \/>\n cd redis-rb-cluster\/<br \/>\n[\/shell]<\/p>\n<p>&nbsp;<\/p>\n<p>\u0e41\u0e01\u0e49\u0e44\u0e1f\u0e25\u0e4c example.rb \u0e40\u0e1b\u0e47\u0e19<\/p>\n<p>[ruby]<br \/>\nrequire &#8216;.\/cluster&#8217;<\/p>\n<p>if ARGV.length != 2<br \/>\n    startup_nodes = [<br \/>\n        {:host =&gt; &quot;127.0.0.1&quot;, :port =&gt; 6379},<br \/>\n        {:host =&gt; &quot;127.0.0.1&quot;, :port =&gt; 6380},<br \/>\n        {:host =&gt; &quot;127.0.0.1&quot;, :port =&gt; 6381}<br \/>\n    ]<br \/>\nelse<br \/>\n    startup_nodes = [<br \/>\n        {:host =&gt; ARGV[0], :port =&gt; ARGV[1].to_i}<br \/>\n    ]<br \/>\nend<\/p>\n<p>rc = RedisCluster.new(startup_nodes,32,:timeout =&gt; 0.1)<\/p>\n<p>last = false<\/p>\n<p>while not last<br \/>\n    begin<br \/>\n        last = rc.get(&quot;__last__&quot;)<br \/>\n        last = 0 if !last<br \/>\n    rescue =&gt; e<br \/>\n        puts &quot;error #{e.to_s}&quot;<br \/>\n        sleep 1<br \/>\n    end<br \/>\nend<\/p>\n<p>((last.to_i+1)..1000000000).each{|x|<br \/>\n    begin<br \/>\n        rc.set(&quot;foo#{x}&quot;,x)<br \/>\n        puts rc.get(&quot;foo#{x}&quot;)<br \/>\n        rc.set(&quot;__last__&quot;,x)<br \/>\n    rescue =&gt; e<br \/>\n        puts &quot;error #{e.to_s}&quot;<br \/>\n    end<br \/>\n    sleep 0.1<br \/>\n}<br \/>\n[\/ruby]<\/p>\n<p>\u0e25\u0e2d\u0e07\u0e23\u0e31\u0e19<\/p>\n<p>[shell] ruby example.rb<br \/>\n1<br \/>\n2<br \/>\n3<br \/>\n4<br \/>\n5<br \/>\n6<br \/>\n7<br \/>\n8<br \/>\n9<br \/>\n10<br \/>\n11<br \/>\n12<br \/>\n13<br \/>\n14<br \/>\n15<br \/>\n16<br \/>\n17<br \/>\n18<br \/>\n19<br \/>\n20<br \/>\n21<br \/>\n22<br \/>\n23<br \/>\n24<br \/>\n25<br \/>\n26<br \/>\n27<br \/>\n28<br \/>\n29<br \/>\n30<br \/>\n31<br \/>\n32<br \/>\n33<br \/>\n^Cexample.rb:37:in `sleep&#8217;: Interrupt<br \/>\n        from example.rb:37:in `block in &lt;main&gt;&#8217;<br \/>\n        from example.rb:29:in `each&#8217;<br \/>\n        from example.rb:29:in `&lt;main&gt;&#8217;<\/p>\n<p>[\/shell]<\/p>\n<p>\u0e25\u0e2d\u0e07\u0e40\u0e02\u0e49\u0e32\u0e44\u0e1b get value<\/p>\n<p>[shell]<br \/>\n redis-cli -p 6379 -c<br \/>\n127.0.0.1:6379&gt; get foo10<br \/>\n&gt; Redirected to slot [11976] located at 127.0.0.1:6381<br \/>\n&quot;10&quot;<br \/>\n127.0.0.1:6381&gt; get foo15<br \/>\n&quot;15&quot;<br \/>\n127.0.0.1:6381&gt;<br \/>\n[\/shell]<\/p>\n<p>&nbsp;<\/p>\n<p>\u0e44\u0e14\u0e49 value \u0e08\u0e32\u0e01 node \u0e2d\u0e37\u0e48\u0e19\u0e46 \u0e17\u0e35\u0e48\u0e44\u0e14\u0e49\u0e08\u0e32\u0e01\u0e01\u0e32\u0e23 sharding \u0e16\u0e39\u0e01\u0e15\u0e49\u0e2d\u0e07<\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e15\u0e31\u0e27\u0e2d\u0e22\u0e48\u0e32\u0e07\u0e1c\u0e21\u0e08\u0e30\u0e17\u0e33\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e17\u0e35\u0e48\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e15\u0e31\u0e27\u0e40\u0e2d\u0e07 \u0e41\u0e15\u0e48 start \u0e04\u0e19\u0e25\u0e30 port \u0e40\u0e1e\u0e37\u0e48\u0e2d\u0e17\u0e33\u0e40\u0e1b\u0e47\u0e19 redis server \u0e2b\u0e25\u0e32\u0e22\u0e15\u0e31\u0e27\u0e04\u0e23\u0e31\u0e1a \u0e0b\u0e36\u0e48\u0e07 redis-cluster&#8230;<\/p>\n<div class=\"more-link-wrapper\"><a class=\"more-link\" href=\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\">Read the post<span class=\"screen-reader-text\">\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster<\/span><\/a><\/div>\n","protected":false},"author":1,"featured_media":2006,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","enabled":false}}},"categories":[5,11],"tags":[286,358,285,287,176],"jetpack_publicize_connections":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.4 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL<\/title>\n<meta name=\"description\" content=\"\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e41\u0e1a\u0e1a master-master (sharding) \u0e08\u0e33\u0e19\u0e27\u0e19 3 node \u0e0b\u0e36\u0e48\u0e07\u0e08\u0e30\u0e08\u0e33\u0e25\u0e2d\u0e07\u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e2d\u0e22\u0e39\u0e48\u0e1a\u0e19\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e40\u0e14\u0e35\u0e22\u0e27\u0e01\u0e31\u0e19 (\u0e04\u0e19\u0e25\u0e30 port)\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL\" \/>\n<meta property=\"og:url\" content=\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\" \/>\n<meta property=\"og:site_name\" content=\"EngineerBALL\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/engineerball\" \/>\n<meta property=\"article:author\" content=\"https:\/\/www.facebook.com\/troueblemaker.khunpech?ref=tn_tnmn\" \/>\n<meta property=\"article:published_time\" content=\"2014-08-21T16:43:08+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2014-12-16T06:38:58+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"635\" \/>\n\t<meta property=\"og:image:height\" content=\"200\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"ball\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@engineerball\" \/>\n<meta name=\"twitter:site\" content=\"@engineerball\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"ball\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\",\"url\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\",\"name\":\"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL\",\"isPartOf\":{\"@id\":\"https:\/\/engineerball.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage\"},\"image\":{\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage\"},\"thumbnailUrl\":\"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg\",\"datePublished\":\"2014-08-21T16:43:08+00:00\",\"dateModified\":\"2014-12-16T06:38:58+00:00\",\"author\":{\"@id\":\"https:\/\/engineerball.com\/blog\/#\/schema\/person\/415320d0da2d392375528001aa6ea53e\"},\"description\":\"\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e41\u0e1a\u0e1a master-master (sharding) \u0e08\u0e33\u0e19\u0e27\u0e19 3 node \u0e0b\u0e36\u0e48\u0e07\u0e08\u0e30\u0e08\u0e33\u0e25\u0e2d\u0e07\u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e2d\u0e22\u0e39\u0e48\u0e1a\u0e19\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e40\u0e14\u0e35\u0e22\u0e27\u0e01\u0e31\u0e19 (\u0e04\u0e19\u0e25\u0e30 port)\",\"breadcrumb\":{\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage\",\"url\":\"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg\",\"contentUrl\":\"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg\",\"width\":635,\"height\":200},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/engineerball.com\/blog\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/engineerball.com\/blog\/#website\",\"url\":\"https:\/\/engineerball.com\/blog\/\",\"name\":\"EngineerBALL\",\"description\":\"Damn Those Sweet Memories\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/engineerball.com\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/engineerball.com\/blog\/#\/schema\/person\/415320d0da2d392375528001aa6ea53e\",\"name\":\"ball\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/engineerball.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/d8d00c01f55942d7c8f2dbc70a9cefe0?s=96&d=monsterid&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/d8d00c01f55942d7c8f2dbc70a9cefe0?s=96&d=monsterid&r=g\",\"caption\":\"ball\"},\"description\":\"Teerapat Khunpech Live, Tech, Beers, Bike, Cafe Racer, Docker, Devops, Eco-System\",\"sameAs\":[\"https:\/\/engineerball.com\",\"https:\/\/www.facebook.com\/troueblemaker.khunpech?ref=tn_tnmn\",\"https:\/\/twitter.com\/engineerball\"],\"url\":\"https:\/\/engineerball.com\/blog\/author\/ball\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL","description":"\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e41\u0e1a\u0e1a master-master (sharding) \u0e08\u0e33\u0e19\u0e27\u0e19 3 node \u0e0b\u0e36\u0e48\u0e07\u0e08\u0e30\u0e08\u0e33\u0e25\u0e2d\u0e07\u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e2d\u0e22\u0e39\u0e48\u0e1a\u0e19\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e40\u0e14\u0e35\u0e22\u0e27\u0e01\u0e31\u0e19 (\u0e04\u0e19\u0e25\u0e30 port)","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html","og_locale":"en_US","og_type":"article","og_title":"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL","og_url":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html","og_site_name":"EngineerBALL","article_publisher":"https:\/\/www.facebook.com\/engineerball","article_author":"https:\/\/www.facebook.com\/troueblemaker.khunpech?ref=tn_tnmn","article_published_time":"2014-08-21T16:43:08+00:00","article_modified_time":"2014-12-16T06:38:58+00:00","og_image":[{"width":635,"height":200,"url":"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg","type":"image\/jpeg"}],"author":"ball","twitter_card":"summary_large_image","twitter_creator":"@engineerball","twitter_site":"@engineerball","twitter_misc":{"Written by":"ball","Est. reading time":"3 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html","url":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html","name":"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster - EngineerBALL","isPartOf":{"@id":"https:\/\/engineerball.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage"},"image":{"@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage"},"thumbnailUrl":"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg","datePublished":"2014-08-21T16:43:08+00:00","dateModified":"2014-12-16T06:38:58+00:00","author":{"@id":"https:\/\/engineerball.com\/blog\/#\/schema\/person\/415320d0da2d392375528001aa6ea53e"},"description":"\u0e01\u0e32\u0e23\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster \u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e41\u0e1a\u0e1a master-master (sharding) \u0e08\u0e33\u0e19\u0e27\u0e19 3 node \u0e0b\u0e36\u0e48\u0e07\u0e08\u0e30\u0e08\u0e33\u0e25\u0e2d\u0e07\u0e43\u0e2b\u0e49\u0e17\u0e33\u0e07\u0e32\u0e19\u0e2d\u0e22\u0e39\u0e48\u0e1a\u0e19\u0e40\u0e04\u0e23\u0e37\u0e48\u0e2d\u0e07\u0e40\u0e14\u0e35\u0e22\u0e27\u0e01\u0e31\u0e19 (\u0e04\u0e19\u0e25\u0e30 port)","breadcrumb":{"@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#primaryimage","url":"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg","contentUrl":"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg","width":635,"height":200},{"@type":"BreadcrumbList","@id":"https:\/\/engineerball.com\/blog\/2014\/08\/21\/how-to-install-redis-cluster.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/engineerball.com\/blog"},{"@type":"ListItem","position":2,"name":"\u0e15\u0e34\u0e14\u0e15\u0e31\u0e49\u0e07 redis-cluster"}]},{"@type":"WebSite","@id":"https:\/\/engineerball.com\/blog\/#website","url":"https:\/\/engineerball.com\/blog\/","name":"EngineerBALL","description":"Damn Those Sweet Memories","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/engineerball.com\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/engineerball.com\/blog\/#\/schema\/person\/415320d0da2d392375528001aa6ea53e","name":"ball","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/engineerball.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/d8d00c01f55942d7c8f2dbc70a9cefe0?s=96&d=monsterid&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/d8d00c01f55942d7c8f2dbc70a9cefe0?s=96&d=monsterid&r=g","caption":"ball"},"description":"Teerapat Khunpech Live, Tech, Beers, Bike, Cafe Racer, Docker, Devops, Eco-System","sameAs":["https:\/\/engineerball.com","https:\/\/www.facebook.com\/troueblemaker.khunpech?ref=tn_tnmn","https:\/\/twitter.com\/engineerball"],"url":"https:\/\/engineerball.com\/blog\/author\/ball"}]}},"jetpack_featured_media_url":"https:\/\/engineerball.com\/blog\/wp-content\/uploads\/2014\/08\/post-2013-10-01.jpg","jetpack_shortlink":"https:\/\/wp.me\/p3Nmbl-w8","jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"jetpack-related-posts":[],"_links":{"self":[{"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/posts\/1992"}],"collection":[{"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/comments?post=1992"}],"version-history":[{"count":0,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/posts\/1992\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/media\/2006"}],"wp:attachment":[{"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/media?parent=1992"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/categories?post=1992"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/engineerball.com\/blog\/wp-json\/wp\/v2\/tags?post=1992"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}