playbook安装nginxlinux
playbook实战-nginx安装1nginx
针对自定制的源码安装nginxweb
思路:先在一台机器上编译安装好nginx、打包,而后再用ansible去下发shell
cd /etc/ansible 进入ansible配置文件目录apache
mkdir nginx_install 建立一个nginx_install的目录,方便管理vim
cd nginx_installbash
mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}服务器
说明:roles目录下有两个角色,common为一些准备操做,install为安装nginx的操做。每一个角色下面又有几个目录,handlers下面是当发生改变时要执行的操做,一般用在配置文件发生改变,重启服务。files为安装时用到的一些文件,meta为说明信息,说明角色依赖等信息,tasks里面是核心的配置文件,templates一般存一些配置文件,启动脚本等模板文件,vars下为定义的变量ui
playbook实战-nginx安装2命令行
须要事先准备好安装用到的文件,具体以下:
在一台机器上事先编译安装好nginx,配置好启动脚本,配置好配置文件
安装好后,咱们须要把nginx目录打包,并放到/etc/ansible/nginx_install/roles/install/files/下面,名字为nginx.tar.gz
启动脚本、配置文件都要放到/etc/ansible/nginx_install/roles/install/templates下面
cd /etc/ansible/nginx_install/roles
定义common的tasks,nginx是须要一些依赖包的
vim ./common/tasks/main.yml //内容以下
- name: Install initializtion require software
yum: name={{ item }} state=installed
with_items:
- zlib-devel
- pcre-devel
playbook实战-nginx安装3
定义变量
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=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 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
playbook实战-nginx安装4
接下来会创建用户,启动服务,删除压缩包
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/nginx.tar.gz
playbook实战-nginx安装5
再建立main.yml而且把copy和install调用
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
实例:
1.
[root@axinlinux-01 ~]# cd /etc/ansible/
[root@axinlinux-01 ansible]# ls
ansible.cfg create_user.yml handlers.yml hosts roles test.yml when.yml while.retry while.yml
[root@axinlinux-01 ansible]# mkdir nginx_install
[root@axinlinux-01 ansible]# cd nginx_install/
[root@axinlinux-01 nginx_install]# mkdir -p roles/{common,install}/{handlers,files,mete,tasks,templates,vars} #在roles目录下建立了common和install目录,在这两个目录下又建立了后面的这些目录
[root@axinlinux-01 nginx_install]# ls
roles
[root@axinlinux-01 nginx_install]# ls roles/
common install
[root@axinlinux-01 nginx_install]# ls roles/install/
files handlers mete tasks templates vars
files是咱们要拷贝的一些文件。把要拷贝到其余机器上的文件放到这个目录下来
handlers是对应一些handlers放到这下面来
mete是说明信息,能够留空
tasks主要的核心任务是什么
templates模板。好比咱们安装nginx,针对不一样的服务器有的是4核的有的是8核的,针对4核的启动的子进程就是4,针对8核的子进程就是8。根据系统的不一样,提供不一样的变量在里面
vars是定义的一些变量
2.
[root@axinlinux-01 nginx_install]# cd /usr/local/ #咱们已经有nginx了,就不须要在源码安装了
[root@axinlinux-01 local]# tar czvf nginx.tar.gz --exclude "nginx.conf" --exclude "vhosts" nginx/
#将nginx目录打包,过滤出(--clude)nginx.conf和vhosts目录,暂时不打包这两个
[root@axinlinux-01 local]# mv nginx.tar.gz /etc/ansible/nginx_install/roles/install/files/ #将打包好的nginx放到files下
[root@axinlinux-01 local]# cp nginx/conf/nginx.conf /etc/ansible/nginx_install/roles/install/templates/ #将nginx.conf放到templates下
[root@axinlinux-01 local]# cp /etc/init.d/nginx /etc/ansible/nginx_install/roles/install/templates/ #将启动脚本放到templates下
vhosts暂时先不拷贝了,后面有专门搞配置的一章
[root@axinlinux-01 local]# cd /etc/ansible/nginx_install/roles/common/
[root@axinlinux-01 common]# vim tasks/main.yml #在这不像在playbook里直接写tasks一行,后面就直接跟模块名就能够了。可是在这,这种playbook是由目录组成的很大的一个小级别一个小级别的,他不是一个总体。要想将这个总体串联起来,就要建立对应的上面tasks、handlers等等这些目录,在这些目录下面呢,去建立main.yml这个文件,那么他会自动去找。那么这下面就是你要执行的一些东西了。在这里就是启动nginx时,所依赖的包和库等等
- name: Install initializtion require software
yum: name={{ item }} state=installed #模块yum,item就是变量下面的两个,而后就是安装
with_items:
- zlib-devel #须要安装的
- pcre-devel #须要安装的
- name: Install initializtion require software yum: name={{ item }} state=installed with_items: - zlib-devel - pcre-devel
注意:
以上这里,在最后执行的过程中(ansible-playbook),出现报错为yum安装的包有问题(多是yum循环的问题)。能够换一种方法,如下:
[root@axinlinux-01 common]# vim tasks/main.yml
- name: Install initializtion require software
yum: name="pcre-devel,zlib-devel" state=installed #不使用循环,直接安装这两个。使用逗号分隔
3.
[root@axinlinux-01 common]# vim /etc/ansible/nginx_install/roles/install/vars/main.yml
nginx_user: www #根据机器环境的不一样,咱们能够去定义它不一样的值。好比web1是www,web2是apache
nginx_port: 80 #还能够去定义port,由于有的是80,有的是8080
nginx_basedir: /usr/local/nginx
nginx_user: www nginx_port: 80 nginx_basedir: /usr/local/nginx
vim /etc/ansible/nginx_install/roles/install/tasks/copy.yml #至关于子配置文件(主配置文件是main.yml),将所需文档拷贝到目标机器
- name: Copy Nginx Software
copy: src=nginx.tar.gz dest=/tmp/nginx.tar.gz owner=root group=root #copy模块,拷贝nginx的tar包。不须要写绝对路径,由于能自动在files目录下找
- name: Uncompression Nginx Software
shell: tar zxf /tmp/nginx.tar.gz -C /usr/local/ #shell模块,用来解压
- 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 #拷贝配置文件
templates
- name: Copy Nginx Software 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 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
它是一个模块功能,与copy不一样的是他的文本文件采用了jinga2语法,注意:template只能在palybook中使用。
4.
vim /etc/ansible/nginx_install/roles/install/tasks/install.yml #这个其实是总的.yml
- name: Create Nginx User
user: name={{ nginx_user }} state=present createhome=no shell=/sbin/nologin #user模块。nginx_user变量,在第三步骤vars/main.yml定义的。也就是使用www用户。不须要建立用户家目录
- name: Start Nginx Service
shell: /etc/init.d/nginx start
- name: Add Boot Start Nginx Service
shell: chkconfig --level 345 nginx on #开启启动。第一次的话用chkconfig,不要用systemctl
- name: Delete Nginx compression files
shell: rm -rf /tmp/nginx.tar.gz
- 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/nginx.tar.gz
5.
[root@axinlinux-01 common]# vim /etc/ansible/nginx_install/roles/install/tasks/main.yml #调用这两个
- include: copy.yml
- include: install.yml
[root@axinlinux-01 common]# vim /etc/ansible/nginx_install/install.yml
---
- hosts: axinlinux-02 #使用一个机器来,能够写testhost(主机组)
remote_user: root
gather_facts: True
roles:
- common
- install
--- - hosts: testhost remote_user: root gather_facts: True roles: - common - install
[root@axinlinux-02 ~]# yum remove nginx #卸载以前yum的ngixn
[root@axinlinux-02 ~]# rm -f /etc/init.d/nginx
[root@axinlinux-01 common]# ansible-playbook /etc/ansible/nginx_install/install.yml
[root@axinlinux-02 ~]# ps aux |grep nginx #检查02机器,查看是否是咱们配置文件的nginx的进程
root 12454 0.0 0.0 45700 1132 ? Ss 21:14 0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
nobody 12455 0.0 0.2 48192 3772 ? S 21:14 0:00 nginx: worker process
nobody 12456 0.0 0.2 48192 4028 ? S 21:14 0:00 nginx: worker process
root 12651 0.0 0.0 112676 988 pts/0 S+ 21:15 0:00 grep --color=auto nginx
[root@axinlinux-02 ~]# cat /usr/local/nginx/conf/nginx.conf
总结:
咱们在最后执行ansible-playbook /etc/ansible/nginx_install/install.yml的时候,总的有一个.yml的文件吧,他是一个总入口的文件。那么他会指定那个机器去作接下来的操做。同时他也会定义一个roles,roles对应一些子目录(能够理解为子playbook脚本)。
roles里有common和install:
common里有tasks/main.yml,无论运行什么,他都会去tasks里找,去安装那两个依赖的包
install里也有tasks/main.yml,他链接copy.yml和install.yml,这两个.yml要在同一个目录下。