1.缘起
因为公司没有运维人员,每次发布项目都需要手动编译,手工发布,特别浪费时间,发布几次以后就烦了,就想着全换成自动化方式打包发布,经过几个筛选终于选定用ansible来做自动化打包发布。从此节约大把的时间来听听歌看看书喝喝茶了。。。经过实践表面,在没有运维岗的时候,ansible绝对是中小创业公司项目发布的最佳选择!
2.介绍
ansible其实就是一个可以通过SSH与远程服务器进行连接交互的工具,它内置了很多模块可以让你轻松的通过 命令或者编写playbook剧本操作远程服务器,
3.安装与简单测试
- 安装ansible很简单,我的系统是centsos7.2,直接敲,
yum install ansible -y
即可 windows系统可以考虑安装个cygwin,来模拟进行linux操作,在cygwin的虚拟linux上安装ansible与远程服务器进行交互。 安装好以后ansible --version
进行查看 如下:[root ~]# ansible --version ansible 2.3.1.0 config file = /etc/ansible/ansible.cfg configured module search path = Default w/o overrides python version = 2.7.5 (default, Nov 6 2016, 00:28:07) [GCC 4.8.5 20150623 (Red Hat 4.8.5-11)]
- 安装好ansible以后,建议配置ssh免密码登录远程服务器,不会操作的可以自行百度
- ansible有个host配置,yum安装以后,在/etc/ansible/hosts里可以可以添加远程服务器主机的ip地址,或者一组ip服务器地址,例如我们的服务是分布式部署,有三台服务,配置如下
#[]里是服务器组的name,后续每行跟着的是服务器的ip地址[yrServer] 192.168.9.50192.168.9.51192.168.9.52
- 命令行测试
ansible yrServer -m ping
服务器返回[root ~]# ansible all -m ping 192.168.9.50 | SUCCESS => { "changed": false, "ping": "pong" } 192.168.9.51 | SUCCESS => { "changed": false, "ping": "pong" } 192.168.9.52 | SUCCESS => { "changed": false, "ping": "pong" }
表示三台服务器都已经ping通,其中参数里的changed的false代表,主机没有任何改动 ping后面pong标识已经ping通
ansible可以通过类似上面的命令行与主机进行交互,其实通过ansible进行远程主机操作,就是把ansible脚本转换层shell脚本与命令在远程主机上进行操作,但是自动化运维是一组命令跟脚本的组合,所以就需要学习一下ansible的杀手锏playbook了
4.Playbook
playbook是一组ansible命令的组合,我们可以称他为剧本,你完全可以理解成playbook就是拍戏的那个剧本,演员只要照着剧本演戏,就能完成拍戏任务,我们把我们想做的操作编排成剧本,ansible就可以编排有序的执行任务,并给与我们反馈。Playbooks 可用于声明配置,更强大的地方在于,在 playbooks 中可以编排有序的执行过程,甚至于做到在多组机器间,来回有序的执行特别指定的步骤.并且可以同步或异步的发起任务.
4.1 Playbook示例
playbook的格式是YAML,语法比较简单,
playbook 由一个或多个 ‘plays’ 组成.它的内容是一个以 ‘plays’ 为元素的列表. “plays” 算是一个体育方面的类比,你可以通过多个 plays 告诉你的系统做不同的事情,不仅是定义一种特定的状态或模型.你可以在不同时间运行不同的 plays. 这里有一个从github源码demo里找到的playbook示例,其中仅包含一个 play: 仔细看注视---#必须---开头- hosts: webservers#hosts里定义的组名或者直接服务器ip vars:#参数 http_port: 80 max_clients: 200 remote_user: root #执行的账户名 tasks:#执行的任务 - name: ensure apache is at the latest version#任务名称是安装最新版本的apache yum: pkg=httpd state=latest#执行的命令是ansible yum模块安装httpd - name: write the apache config file#任务名称是修改apache的config配置文件 template: src=/srv/httpd.j2 dest=/etc/httpd.conf #采用模版文件,从从src复制到dest,名字最终为httpd.conf notify:#事件通知,一有修改配置文件,就通知的名字为restart apache,会执行handlers相同名字的service进行执行重启 - restart apache - name: ensure apache is running #任务名称 service: name=httpd state=started #任务操作是:启动httpd handlers: - name: restart apache #任务名称 service: name=httpd state=restarted #任务操作是重启httpd服务
执行ansible playbook
ansible-playbook demo.yml
就可以查看结果