其实我也蛮着急去分享这个,但是饭得一口口吃不是,今天就来分享下,企业运维工作中如何使用ansible去编译安装一个nginx服务。
有时候我们会有这样一个需求,需要定制(自定义模块)的去编译安装一套nginx服务,但是集群数量比较大,时间就一天,如何搞定呢?
思路:先在一台机器上编译安装好nginx、打包,然后再用ansible去下发。
进入ansible配置文件目录
cd /etc/ansible
创建一个nginx_install的目录,方便管理:
mkdir nginx_install
创建对应的子目录:
cd nginx_install
mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}
说明: roles目录下有两个角色:
每个角色下面又有几个目录:
需要事先准备好安装用到的文件,具体如下:
在一台机器上事先编译安装好nginx,配置好启动脚本,配置好配置文件:
安装好后,我们需要把nginx目录打包,并放到
tar zcvf oknginx.tar.gz --exclude "nginx.conf" --exclude "vhost" nginx/
mv oknginx.tar.gz /etc/ansible/nginx_install/roles/install/files/
启动脚本、配置文件都要放到
cp nginx/conf/nginx.conf /etc/ansible/nginx_install/roles/install/templates/
cp /etc/init.d/nginx /etc/ansible/nginx_install/roles/install/templates/
定义common的tasks,如下是安装扩展nginx依赖包:
cd /etc/ansible/nginx_install/roles
vim ./common/tasks/main.yml //内容如下
- name: Install initializtion require software
yum: name={{ item }} state=installed
with_items:
- zlib-devel
- pcre-devel
定义变量:
vim /etc/ansible/nginx_install/roles/install/vars/main.yml //内容如下
nginx_user: www
nginx_port: 80
nginx_basedir: /usr/local/nginx
//左边是定义的名字,右边是值
首先要把所有用到的文档拷贝到目标机器
vim /etc/ansible/nginx_install/roles/install/tasks/copy.yml //内容如下
- name: Copy Nginx Software
copy: src=oknginx.tar.gz dest=/tmp/oknginx.tar.gz owner=root group=root
- name: Uncompression Nginx Software
shell: tar zxf /tmp/oknginx.tar.gz -C /usr/local/
- name: Copy Nginx Start Script
template: src=nginx dest=/etc/init.d/nginx owner=root group=root mode=0755
- name: Copy Nginx Config
template: src=nginx.conf dest={{ nginx_basedir }}/conf/ owner=root group=root mode=0644
vim /etc/ansible/nginx_install/roles/install/tasks/install.yml //内容如下
- name: Create Nginx User
user: name={{ nginx_user }} state=present createhome=no shell=/sbin/nologin
- name: Start Nginx Service
shell: /etc/init.d/nginx start
- name: Add Boot Start Nginx Service
shell: chkconfig --level 345 nginx on
- name: Delete Nginx compression files
shell: rm -rf /tmp/oknginx.tar.gz
// nginx_user 调用参数;state=present 表示存在。
vim /etc/ansible/nginx_install/roles/install/tasks/main.yml //内容如下
- include: copy.yml
- include: install.yml
到此两个roles:common和install就定义完成了。
接下来要定义一个入口配置文件:
vim /etc/ansible/nginx_install/install.yml //内容如下
---
- hosts: testhost
remote_user: root
gather_facts: True
roles:
- common
- install
执行:
ansible-playbook /etc/ansible/nginx_install/install.yml
最终执行效果如下:
之前客户端均编译安装了nginx,首先我需要删除。(线上环境一定要仔细考虑!!!)
[root@zhdy02 ~]# find / -name "nginx*" -exec rm -rf {} \;
客户端检测:
[[email protected] ~]# ps aux | grep nginx
root 7735 0.0 0.0 20352 576 ? Ss 18:09 0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
nobody 7738 0.0 0.3 22796 3148 ? S 18:09 0:00 nginx: worker process
root 7851 0.0 0.0 112668 968 pts/0 R+ 18:09 0:00 grep --color=auto nginx
[[email protected] ~]# date
2016年 11月 09日 星期四 18:11:32 CST