热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

运维自动化之ansibleplaybook安装lnmp环境

之前介绍了使用ansibleplaybok安装zabbix客户端、mysql服务端、nginx,现在介绍一下安装lnmp环境。下面是安装nginx的信息:nginx_user:ww

之前介绍了使用ansible playbok安装zabbix客户端、mysql服务端、nginx,现在介绍一下安装lnmp环境。

下面是安装nginx的信息:

nginx_user: www                        nginx用户
nginx_port: 80                         nginx监听端口
nginx_web_dir: /data/webroot/nginx     nginx的目录
nginx_version: 1.4.3                   nginx的版本
pcre_version: 8.33                     pcre的版本
pretended_name: Tengine                为了安全起见,把nginx名字改为tengine
pretended_version: 1.5.2               隐藏版本,换个tengine的版本

下面是安装php的信息:

php_user: www                            php fpm模式的启动用户
php_port: 9000                           php fpm使用tcp的端口
php_dir: /usr/local                      php的安装目录
php_version: 5.3.10                      php的版本
mysql_basedir: /data/mysql/basedir       mysql的目录

下面是安装mysql的信息:

mysql_basedir: /data/mysql/basedir                    源码目录
mysql_datadir: /data/mysql/datadir                    数据目录
mysql_user: mysql                                     mysql用户
mysql_database_user: root                             数据库用户
mysql_passwd: ‘E4yR3WnoluSFTCBAI‘                     数据库密码
mysql_port: 3306                                      mysql监听端口
mysql_sock: /data/mysql/datadir/mysql.sock            mysql的sock
mysql_charset: utf8                                   mysql字符集
mysql_collation: utf8_general_ci                      mysql排序方式
mysql_version: Percona-Server-5.5.21-rel25.1.tar.gz   mysql版本

备注:此playbook仅能对centos或者redhat的6.x版本进行安装。

下面是安装lnmp的playbook结构

09:28:50 # tree nginx* mysql* php*
nginx_delete
├── files
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── delete.yml
│   └── main.yml
├── templates
└── vars
    └── main.yml
nginx_install
├── files
│   └── nginx-1.4.3.tar.gz
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── copy.yml
│   ├── delete.yml
│   ├── install.yml
│   └── main.yml
├── templates
│   ├── index.html
│   ├── index.php
│   ├── install_nginx.sh
│   ├── nginx
│   ├── nginx.conf
│   └── vhost.conf
└── vars
    └── main.yml
mysql_delete
├── files
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── delete.yml
│   └── main.yml
├── templates
└── vars
    └── main.yml
mysql_install
├── files
│   └── mysql.tar.gz
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── copy.yml
│   ├── delete.yml
│   ├── install.yml
│   └── main.yml
├── templates
│   ├── install_mysql.sh
│   ├── my.cnf
│   ├── mysqld
│   └── mysql_security.sh
└── vars
    └── main.yml
php_delete
├── files
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── delete.yml
│   └── main.yml
├── templates
│   └── delete_php.sh
└── vars
    └── main.yml
php_install
├── files
│   └── php.tar.gz
├── handlers
├── meta
│   └── main.yml
├── tasks
│   ├── copy.yml
│   ├── delete.yml
│   ├── install.yml
│   └── main.yml
├── templates
│   ├── install_php.sh
│   ├── php-fpm
│   └── php-fpm.conf
└── vars
    └── main.yml

36 directories, 47 files

playbook的lnmp安装是

09:29:59 # cat lnmp_install.yml 
---
- hosts: "{{host}}"
  remote_user: "{{user}}"
  gather_facts: True
  roles:
    - common
    - pcre_install
    - nginx_install
    - mysql_install
    - php_install

playbook的lnmp删除是

09:30:33 # cat lnmp_delete.yml 
---
- hosts: "{{host}}"
  remote_user: "{{user}}"
  gather_facts: True
  roles:
    - pcre_delete
    - php_delete
    - nginx_delete
    - mysql_delete

1、安装lnmp

09:35:55 #  time ansible-playbook lnmp_install.yml --extra-vars "host=192.168.240.13 user=root" --private-key=/root/test.pem 

PLAY [192.168.240.13] ********************************************************* 

GATHERING FACTS *************************************************************** 
ok: [192.168.240.13]

TASK: [common | Install initializtion require software] *********************** 
changed: [192.168.240.13]

TASK: [pcre_install | Copy Pcre Software To Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [pcre_install | Uncompression Pcre Software In Redhat Client] *********** 
changed: [192.168.240.13]

TASK: [pcre_install | Delete Pcre Software In Redhat Client] ****************** 
changed: [192.168.240.13]

TASK: [nginx_install | Copy Nginx Software To Redhat Client] ****************** 
changed: [192.168.240.13]

TASK: [nginx_install | Uncompression Nginx Software To Redhat Client] ********* 
changed: [192.168.240.13]

TASK: [nginx_install | Copy Nginx Start Script To Redhat Client] ************** 
changed: [192.168.240.13]

TASK: [nginx_install | Copy Nginx Config To Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [nginx_install | Copy Nginx Vhost Config to RedHat Client] ************** 
changed: [192.168.240.13]

TASK: [nginx_install | Create Nginx User In Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [nginx_install | Create Nginx  Dir] ************************************* 
changed: [192.168.240.13] => (item=vhost)
changed: [192.168.240.13] => (item=logs)

TASK: [nginx_install | Modify Nginx Dir Permission In Redhat Client] ********** 
changed: [192.168.240.13] => (item=/data/webroot/nginx)
changed: [192.168.240.13] => (item=/usr/local/nginx-1.4.3)

TASK: [nginx_install | Create Index Html To Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [nginx_install | Install Check Script In Redhat Client] ***************** 
changed: [192.168.240.13]

TASK: [nginx_install | Start Nginx Service In Redhat Client] ****************** 
changed: [192.168.240.13]

TASK: [nginx_install | Add Boot Start Nginx Service In Redhat Client] ********* 
changed: [192.168.240.13]

TASK: [nginx_install | Delete Nginx compression Software In Redhat Client] **** 
changed: [192.168.240.13]

TASK: [mysql_install | Copy Mysql Software To Redhat Client] ****************** 
changed: [192.168.240.13]

TASK: [mysql_install | Create Mysql User In Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [mysql_install | Copy Mysql Start Script To Redhat Client] ************** 
changed: [192.168.240.13]

TASK: [mysql_install | Copy Install Mysql Script  To Redhat Client] *********** 
changed: [192.168.240.13]

TASK: [mysql_install | Copy Mysql Config To Redhat Client] ******************** 
changed: [192.168.240.13]

TASK: [mysql_install | Copy Mysql Security Script To Redhat Client] *********** 
changed: [192.168.240.13]

TASK: [mysql_install | Create Mysql Install Dir] ****************************** 
ok: [192.168.240.13]

TASK: [mysql_install | Uncompression Mysql Software To Redhat Client] ********* 
changed: [192.168.240.13]

TASK: [mysql_install | Modify Mysql Dir Permission In Redhat Client] ********** 
ok: [192.168.240.13] => (item=/data/mysql/datadir)
ok: [192.168.240.13] => (item=/data/mysql/basedir)

TASK: [mysql_install | Install Mysql Script In Redhat Client] ***************** 
changed: [192.168.240.13]

TASK: [mysql_install | Start Myql Security Script In Redhat Client] *********** 
changed: [192.168.240.13]

TASK: [mysql_install | Add Boot Start Mysql Service In Redhat Client] ********* 
changed: [192.168.240.13]

TASK: [mysql_install | Delete Mysql compression Software In Redhat Client] **** 
changed: [192.168.240.13]

TASK: [php_install | Copy Php Software To Redhat Client] ********************** 
changed: [192.168.240.13]

TASK: [php_install | Uncompression Php Software To Redhat Client] ************* 
changed: [192.168.240.13]

TASK: [php_install | Copy Php Start Script To Redhat Client] ****************** 
changed: [192.168.240.13]

TASK: [php_install | Copy Php Config To Redhat Client] ************************ 
changed: [192.168.240.13]

TASK: [php_install | Copy Php Install Script To Redhat Client] **************** 
changed: [192.168.240.13]

TASK: [php_install | Create Php User In Redhat Client] ************************ 
ok: [192.168.240.13]

TASK: [php_install | Install Php Script In Redhat Client] ********************* 
changed: [192.168.240.13]

TASK: [php_install | Start Php Service In Redhat Client] ********************** 
changed: [192.168.240.13]

TASK: [php_install | Add Boot Start Php Service In Redhat Client] ************* 
changed: [192.168.240.13]

TASK: [php_install | Delete Php compression Software In Redhat Client] ******** 
changed: [192.168.240.13]

PLAY RECAP ******************************************************************** 
192.168.240.13             : ok=41   changed=37   unreachable=0    failed=0   


real	2m16.803s
user	0m14.753s
sys	0m1.468s

可以看到2分16秒就安装成功,一般比较费时的是使用yum安装软件与从本地负责包到客户端,所以yum源最后使用自己做的yum源或者找个速度快的yum源。

2、安装后测试

[root@ip-10-10-240-20 tmp]# ps -ef|grep nginx|wc -l
10
[root@ip-10-10-240-20 tmp]# ps -ef|grep mysql|wc -l
3
[root@ip-10-10-240-20 tmp]# ps -ef|grep php|wc -l
130
[root@ip-10-10-240-20 tmp]# cd /data/webroot/nginx/
logs/  vhost/ 
[root@ip-10-10-240-20 tmp]# cd /data/webroot/nginx/vhost/
[root@ip-10-10-240-20 vhost]# cat index.html 
Nginx 1.4.3 in 10.10.240.20  is success!
[root@ip-10-10-240-20 vhost]# cat index.php 

[root@ip-10-10-240-20 vhost]# curl 10.10.240.20/index.html
Nginx 1.4.3 in 10.10.240.20  is success!
[root@ip-10-10-240-20 vhost]# curl 10.10.240.20/index.php
Successs!!!Php install success!
[root@ip-10-10-240-20 vhost]# curl -I 10.10.240.20/index.php
HTTP/1.1 200 OK
Server: Tengine/1.5.2
Date: Mon, 21 Jul 2014 02:12:24 GMT
Content-Type: text/html
Connection: keep-alive
Vary: Accept-Encoding

3、删除lnmp

09:38:36 #  time ansible-playbook lnmp_delete.yml --extra-vars "host=192.168.240.13 user=root" --private-key=/root/test.pem 

PLAY [192.168.240.13] ********************************************************* 

GATHERING FACTS *************************************************************** 
ok: [192.168.240.13]

TASK: [pcre_delete | Delete Pcre] ********************************************* 
changed: [192.168.240.13]

TASK: [php_delete | Copy Delete Php Script To RedHat Client] ****************** 
changed: [192.168.240.13]

TASK: [php_delete | Run Delete Php Script In RedHat Client] ******************* 
changed: [192.168.240.13]

TASK: [php_delete | Delete Php User In Redhat Client] ************************* 
failed: [192.168.240.13] => {"failed": true, "item": "", "name": "www", "rc": 8}
msg: userdel: user www is currently logged in

...ignoring

TASK: [php_delete | Delete Php Script] **************************************** 
changed: [192.168.240.13]

TASK: [nginx_delete | stop nginx service] ************************************* 
changed: [192.168.240.13]

TASK: [nginx_delete | Delete Nginx Boot Start Script] ************************* 
changed: [192.168.240.13]

TASK: [nginx_delete | Delete Nginx Dir] *************************************** 
changed: [192.168.240.13]

TASK: [nginx_delete | Delete Nginx User] ************************************** 
changed: [192.168.240.13]

TASK: [nginx_delete | Delete Nginx Service Start Script] ********************** 
changed: [192.168.240.13]

TASK: [mysql_delete | Stop Mysql Service] ************************************* 
changed: [192.168.240.13]

TASK: [mysql_delete | Delete Mysql Boot Start Script] ************************* 
changed: [192.168.240.13]

TASK: [mysql_delete | Delete Mysql Dir And Socket] **************************** 
changed: [192.168.240.13]

TASK: [mysql_delete | Delete Mysql User] ************************************** 
changed: [192.168.240.13]

TASK: [mysql_delete | Delete Mysql Service Start Script] ********************** 
changed: [192.168.240.13]

PLAY RECAP ******************************************************************** 
192.168.240.13             : ok=16   changed=14   unreachable=0    failed=0   


real	0m31.511s
user	0m1.470s
sys	0m0.232s

4、删除后测试

[root@ip-10-10-240-20 vhost]# ll /usr/local/
total 40
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 bin
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 etc
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 games
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 include
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 lib64
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 libexec
drwxr-xr-x. 2 root   root   4096 Sep 23  2011 sbin
drwxr-xr-x. 5 root   root   4096 May 12  2013 share
drwxr-xr-x. 3 root   root   4096 May 12  2013 src
drwxr-xr-x  5 zabbix zabbix 4096 Jul  8 02:17 zabbix
[root@ip-10-10-240-20 vhost]# ps -ef|grep php
root     10016  3527  0 22:13 pts/0    00:00:00 grep php
[root@ip-10-10-240-20 vhost]# ps -ef|grep mysql
root     10018  3527  0 22:13 pts/0    00:00:00 grep mysql
[root@ip-10-10-240-20 vhost]# ps -ef|grep nginx
root     10020  3527  0 22:13 pts/0    00:00:00 grep nginx
[root@ip-10-10-240-20 vhost]# id www
id: www: No such user
[root@ip-10-10-240-20 vhost]# id mysql
id: mysql: No such user

可与看到都删除了。

如果大家想使用我的例子,可以从github里下载(地址是https://github.com/dl528888/ansible-examples/tree/master/lnmp_install),然后放到/etc/ansible目录里

,

本文出自 “吟—技术交流” 博客,请务必保留此出处http://dl528888.blog.51cto.com/2382721/1440775

运维自动化之ansible playbook安装lnmp环境


推荐阅读
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了一种解析GRE报文长度的方法,通过分析GRE报文头中的标志位来计算报文长度。具体实现步骤包括获取GRE报文头指针、提取标志位、计算报文长度等。该方法可以帮助用户准确地获取GRE报文的长度信息。 ... [详细]
author-avatar
Sure张硕
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有