平台云基石-CoreOS之集群篇(无需互联网)

    官方文档中关于集群的配置需要在cloud-config.yaml中配置discovery,而我的实验环境没有外网。

 

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. #cloud-config  
  2.   
  3. coreos:  
  4.   etcd:  
  5.     # generate a new token for each unique cluster from https://discovery.etcd.io/new  
  6.     discovery: https://discovery.etcd.io/<token>  
  7.     # multi-region and multi-cloud deployments need to use $public_ipv4  
  8.     addr: $private_ipv4:4001  
  9.     peer-addr: $private_ipv4:7001  
  10.   units:  
  11.     - name: etcd.service  
  12.       command: start  
  13.     - name: fleet.service  
  14.       command: start  

 

 

 解决方案1、搭建自己的Discovery Endpoint(我没解决)

https://github.com/coreos/discovery.etcd.io 下载本地部署。我部署访问显示不能生成token,放弃尝试,有兴趣的朋友可以尝试下,期待你的解决。

 

解决方案2、手工启动etcd(有问题)

登录coreos1

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. ssh core@192.168.1.104  

执行如下代码 

 

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. etcd -name="coreos1" -addr="192.168.1.104:4001" -peer-addr="192.168.1.104:7001"  -data-dir="/home/core/etcd"  

 

 

登录coreos2

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. ssh core@192.168.1.106  

 执行如下代码 

 

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. etcd -name="coreos2" -addr="192.168.1.105:4001" -peer-addr="192.168.1.105:7001" -peers="192.168.1.104:7001" -data-dir="/home/core/etcd"  

 

 

登录coreos3

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. ssh core@192.168.1.105  

 执行如下代码

 

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. etcd -name="coreos3" -addr="192.168.1.106:4001" -peer-addr="192.168.1.106:7001" -peers="192.168.1.104:7001,192.168.1.105:7001" -data-dir="/home/core/etcd"  

 

 

测试集群

新开窗口登录coreos1

 

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. ssh core@192.168.1.103  

 输入

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. fleetctl list-machines  

 得到

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. core@coreos1 ~ $ fleetctl list-machines  
  2. MACHINE         IP              METADATA  
  3. 79a6a4fe...     192.168.1.103   -  
  4. d049e2ca...     192.168.1.106   -  
  5. dcbf31c5...     192.168.1.105   -  

 

问题

1、etcd不能后台运行

按照上面的etcd命令执行,当关闭客户端的时候,etcd就关闭了,随之集群就没有了,尝试nohup无效。

 

解决方案3:使用cloud-config.yaml(用这个吧)

单个机器按照《平台云基石-CoreOS之离线安装篇(无需互联网)》,配置按照如下做修改。完美解决!此处要格外小心yaml文件的格式缩进、空格、tab等等,若失败多检查文件。

第一台机器

为主节点,配置如下

cloud-config-104.yaml

Yaml代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. #cloud-config  
  2.   
  3. hostname: coreos1  
  4.   
  5. coreos:    
  6.   etcd:      
  7.     addr: 192.168.1.104:4001  
  8.     peer-addr: 192.168.1.104:7001  
  9.   units:  
  10.     - name: etcd.service  
  11.       command: start  
  12.     - name: fleet.service  
  13.       command: start  
  14.     - name: static.network  
  15.       content: |  
  16.         [Match]  
  17.         Name=enp3s0  
  18.   
  19.         [Network]  
  20.         Address=192.168.1.104/24  
  21.         Gateway=192.168.1.254  
  22.         DNS=192.168.1.254     
  23. users:    
  24.   - name: core  
  25.     ssh-authorized-keys:   
  26.       - ssh-rsa #你的公钥  
  27.   
  28.   - groups:  
  29.       - sudo  
  30.       - docker  

 

 第二台机器

cloud-config-105.yaml

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. #cloud-config  
  2.   
  3. hostname: coreos2  
  4.   
  5. coreos:    
  6.   etcd:      
  7.     peers: 192.168.1.104:7001  
  8.     addr: 192.168.1.105:4001  
  9.     peer-addr: 192.168.1.105:7001  
  10.   units:  
  11.     - name: etcd.service  
  12.       command: start  
  13.     - name: fleet.service  
  14.       command: start  
  15.     - name: static.network  
  16.       content: |  
  17.         [Match]  
  18.         Name=enp3s0  
  19.   
  20.         [Network]  
  21.         Address=192.168.1.105/24  
  22.         Gateway=192.168.1.254  
  23.         DNS=192.168.1.254     
  24. users:    
  25.   - name: core  
  26.     ssh-authorized-keys:   
  27.       - ssh-rsa #你的公钥  
  28.   
  29.   - groups:  
  30.       - sudo  
  31.       - docker  

 

 第三台机器

 cloud-config-106.yaml

 

Yaml代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. #cloud-config  
  2.   
  3. hostname: coreos3  
  4.   
  5. coreos:    
  6.   etcd:      
  7.     peers: 192.168.1.104:7001  
  8.     addr: 192.168.1.106:4001  
  9.     peer-addr: 192.168.1.106:7001  
  10.   units:  
  11.     - name: etcd.service  
  12.       command: start  
  13.     - name: fleet.service  
  14.       command: start  
  15.     - name: static.network  
  16.       content: |  
  17.         [Match]  
  18.         Name=enp3s0  
  19.   
  20.         [Network]  
  21.         Address=192.168.1.106/24  
  22.         Gateway=192.168.1.254  
  23.         DNS=192.168.1.254     
  24. users:    
  25.   - name: core  
  26.     ssh-authorized-keys:   
  27.       - ssh-rsa  #你的公钥  
  28.   - groups:  
  29.       - sudo  
  30.       - docker  

 测试

Java代码  平台云基石-CoreOS之集群篇(无需互联网)
  1. fleetctl list-machines  

 

上一篇:Linux (x86) Exploit 开发系列教程之八 绕过 ASLR -- 第三部分


下一篇:互联网模式下的测试数据中心,小白也能高效构造数据