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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

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

下面是安装nginx的信息:

1
2
3
4
5
6
7
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的信息:

1
2
3
4
5
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的信息:

1
2
3
4
5
6
7
8
9
10
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结构

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
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安装是

1
2
3
4
5
6
7
8
9
10
11
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删除是

1
2
3
4
5
6
7
8
9
10
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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
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、安装后测试

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
[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 
<?php
$link = mysql_connect( '10.10.240.20' , 'zabbix' , 'zabbix' );
if  ($link)
echo  "Successs!!!Php install success!\n" ;
else
echo  "Fail!!!Php install fail!\n" ;
mysql_close();
?>
[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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
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、删除后测试

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
[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目录里

wKioL1PMeluAMkeYAAHxwM1hkkM273.jpg








 本文转自 reinxu 51CTO博客,原文链接:http://blog.51cto.com/dl528888/1440775,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
11天前
|
消息中间件 运维 Kubernetes
构建高效自动化运维体系:Ansible与Kubernetes的融合实践
【5月更文挑战第9天】随着云计算和微服务架构的普及,自动化运维成为确保系统可靠性和效率的关键。本文将深入探讨如何通过Ansible和Kubernetes的集成,构建一个强大的自动化运维体系。我们将分析Ansible的配置管理功能以及Kubernetes容器编排的优势,并展示如何将二者结合,以实现持续部署、快速扩展和高效管理现代云原生应用。文章还将涵盖实际案例,帮助读者理解在真实环境下如何利用这些工具优化运维流程。
|
1天前
|
运维 监控 安全
构建高效自动化运维体系:Ansible与Docker的协同实战
【5月更文挑战第25天】 在当今快速迭代的软件发布环境中,自动化运维成为确保部署效率和可靠性的关键。本文通过深入分析Ansible和Docker技术,探索它们如何协同工作以构建一个高效的自动化运维体系。文章不仅介绍了Ansible的配置管理功能和Docker容器化的优势,还详细阐述了将两者结合的实践策略,旨在帮助读者理解并实现更智能、更灵活的基础设施管理。
|
2天前
|
运维 安全 Devops
构建高效自动化运维体系:Ansible与Docker的协同实践
【5月更文挑战第23天】 在现代IT基础设施管理中,自动化运维已成为推动效率和可靠性的关键因素。本文探讨了如何利用Ansible这一强大的自动化工具与容器化技术的代表Docker相结合,构建一个高效的自动化运维体系。通过分析两者的特点及互补性,我们展示了一种整合策略,该策略可帮助企业实现快速、一致且安全的部署和管理过程。
|
3天前
|
运维 监控 Docker
构建高效自动化运维体系:Ansible与Docker的完美结合
【5月更文挑战第23天】 在现代IT基础设施管理中,自动化运维已成为提升效率、确保一致性和降低人为错误的关键手段。本文深入探讨了如何通过结合Ansible和Docker技术,构建一个高效、可靠的自动化运维体系。文章首先概述了自动化运维的必要性,接着详细阐述了Ansible和Docker各自的核心优势,最后提供了一个实践案例来展示如何将两者融合以实现运维自动化的最佳实践。
|
5天前
|
运维 Linux 程序员
最全树莓派4B安装64位Linux(不用显示器键盘鼠标),Linux运维面试送分题
最全树莓派4B安装64位Linux(不用显示器键盘鼠标),Linux运维面试送分题
最全树莓派4B安装64位Linux(不用显示器键盘鼠标),Linux运维面试送分题
|
5天前
|
运维 网络协议 Linux
2024年最全CentOS8 Consul微服务架构安装(1)_agent(1),Linux运维开发面试
2024年最全CentOS8 Consul微服务架构安装(1)_agent(1),Linux运维开发面试
|
9天前
|
运维 Linux Docker
ChatGLM3在Docker环境部署,Linux运维免打包多渠道统计如何实现
ChatGLM3在Docker环境部署,Linux运维免打包多渠道统计如何实现
|
9天前
|
运维 Linux Docker
ChatGLM3在Docker环境部署(1),Linux运维电话面试技巧
ChatGLM3在Docker环境部署(1),Linux运维电话面试技巧
|
11天前
|
Web App开发 测试技术 Python
【如何学习python自动化测试】—— 浏览器驱动的安装 以及 如何更新driver
【如何学习python自动化测试】—— 浏览器驱动的安装 以及 如何更新driver
|
11天前
|
运维 安全 API
构建高效自动化运维体系:Ansible与Docker的协同实践
【5月更文挑战第13天】在现代IT基础设施管理中,自动化运维已成为提升效率、确保一致性和降低人为错误的关键。本文通过深入探讨Ansible和Docker的集成实践,揭示了如何构建一个灵活、可扩展且高效的自动化运维体系。我们将从理论到实践,展示如何利用这两种技术实现自动化部署、管理和扩展应用服务,以及它们如何帮助运维团队应对快速变化的业务需求和复杂的IT环境。
34 1