一 前期说明

l思路:先在一台机器上编译安装好nginx、打包,然后再用ansible去下发

lcd /etc/ansible   进入ansible配置文件目录

lmkdir  nginx_install   创建一个nginx_install的目录,方便管理

lcd nginx_install;

lmkdir -p roles/{

common,install}/{
handlers,files,meta,tasks,templates,vars}   

## 分别在common 和install 这两个目录下面建立这些目录

l说明:roles目录下有两个角色,common为一些准备操作,install为安装nginx的操作。每个角色下面又有几个目录,handlers下面是当发生改变时要执行的操作,通常用在配置文件发生改变,重启服务。files为安装时用到的一些文件,meta为说明信息,说明角色依赖等信息,tasks里面是核心的配置文件,templates通常存一些配置文件,启动脚本等模板文件,vars下为定义的变量

二 在已经安装好nginx服务器上面操作

l需要事先准备好安装用到的文件,具体如下:

l在一台机器上事先编译安装好nginx,配置好启动脚本,配置好配置文件

l安装好后,我们需要把nginx目录打包,并放到/etc/ansible/nginx_install/roles/install/files/下面,名字为nginx.tar.gz

cd /usr/local/目录下

ltar czvf nging.tar.gz nginx  打包

cp nginx.tar.gz /etc/ansible/nginx_install/roles/install/files/

l启动脚本、配置文件都要放到/etc/ansible/nginx_install/roles/install/templates下面

cp /etc/init.d/nginx /etc/ansible/nginx_install/roles/install/templates

cp /usr/local/nginx/conf/nginx.conf /etc/ansible/nginx_install/roles/install/templates

三 定义相关配置文件

lcd  /etc/ansible/nginx_install/roles

l定义commontasksnginx是需要一些依赖包的

[root@slave tasks]# cat main.yml - name: install initaliztion require software  yum: name=`item` state=installed  with_items:   - zlib-devel   - pcre-devel   - openssl-devel

l定义变量

[root@slave vars]# cat /etc/ansible/nginx_install/roles/install/vars/main.yml  nginx_user: www nginx_port: 80 nginx_basedir: /usr/local/nginx

首先要把所有用到的文档拷贝到目标机器 (复制文件)

cat /etc/ansible/nginx_install/roles /install/tasks/copy.yml- name: Copy NginxSoftware     copy: src=nginx.tar.gz dest=/tmp/nginx.tar.gz owner=root group=root- name: Uncompression Nginx Software  shell: tar zxf /tmp/nginx.tar.gz -C /usr/local/- name: Copy NginxStart Script  template: src=nginx dest=/etc/init.d/nginx owner=root group=root mode=0755- name: Copy NginxConfig  template: src=nginx.conf dest={
{ nginx_basedir }}/conf/ owner=root group=root mode=0644

接下来会建立用户,启动服务,删除压缩包  (安装启动服务)

cat   /etc/ansible/nginx_install/roles /install/tasks/install.yml- name: Create NginxUser  user: name={
{ nginx_user }} state=present createhome=no shell=/sbin/nologin- name: Start NginxService  service: name=nginx state=restarted- name: Add Boot Start NginxService  shell: chkconfig --level 345 nginx on- name: Delete Nginxcompression files  shell: rm -rf /tmp/nginx.tar.gz

再创建main.yml并且 copyinstall调用

cat  /etc/ansible/nginx_install/roles /install/tasks/main.yml- include: copy.yml- include: install.yml

最后定义总入口文件

[root@slave tasks]# cat /etc/ansible/nginx_install/install.yml ---- hosts: 192.168.216.131 (也可以写个组名)  remote_user: root  gather_facts: True  roles:    - common    - install

四 执行

执行: ansible-playbook /etc/ansible/nginx_install/install.yml

最后去客户端上面查看nginx服务是否正常启动