码迷,mamicode.com
首页 > 其他好文 > 详细

第四章 consul cluster

时间:2016-04-10 21:10:33      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:

1、vagrant

为了模拟集群效果,使用vagrant

1.1、首先下载vagrant

https://www.vagrantup.com/downloads.html

说明:浏览器下载可能比较慢,可以通过迅雷下载。

1.2、下载之后,安装vagrant

mac中下一步到底就可以。

说明:虽然vagrant需要依赖于virtualbox,但是我们不需要事先安装,因为在安装vagrant的时候,会自动先安装virtualbox的。

1.3、打开终端,启动vagrant

1.3.1、初始化:

技术分享

说明:以上是安装64bit的Linux系统(Ubuntu),32bit的将数字改为32即可。

参考:https://liuzhichao.com/p/1940.html

1.3.2、修改Vagrantfile文件

技术分享

说明:ruby写的,内容改为如下:

技术分享
 1 # -*- mode: ruby -*-
 2 # vi: set ft=ruby :
 3 $script = <<SCRIPT
 4 echo Installing dependencies...
 5 sudo apt-get update
 6 sudo apt-get install -y unzip curl
 7 echo Fetching Consul...
 8 cd /tmp/
 9 wget https://releases.hashicorp.com/consul/0.6.1/consul_0.6.1_linux_amd64.zip -O consul.zip
10 echo Installing Consul...
11 unzip consul.zip
12 sudo chmod +x consul
13 sudo mv consul /usr/bin/consul
14 sudo mkdir /etc/consul.d
15 sudo chmod a+w /etc/consul.d
16 SCRIPT
17 
18 # Vagrantfile API/syntax version. Don‘t touch unless you know what you‘re doing!
19 VAGRANTFILE_API_VERSION = "2"
20 
21 Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
22   config.vm.box = "debian/wheezy64"
23 
24   config.vm.provision "shell", inline: $script
25 
26   config.vm.define "n1" do |n1|
27       n1.vm.hostname = "n1"
28       n1.vm.network "private_network", ip: "172.20.20.10"
29   end
30 
31   config.vm.define "n2" do |n2|
32       n2.vm.hostname = "n2"
33       n2.vm.network "private_network", ip: "172.20.20.11"
34   end
35 end
View Code

该文件内容是consul官方推荐的demo。这一块儿内容可以根据实际情况去修改。(我将节点的IP自己指定了一下,尽量不要与自己本机的IP一样,否则可能会影响一些功能),以下是我的配置。

技术分享
 1 # -*- mode: ruby -*-
 2 # vi: set ft=ruby :
 3 $script = <<SCRIPT
 4 echo Installing dependencies...
 5 sudo apt-get update
 6 sudo apt-get install -y unzip curl
 7 echo Fetching Consul...
 8 cd /tmp/
 9 wget https://releases.hashicorp.com/consul/0.6.1/consul_0.6.1_linux_amd64.zip -O consul.zip
10 echo Installing Consul...
11 unzip consul.zip
12 sudo chmod +x consul
13 sudo mv consul /usr/bin/consul
14 sudo mkdir /etc/consul.d
15 sudo chmod a+w /etc/consul.d
16 SCRIPT
17 
18 # Vagrantfile API/syntax version. Don‘t touch unless you know what you‘re doing!
19 VAGRANTFILE_API_VERSION = "2"
20 
21 Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
22   config.vm.box = "debian/wheezy64"
23 
24   config.vm.provision "shell", inline: $script
25 
26   config.vm.define "n110" do |n1|
27       n1.vm.hostname = "n110"
28       n1.vm.network "private_network", ip: "192.168.21.110"
29   end
30 
31   config.vm.define "n111" do |n2|
32       n2.vm.hostname = "n111"
33       n2.vm.network "private_network", ip: "192.168.21.111"
34   end
35 end
View Code

只是修改了节点位置,其实上边的script根本没让他去执行,可以去掉。

1.3.3、启动

技术分享

说明:当看到日志输出到

技术分享

就可以"ctrl+c"退出了(可能有时候需要"ctrl+c"两次),否则会将本机~/下的内容同步到n110这个节点,可能n110这个节点的空间会不够,导致后期工作无法进行。

这时候一个节点启动起来了,但是第二个没起来,需要再执行上边的操作一次。

最后,第三次执行启动命令。

技术分享

这样就好了。

 

之后针对n110和n111两个节点分别安装软件。

2、安装软件

进入/tmp/,下载consul软件。

技术分享

之后解压(前提是"unzip"命令已安装,如果没安装,执行技术分享

技术分享

解压之后出现一个二进制文件"consul",如下:

技术分享

之后将这个二进制文件移动或拷贝到/usr/bin下

技术分享

说明:以上步骤分别针对针对n110和n111两个节点执行一次。

 

3、n110以server模式启动服务

技术分享

 

4、n111以client模式启动服务

技术分享

 

5、join

分别启动以上两个服务后,发现其实n110和n111两个彼此谁都不知道谁(可以通过切换屏幕后,使用技术分享来验证),此时必须其中一个节点join到另一个节点,这时候才能彼此组成集群。

技术分享

说明:以上命令将n110节点加入到n111所在的集群(反过来去join也是没问题的),之后通过技术分享来看n110和n111时,彼此都是一个集群的两个member了。

注意:假设一个集群有2个节点(n1,n2),这时候有一个节点n3想加入集群,不需要join两遍,只需要join n1或n2就好。这样的话,集群之间通过gossip协议彼此沟通,n3就加入集群了。

 

6、节点离开集群

"ctrl+c"

 

补:以上的join是手工join的,还有一种节点加入集群后自动join到集群中去,查看:

https://www.consul.io/intro/getting-started/join.html

 

参考:

https://www.consul.io/intro/getting-started/join.html

http://www.jianshu.com/p/d483db36ec9a

https://liuzhichao.com/p/1940.html

第四章 consul cluster

标签:

原文地址:http://www.cnblogs.com/java-zhao/p/5375132.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!