2024年8月20日(playbook nginx任务 mariadb)

一、剧本部署nginx
javascript 复制代码
[root@m0 ~]# mkdir /etc/ansible/playbook
[root@m0 ~]# vim /etc/ansible/playbook/nginx.yml 
---
-       hosts:          group02
        remote_user:    root
        tasks:
        -       name:   卸载httpd
                yum:    name=httpd      state=absent

        -       name:   安装nginx
                yum:    name=nginx      state=present

        -       name:   修改资源文件
                shell:  echo 'I am nginx,port is 80' > /usr/share/nginx/html/index.html

        -       name:   修改端口
                command:        sed -i '/listen/s/80/8080/g' /etc/nginx/nginx.conf
                notify:
                -       restart nginx
        -       name:   启动服务
                service:        name=nginx      state=started   enabled=yes
        handlers:
        -       name:   restart nginx
                service:        name=nginx      state=restarted    
二、roles(难点)

roles介绍

roles(角色):就是通过分别将variables,tasks及handlers等放置于单独的目录中,并可以便捷地调用它们的一种机制。

假设我们要写一个playbook来安装管理lamp环境,那么这个playbook就会写很长。所以我们希望把这个很大的文件分成多个功能拆分,分成apache管理,php管理,mysql管理,然后在需要使用的时候直接调用就可以了,以免重复写。就类似编程里的模块化的概念,以达到代码复用的效果。

1、创建roles的目录结构

files:用来存放由copy模块或script模块调用的文件。

tasks:至少有一个main.yml文件,定义各tasks。

handlers:有一个main.yml文件,定义各handlers。

templates:用来存放jinjia2模板。

vars:有一个main.yml文件,定义变量。

meta:有一个main.yml文件,定义此角色的特殊设定及其依赖关系。

注意:在每个角色的目录中分别创建files,tasks,handlers,templates,vars和meta目录,用不到的目录可以创建为空目录.

javascript 复制代码
[root@m0 ~]# cd /etc/ansible/roles/
[root@m0 roles]# mkdir nginx
[root@m0 roles]# cd nginx/
[root@m0 nginx]# ls
[root@m0 nginx]# mkdir files
[root@m0 nginx]# mkdir tasks
[root@m0 nginx]# mkdir handlers
[root@m0 nginx]# mkdir templates
[root@m0 nginx]# mkdir vars
[root@m0 nginx]# mkdir meta

[root@m0 nginx]# touch handlers/main.yml
[root@m0 nginx]# touch tasks/main.yml
[root@m0 nginx]# touch vars/main.yml
[root@m0 nginx]# tree
.
├── files
├── handlers
│   └── main.yml
├── meta
├── tasks
│   └── main.yml
├── templates
└── vars
    └── main.yml


[root@m0 nginx]# vim /etc/ansible/playbook/test001.yml
---
-       hosts:          s
        remote_user:    root
        roles:
                -       nginx

[root@m0 nginx]# ansible-playbook /etc/ansible/playbook/test001.yml 
[root@m0 nginx]# ansible s -m yum -a 'name=nginx state=absent'

[root@m0 nginx]# vim /etc/ansible/roles/nginx/tasks/main.yml 
---
-       name:   卸载httpd
        yum:    name=httpd      state=absent
-       name:   卸载nginx
        yum:    name=nginx      state=absent
-       name:   安装nginx
        yum:    name=nginx      state=present
-       name:   启动服务 
        service:        name=nginx      state=started   enabled=yes
...

[root@m0 nginx]# ansible-playbook /etc/ansible/playbook/test001.yml

[root@m0 nginx]# vim /etc/ansible/playbook/test001.yml
---
-       hosts:          s
        remote_user:    root
        roles:
                -       nginx
                -       mysql
...

[root@m0 nginx]# cp /etc/ansible/roles/nginx/ /etc/ansible/roles/mysql -r
[root@m0 nginx]# ansible-playbook /etc/ansible/playbook/test001.yml 
 
2、练习

使用role实现lnmp

nginx改配置 8080端口

mariadb中创建eleme数据库

创建表t_user

id int 编号 主键约束 自增 遍号

username varchar 非空约束 账号

password varchar 非空约束 密码

remark varchar 非空约束 账号权限说明
yum remove mariadb-libs-5.5.56-2.el7.x86_64

yum -y install mariadb

yum -y install mariadb-server

systemctl start mariadb.service

mysql

javascript 复制代码
[root@m0 ~]# mysql << EOF
> create database if not exists eleme charset utf8mb4;
> use eleme;
> create table user(id int primary key auto_increment,username varchar(45) not null,password varchar(45) not null,remark varchar(45));
> quit
> EOF
[root@m0 ~]# mysql
javascript 复制代码
[root@m0 ~]# vim /etc/ansible/roles/nginx/tasks/main.yml
---
-       name:   卸载mariadb
        yum:    name=mariadb,mariadb-server,mariadb-devel       state=absent

-       name:   安装mariadb
        yum:    name=mariadb,mariadb-server,mariadb-devel       state=present

-       name:   启动mariadb
        service:        name=mariadb    state=started   enabled=yes

-       name:   执行脚本,创建数据库和数据表
        script: /etc/ansible/script/dbtable.sh


[root@m0 ~]# cd /etc/ansible/roles/
[root@m0 roles]# mkdir mariadb
[root@m0 roles]# cd mariadb/
[root@m0 mariadb]# mkdir tasks
[root@m0 mariadb]# touch tasks/main.yml
[root@m0 mariadb]# vim /etc/ansible/playbook/test003.yml
---
-   hosts:          s
    remote_user:    root
    roles:
        -    mariadb


[root@m0 mariadb]# cd /etc/ansible/
[root@m0 ansible]# mkdir script
[root@m0 ansible]# vim /etc/ansible/script/dbtable.sh
#!/bin/bash
mysql << EOF
create database if not exists eleme charset utf8mb4;
use eleme;
create table user(id int primary key auto_increment,username varchar(45) not null,password varchar(45) not null,remark varchar(45));
quit
EOF


[root@m0 ansible]# ansible-playbook /etc/ansible/playbook/test003.yml
相关推荐
阿政一号4 分钟前
Linux进程间通信:【目的】【管道】【匿名管道】【命名管道】【System V 共享内存】
linux·运维·服务器·进程间通信
suimeng613 分钟前
基本元素定位(findElement方法)
java·selenium
方渐鸿14 分钟前
【2025】快速部署安装docker以及项目搭建所需要的基础环境(mysql、redis、nginx、nacos)
java·运维·docker·持续部署·dockercompse
程序员鱼皮15 分钟前
2025最新 Java 面经:美团后端面试真实复盘,附答案模板,速速收藏!
java·后端·面试
又过一个秋17 分钟前
【sylar-webserver】7 定时器模块
linux·c++
我要学编程(ಥ_ಥ)21 分钟前
初始JavaEE篇 —— Mybatis-plus 操作数据库
java·java-ee·mybatis·mybatis-plus
有来技术29 分钟前
从0到1手撸企业级权限系统:基于 youlai-boot(开源) + Java17 + Spring Boot 3 完整实战
java·spring boot·后端
小哈里30 分钟前
【运维】云计算的发展历程,云原生时代的运维理念&工具技术栈,高可用系统的云运维 —— 以K8S集群调度算法与命令为例
运维·云原生·kubernetes·云计算·架构设计
皮卡兔子屋35 分钟前
java虚拟机---JVM
java·jvm