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

[经验分享] 基于ansible Role实现批量部署lamp平台

[复制链接]

尚未签到

发表于 2018-7-30 12:46:30 | 显示全部楼层 |阅读模式
1、配置好 Inventory 文件  
# /etc/ansible/hosts
  
[webhosts]
  
node2.example.com
  
node3.example.com
  

  
[mysql]
  
director1.example.com
  
director2.example.com
  

  
2、创建对应的目录树
  
# 执行 tree /root/lamp/roles 查看目录树
  
/root/lamp/roles
  
|-- common
  
|   |-- default
  
|   |-- files
  
|   |   `-- hosts
  
|   |-- handlers
  
|   |-- meta
  
|   |-- tasks
  
|   |   `-- main.yml
  
|   |-- templates
  
|   `-- vars
  
|-- db
  
|   |-- default
  
|   |-- files
  
|   |   `-- my.cnf
  
|   |-- handlers
  
|   |   `-- main.yml
  
|   |-- meta
  
|   |-- tasks
  
|   |   `-- main.yml
  
|   |-- templates
  
|   `-- vars
  
|-- db.yml
  
|-- php
  
|   |-- default
  
|   |-- files
  
|   |   `-- php.ini
  
|   |-- handlers
  
|   |-- meta
  
|   |-- tasks
  
|   |   `-- main.yml
  
|   |-- templates
  
|   `-- vars
  
|-- site.yml
  
|-- web
  
|   |-- default
  
|   |-- files
  
|   |   `-- httpd.conf
  
|   |-- handlers
  
|   |   `-- main.yml
  
|   |-- meta
  
|   |-- tasks
  
|   |   `-- main.yml
  
|   |-- templates
  
|   `-- vars
  
`-- web.yml
  

  

  

  
3、各个文件的内容
  
# 当前所在目录 /root/lamp/roles
  
# cat db.yml
  
- name: mysqld servise
  
  remote_user: root
  
  hosts: mysql
  
  roles:
  
    - common
  
    - db
  

  
# cat web.yml
  
- name: wed servise
  
  remote_user: root
  
  hosts: webhosts
  
  roles:
  
    - common
  
    - php
  
    - web
  

  
# cat common/files/hosts
  
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
  
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
  
172.16.10.22 node2.example.com
  
172.16.10.33 node3.example.com
  
172.16.0.50 director1.example.com
  
172.16.0.51 director2.example.com
  

  
# cat common/tasks/main.yml
  
- name: Configure hostname resolve
  
  copy: src=hosts dest=/etc/hosts
  

  
# cat php/tasks/main.yml
  
- name: install php
  
  yum: name=php state=present
  
- name: configuration php
  
  copy: src=php.ini dest=/etc/php.ini
  

  
# cat web/tasks/main.yml
  
- name: install httpd
  
  yum: name=httpd state=present
  
- name: configuration httpd
  
  copy: src=httpd.conf dest=/etc/httpd/conf/httpd.conf
  
  notify:
  
    - restart httpd
  
- name: service httpd start
  
  service: name=httpd enabled=no state=started
  

  
# cat web/handlers/main.yml
  
- name: restart httpd
  
  service: name=httpd state=restarted
  

  
# cat db/tasks/main.yml
  
- name: install mysql
  
  yum: name=mysql state=present
  
- name: install mysql-server
  
  yum: name=mysql-server state=present
  
- name: configuration mysqld
  
  copy: src=my.cnf dest=/etc/my.cnf
  
  notify:
  
    - restart mysqld
  
- name: service mysqld start
  
  service: name=mysqld enabled=no state=started
  

  
# cat db/handlers/main.yml
  
- name: restart mysqld
  
  service: name=mysqld state=restarted
  

  
4、开始批量部署
  
ansible-playbooks web.yml
  
ansible-playbooks db.yml

运维网声明 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-543600-1-1.html 上篇帖子: 使用ansible部署安装corosync+pacemaker 下篇帖子: Ansible 学习笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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