97.playbook安装nginx

24.27/24.28 playbook安装nginx

 

 

 

playbook安装nginx

 

playbook实战-nginx安装1

针对自定制的源码安装nginx

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

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

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

cd nginx_install

mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}

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

 

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 #需要安装的

注意:

以上这里,在最后执行的过程当中(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

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

它是一个模块功能,与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

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

[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要在同一个目录下。

 

 

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/u/3866149/blog/3054539

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值