设为首页 收藏本站
查看: 1557|回复: 0

[经验分享] saltstack自动化运维系列11基于etcd的saltstack的自动化扩容

[复制链接]

尚未签到

发表于 2018-1-3 20:31:24 | 显示全部楼层 |阅读模式
  saltstack自动化运维系列11基于etcd的saltstack的自动化扩容
  自动化运维-基于etcd加saltstack的自动化扩容
  # tar -xf etcd-v2.2.1-linux-amd64.tar.gz
  # cd etcd-v2.2.1-linux-amd64
  # cp etcd etcdctl /usr/local/bin/
  查看版本
  # etcd --version
  # mkdir -p /data/etcd
  后台运行进程
  # nohup etcd --name auto_scale --data-dir /data/etcd/ --listen-peer-urls 'http://192.168.3.12:2380,http://192.168.3.12:7001' --listen-client-urls 'http://192.168.3.12:2379,http://192.168.3.12:4001' --advertise-client-urls 'http://192.168.3.12:2379,http://192.168.3.12:4001' &
  # ss -tnlp|grep etcd
  LISTEN     0      128            192.168.3.12:2379                     *:*      users:(("etcd",40909,6))
  LISTEN     0      128            192.168.3.12:2380                     *:*      users:(("etcd",40909,3))
  LISTEN     0      128            192.168.3.12:7001                     *:*      users:(("etcd",40909,5))
  LISTEN     0      128            192.168.3.12:4001                     *:*      users:(("etcd",40909,7))
  创建key和value
  # curl -s http://192.168.3.12:2379/v2/keys/message -XPUT -d value="hello world" | python -m json.tool
  {
  "action": "set",
  "node": {
  "createdIndex": 5,
  "key": "/message",
  "modifiedIndex": 5,
  "value": "hello world"
  }
  }
  查看key和value
  # curl -s http://192.168.3.12:2379/v2/keys/message | python -m json.tool
  {
  "action": "get",
  "node": {
  "createdIndex": 5,
  "key": "/message",
  "modifiedIndex": 5,
  "value": "hello world"
  }
  }
  删除key,可以看到查不到了
  # curl -s http://192.168.3.12:2379/v2/keys/message -XDELETE | python -m json.tool
  {
  "action": "delete",
  "node": {
  "createdIndex": 5,
  "key": "/message",
  "modifiedIndex": 6
  },
  "prevNode": {
  "createdIndex": 5,
  "key": "/message",
  "modifiedIndex": 5,
  "value": "hello world"
  }
  }
  # curl -s http://192.168.3.12:2379/v2/keys/message | python -m json.tool
  {
  "cause": "/message",
  "errorCode": 100,
  "index": 6,
  "message": "Key not found"
  }
  建一个只存在25秒的键值,25秒后发现该键值查不到了
  # curl -s http://192.168.3.12:2379/v2/keys/ttl_use -XPUT -d value='hello world 1' -d ttl=25 | python -m json.tool
  {
  "action": "set",
  "node": {
  "createdIndex": 9,
  "expiration": "2017-04-18T03:04:54.538607442Z",
  "key": "/ttl_use",
  "modifiedIndex": 9,
  "ttl": 25,
  "value": "hello world 1"
  }
  }
  # curl -s http://192.168.3.12:2379/v2/keys/ttl_use | python -m json.tool
  {
  "action": "get",
  "node": {
  "createdIndex": 9,
  "expiration": "2017-04-18T03:04:54.538607442Z",
  "key": "/ttl_use",
  "modifiedIndex": 9,
  "ttl": 24,
  "value": "hello world 1"
  }
  编辑etcd相关配置
  # vim /etc/salt/master
  etcd_pillar_config:
  etcd.host: 192.168.3.12
  etcd.port: 4001
  ext_pillar:
  - etcd: etcd_pillar_config root=/salt/haproxy/
  # /etc/init.d/salt-master restart
  curl -s http://192.168.3.12:2379/v2/keys/salt/haproxy/backend_www_chinasoft_com/web-node1 -XPUT -d value="192.168.3.12:8080" | python -m json.tool
  {
  "action": "set",
  "node": {
  "createdIndex": 11,
  "key": "/salt/haproxy/backend_www_chinasoft_com/web-node1",
  "modifiedIndex": 11,
  "value": "192.168.3.12:8080"
  }
  安装etcd
  # yum install -y python-pip
  # pip search python-etcd
  # pip install python-etcd
  ①编写haproxy的配置文件
  vim /srv/salt/prod/cluster/files/haproxy-outside.cfg
  balance roundrobin
  {% for web,web_ip in pillar.backend_www_chinasoft_com.iteritems() -%}
  server {{ web }} {{ web_ip}} check inter 2000 rise 30 fall 15
  {% endfor %}
DSC0000.png

  ②编写sls文件
  vim /srv/salt/prod/cluster/haproxy-outside.sls
  include:
  - haproxy.install
  haproxy-service:
  file.managed:
  - name: /etc/haproxy/haproxy.cfg
  - source: salt://cluster/files/haproxy-outside.cfg
  - user: root
  - group: root
  - mode: 644
  - template: jinja  # 添加了jinja这一行
  service.running:
  - name: haproxy
  - enable: True

  ->  - require:
  - cmd: haproxy-init
  - watch:
  - file: haproxy-service
DSC0001.png

  执行以下高级状态,如果报错jinja has no attibute backend_www_chinasoft_com重启一下master即可
  # salt '*' state.highstate
  此时向haproxy添加backend主机
  curl -s http://192.168.3.12:2379/v2/keys/salt/haproxy/backend_www_chinasoft_com/web-node2 -XPUT -d value="192.168.3.12:8080" | python -m json.tool
  curl -s http://192.168.3.12:2379/v2/keys/salt/haproxy/backend_www_chinasoft_com/web-node3 -XPUT -d value="192.168.3.12:8080" | python -m json.tool
  # curl -s http://192.168.3.12:2379/v2/keys/salt/haproxy/backend_www_chinasoft_com/web-node4 -XPUT -d value="192.168.3.12:8080" | python -m json.tool
  执行变更
  # salt '*' state.highstate
  通过访问haproxy的管理界面可以看到成功添加 http://192.168.3.12:8888/haproxy-status
DSC0002.png

  可以看到pillar的选项,如果不能看到需要修改/etc/salt/master (pillar_opts: False)
  # salt '*' pillar.items
  node2.chinasoft.com:
  ----------
  backend_www_chinasoft_com:
  ----------
  web-node1:
  192.168.3.12:8080
  web-node2:
  192.168.3.12:8080
  web-node3:
  192.168.3.12:8080
  web-node4:
  192.168.3.12:8080
  zabbix-agent:
  ----------
  Zabbix_Server:
  192.168.3.13
  mini1:
  ----------
  backend_www_chinasoft_com:
  ----------
  web-node1:
  192.168.3.12:8080
  web-node2:
  192.168.3.12:8080
  web-node3:
  192.168.3.12:8080
  web-node4:
  192.168.3.12:8080
  zabbix-agent:
  ----------
  Zabbix_Server:
  192.168.3.13
  编写脚本实现自动添加haproxy后端服务器
  # vim auto_add_haproxynode.sh
  

#!/bin/bash  

  
MAIN_ADD_HOST=$1
  
create_host(){
  
echo 'create host ok'
  
}
  

  
deploy_service(){
  
ADD_HOST_PORT='8080'
  
}
  

  
deploy_code(){
  
echo 'deploy code ok'
  
}
  

  
service_check(){
  
STATUS=$(curl -s --head http://"$ADD_HOST":"$ADD_HOST_PORT"/ |grep "200 OK")
  
if [ -n "$STATUS" ];then
  
echo 'status check ok'
  
else
  
echo 'status check not ok'
  
exit
  
fi
  
}
  

  
etcd_key(){
  
ADD_HOST=$1
  
curl http://192.168.3.12:2379/v2/keys/salt/haproxy/backend_www_chinasoft_com/$ADD_HOST -XPUT -d value="192.168.3.19:${ADD_HOST_PORT}"
  
}
  

  
sync_state(){
  
salt '*' state.sls cluster.haproxy-outside env=prod
  
}
  

  
main(){
  
create_host;
  
deploy_service;
  
deploy_code;
  
etcd_key $MAIN_ADD_HOST;
  
sync_state;
  
}
  

  
main $1
  

  执行脚本,可以看到成功添加
  # ./auto_add_haproxynode.sh web-node18

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-431309-1-1.html 上篇帖子: 使用Ansible部署etcd 3.2高可用集群 下篇帖子: CoreOS, Kubernetes, etcd
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表