关键词:
ansible 用于批量管理远程服务器,下面记录使用ansible远程部署nginx服务的过程。
实验环境:
ansible主机:centos6.6 192.168.38.152 已经源码编译安装好了nginx服务,安装过程参考这里
远程服务器:centos6.6 192.168.38.155 (hosts name: web155.com)用于部署nginx
实验过程:
思路: 先在152机器上编译安装nginx,打包,然后再用ansible下发给其他服务器
cd /etc/ansible 进入ansible配置文件目录
2. mkdir nginx_install 创建一个nginx_install的目录,方便管理
3. cd nginx_install
4. mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}
说明:在/etc/ansible/nginx_install 目录下创建一个roles 目录,在roles 目录下有两个角色,common为一些准备操作,install为安装nginx的操作。每个角色下面又有几个目录。handlers下面是当文件发生改变时要执行的操作,通常是在配置文件发生改变时,需要重启服务。files里面是核心的配置文件,templates通常存一些配置文件,启动脚本等模板文件,vars下为定义的变量。
5. 安装nginx 服务需要先安装一下依赖包:
cd /etc/ansible/nginx_install/roles
在common目录的task里定义main.yml脚本,安装依赖包,
vim ./common/tasks/main.yml //内容如下:
- name: install initializtion require software yum: name={{ item }} state=installed with_items: - zlib-devel - pcre-devel - openssl-devel
6. 将之前源码编译安装在/usr/local/nginx 目录的nginx打包:
cd /usr/local/
tar zcvf nginx.tar.gz nginx/
7. 在 /etc/ansible/nginx_install/roles/install 将安装nginx程序的文件都准备好
cd /etc/ansible/nginx_install/roles/install
cp /usr/local/nginx.tar.gz files/ #打包好的nginx
cp /usr/local/nginx/conf/nginx.conf templates/ #nginx的配置文件
cp /etc/init.d/nginx templates/ #nginx的启动脚本,之前安装的时时候需要自己写
、
8. 然后,需要在 install/vars 目录里写一个main.yml 脚本,记录一些变量:
vim /etc/ansible/nginx_install/roles/install/vars/main.yml
nginx_user: www #nginx的用户,根据nginx.conf文件定义,因为在新的机器上可能没有nginx用户
nginx_basedir: /usr/local/nginx #nginx的安装路径
9. 然后,写/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
这个copy.yml 文件就是执行了,将本地ansible服务器打包了的nginx包,复制到远程。copy模块的默认目录路径就是files 。所以,需要将打包的nginx.tar.gz 复制到files 目录。
copy.yml 复制完nginx.tar.gz包后,就要解包,拷贝启动文件,然后再拷贝配置文件。
10. 定义好copy.yml 文件后,需要定义一个安装脚本:
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 service: name=nginx state=started - name: Add Boot Start Nginx Service shell: chkconfig --level 345 nginx on - name: Delete Nginx compression files shell: rm -rf /tmp/nginx.tar.gz
执行install.yml脚本安装nginx的时候,首先,创建nginx的用户nginx_user,变量在vars目录定义了。
然后,将nginx添加到service服务,并且启动。
然后,将3 4 5 级别的启动都开了。
最后,将安装包删除。
11. 现在已经定义了两个最主要的 .yml 脚本了,但是还是不能实现远程安装nginx。现在还需要在roles/install/tasks/目录下,写一个main.yml 的入口文件,统一管理copy.yml 和install.yml 文件。
vim /etc/ansible/nginx_install/roles/install/tasks/main.yml //内容如下:
- include: copy.yml - include: install.yml
将copy和install两个文件都include进来。
现在,roles下的两个角色common和install都已经准备好了
但是,要实现nginx的ansible-playbook,还需一个总的入口文件。
vim /etc/ansible/nginx__install/install.yml //内容如下:
--- - hosts: web155.com remote_user: root gather_facts: True roles: - common - install
可以看到这个install.yml 文件的结构,hosts就是远程的主机组名,最重要的就是要定义roles模块,当执行ansible-playbook时,就会在roles里找到common和install,然后,在common和install这两个角色里,又分别找到它们的main.yml 入口文件。根据main.yml文件就能找到copy.yml和install.yml文件了。
执行ansible-playbook /etc/ansible/nginx_install/install.yml
然后在另一台机器192.168.38.155的测试机上:
ps aux|grep nginx #检查nginx 服务是否已经正常启动,如果是,则已经正常安装了
以上就是利用ansible远程部署nginx的具体思路了。
我做实验的机器上面,/etc/ansible/nginx_install/ 目录的结构:
[[email protected] nginx_install]# pwd /etc/ansible/nginx_install [[email protected] nginx_install]# tree . ├── install.yml └── roles ├── common │ ├── files │ ├── handlers │ ├── meta │ ├── tasks │ │ └── main.yml │ ├── templates │ └── vars ├── delete │ ├── files │ ├── handlers │ ├── meta │ ├── tasks │ ├── templates │ └── vars └── install ├── files │ ├── nginx-1.6.2.tar.gz │ └── nginx.tar.gz ├── handlers ├── meta ├── tasks │ ├── copy.yml │ ├── install.yml │ └── main.yml ├── templates │ ├── nginx │ └── nginx.conf └── vars └── main.yml
本文出自 “dayAndNight” 博客,请务必保留此出处http://hellocjq.blog.51cto.com/11336969/1894597
ansible-playbook自动化安装keepalived实现nginx服务双机热备自动化配置
脚本实现通过ansible-playbook自动化安装Keepalived和配置,主要解决问题如下:Keepalived自动化安装;keepalived_vrid配置,自动根据vip获取最后一段作为vrid,确保同一网段不会出现vrid冲突导致HA切换失败的问题;自动配置Keepalived;HA检... 查看详情
ansible-playbook实例
准备前提配置ansible主机详情:https://www.cnblogs.com/security-guard/ nginx的安装编写nginx的自动部署文件nginx.yml hosts主机更改为自己定义的 访问目标主机组的IP地址,查看测试页面测试页面:显... 查看详情
ansible-playbook拾遗
ansible-playbook 和handles一起使用---- hosts: webuser: roottasks:- name: ensure nginx is at the latest versionyum: name=nginx sta 查看详情
ansible-playbook
简单例子1:vars定义变量-hosts:allremote_user:rootvars:-package:nginx-service:nginx tasks:-name:installnginxpackage yum:name=packagestate=latest-name:installconfigurationfileforhttpd copy:src=/etc/nginx/nginx.confdest=/etc/nginx/nginx.conf notify: -restartn... 查看详情
ansible-playbook批量添加zabbix监控项目同步配置信息
前言 在上一篇教程中我们已经实现了使用ansible-playbook批量在远程主机上部署zabbix客户端并正常运行,现在我们再次通过ansible-playbook给客户端主机批量增加zabbix监控项目配置(创建监控项目示例:自动发现远程主机监听的TCP... 查看详情
ansible-playbook调试
转载于互联网检测远程主机信息 ansible-i/XXXXX.hostsdev107-msetup 1.ansible-playbook 1)ansible-playbook的语法检测1[root@test-1bin]#ansible-playbook--syntax-checknginx_tags.yaml23playbook:n 查看详情
ansible-playbook批量部署安装tomcat
tomcat安装脚本:---- name: Tomcat install and configuration hosts: "{{ host }}" user: root vars: & 查看详情
ansible的playbook进行yum批量安装nginx最新版本
环境:centos7版本:nginx最新版本软件: ansible 作用:进行批量执行不同机器上,进行安装nginx版本 检查脚本是否正确:[[email protected]ansible-yaml]#ansible-playbook --syntax-check nginx.yml 进行执行:[[em 查看详情
ansible-playbook安装xinted
1、先展示下角色结构:[root@admin1roles]#treentpd/ntpd/├──files│??└──ntp-4.2.8p14.tar.gz├──handlers├──tasks│??└──main.yml├──templates└──vars5directories,2files2、task任务(1)main.yml[root@admin1tasks]#catmain.ymlinc 查看详情
ansible-playbook安装xinted
1、先展示下角色结构:[root@admin1roles]#treentpd/ntpd/├──files│??└──ntp-4.2.8p14.tar.gz├──handlers├──tasks│??└──main.yml├──templates└──vars5directories,2files2、task任务(1)main.yml[root@admin1tasks]#catmain.ymlinc 查看详情
ansible-playbook批量搭建lamp(代码片段)
先在ansible服务器安装LAMP环境,然后再将配置文件通过ansible拷贝到远程主机1.安装httpd软件yum-yinstallhttpd2.安装mysqlyum-yinstallmariadb-servermysqlsystemctlstartmairadb3.安装php和php-mysql模块yum-yinstallphpphp-mysql4.提供php测试页vim/var/www/html/index.php&... 查看详情
ansible-playbook
playbook: 通过事先编写好的playbook文件实现批量管理操作 ===============ansible的任务集注意:1.yml中不可使用tabs键2.缩进对齐,严格控制缩进3.#表注释4.---开头 playbook文件 :是ansible主机用于配置,部署和管理托管主机... 查看详情
ansible-playbook安装tomcat1.8
ansible安装tomcat一个很low的写法,后面再更新高级的写法注:下面with_items显示不正常,具体请看图片~---- hosts: all remote_user: root tasks: - name: "复制jdk文件到目标服务器" &nbs 查看详情
ansible-playbook之循环(loops)
ansible-playbook的循环(Loops)1.标准的Loops:也是最常用的一种循环例:当需要安装10个软件包时,不用写10次任务,只需要写一次然后进行循环即可#注:已经安装的软件系统即不在安装[[email protected] playbook]# cat yum_list.y... 查看详情
安装zabbix-server之ansible-playbook
ZABBIX_VER=5.0URL="https://mirror.tuna.tsinghua.edu.cn/zabbix"FONT=msyhbd.ttcMYSQL_HOST=localhost#MYSQL_HOST=10.0.0.100MYSQL_ZABBIX_USER="zabbix@localhost"#MYSQL_ZABBIX_USER="zabbix@10.0.0.%"MYSQL_ZAB 查看详情
ansible-playbook安装keepalived-指定tags安装master或backup
在实际工作中,新项目上线往往都需要搭建HA,此时我们可以通过ansible的playbook来秒级搭建好一个HA环境,从而解放双手;此playbook适用于centos6、centos7的keepalived搭建,但是请注意var/main.yml中变量的修改,修改为你自己想的设定的... 查看详情
ansible-playbook循环安装软件包(with_items)
[[email protected]~]#vim/etc/ansible/ansible.cfg##定义分组文件路径[defaults]#somebasicdefaultvalues...inventory=/etc/ansible/hosts##分组文件路径:wq[[email protected]~]#vim/etc/ansible/hosts##定义分组##db-[99: 查看详情
ansible-playbook批量安装zabbix_agent(代码片段)
zabbix_agent_install.yml----hosts:本地测试服务器remote_user:roottasks:-name:Installpackagesyum:name=itemstate=presentwith_items:-gcc-c++-curl-curl-devel-net-snmp-net-snmp-devel-mysql-devel-name:copyfilec 查看详情