云计算day28

一、ansible模块
script模块
root@localhost \~# vim test000.sh

#!/bin/bash
mkdir /tmp/three
touch /tmp/three/test
echo 'i am echo,at mttt' > /tmp/three/test
echo 'well done'
root@localhost \~# source test000.sh
well done
root@localhost \~# ansible group02 -m script -a './test000.sh'

copy模块
root@localhost \~# ansible s -m copy -a 'src=./mysql_master.sh dest=~'

使用command模块下载 nfs-utils rpcbind
root@localhost \~# ansible s -m command -a 'yum -y install nfs-utils'
root@localhost \~# ansible s -m command -a 'yum -y install rpcbind'

root@localhost \~# vim /etc/exports

/static *(ro,sync)
在被控制的主机上添加static目录,并创建test文件
root@localhost \~# ansible s -m file -a 'path=/static state=directory'

root@localhost \~# ansible s -m file -a 'path=/static/test state=touch

root@localhost \~# ansible s -m copy -a 'src=/etc/exports dest=/etc/exports'

command模块
root@localhost \~# ansible s -m command -a 'systemctl start nfs'

root@localhost \~# ansible s -m command -a 'systemctl enable nfs'

service模块
root@localhost \~# ansible s -m service -a 'name=rpcbind state=started enabled=yes'
root@localhost \~# yum -y install nfs-utils
root@localhost \~# mkdir /nfs
root@localhost \~# mount -t nfs 192.168.8.157:/static /nfs/
root@localhost \~# ls /nfs/
test

二、playbook
playbook(剧本):是ansible用于配置,部署,和管理被控节点的剧本。用于ansible操作的编排。

一般使用ymal格式

playbook 剧本是保存在控制机的yml文件

YMAL格式
■ 以.yaml或xyml结尾

■ 文件的第一行以" --- "开始,表明YMAL文件的开始(可选的)

■ 以#号开头为注释

■ 列表中的所有成员都开始于相同的缩进级别,并且使用一个"-"作为开头(一个横杠和一个空格)

■ 一个字典是由一个简单的 键:值 的形式组成(这个冒号后面必须是一个空格)

■ 注意:写这种文件可以使用tab键和空格

Playbook常⻅语法

hosts: ⽤于指定要执⾏任务的主机,其可以是⼀个或多个由冒号分 隔主机组.

remote_user: ⽤于指定远程主机上的执行任务的⽤户.

tasks:任务列表,按顺序执行任务.

■ 如果一个host执行task失败,整个tasks都会回滚,修正playbook中的错误,然后重新执行即可.


  • hosts: 组名/别名/ip/域名
    remote_user: root
    tasks:
  • name: 任务说明
    模块: key0=value0
    service: name=vsftpd state=started anabled=yes
  • name: 修改配置文件
    command: sed...
    notify:
  • ancdef

handler:

  • name: abcdef
    service name=vsftpd stste=restared
    ...

三、playbook编排vsftpd
1、安装
root@localhost \~# vim test001.yml


  • hosts: s #使用tab键对齐 指定组
    remote_user: root #
    tasks:
  • name: 安装vsftpd
    yum: name=vsftpd state=latest
    root@localhost \~# ansible-playbook ./test001.yml

2、卸载
root@localhost \~# vim test001.yml


  • hosts: s
    remote_user: root
    tasks:
  • name: 卸载vsftp
    yum: name=vsftpd state=absent
  • name: 安装vsftpd
    yum: name=vsftpd state=latest
    root@localhost \~# ansible-playbook ./test001.yml

3、启动服务
root@localhost \~# vim test001.yml


  • hosts: s
    remote_user: root
    tasks:
  • name: 卸载vsftp
    yum: name=vsftpd state=absent
  • name: 安装vsftpd
    yum: name=vsftpd state=latest
  • name: 启动服务
    service: name=vsftpd state=started e
    nabled=yes
    root@localhost \~# ansible-playbook ./test001.yml

4、修改配置文件设置不允许匿名访问并重启
handlers:类似task,但需要使用notify通知调用。

■ 不管有多少个通知者进行了notify,等到play中的所有task执行完成之后,handlers也只会被执行一次.

■ handlers最佳的应用场景是用来重启服务,或者触发系统重启操作.除此以外很少用到了.

root@localhost \~# yum -y install lftp

root@localhost \~# lftp 192.168.8.157
lftp 192.168.8.157:~> ls

drwxr-xr-x 2 0 0 6 Jun 09 2021 pub
root@s0 \~# sed -n '/^anonymous_enable=YES/s/YES/NO/g' /etc/vsftpd/vsftpd.conf
root@localhost \~# vim test001.yml


  • hosts: s
    remote_user: root
    tasks:

  • name: 卸载vsftp
    yum: name=vsftpd state=absent

  • name: 安装vsftpd
    yum: name=vsftpd state=latest

  • name: 启动服务
    service: name=vsftpd state=started enabled=yes

  • name: 修改配置文件
    command: sed -i '/^anonymous_enable=YES/s/YES/NO/g' /etc/vsftpd/vsftpd.conf
    notify: #调用

  • abcdefg
    handlers:

  • name: abcdefg
    service: name=vsftpd state=res
    tarted

root@localhost \~# ansible-playbook ./test001.yml

root@localhost \~# lftp 192.168.8.157
lftp 192.168.8.157:~> exit
root@localhost \~# lftp 192.168.8.157
lftp 192.168.8.157:~> ls
中断

相关推荐
AKAMAI1 小时前
每百万 Token 成本砍六成,出海 AI 团队开始重算推理这笔账
人工智能·云计算
tiancaijiben13 天前
阿里云Kubernetes集群托管完全指南:从创建到生产级运维
云计算
互联网推荐官13 天前
上海软件定制开发公司推荐:从PaaS工程化路径看D-coding的技术取舍
云原生·云计算·paas·软件开发·开发经验·上海
sbjdhjd13 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
tiancaijiben13 天前
阿里云应用实时监控服务ARMS完全接入指南:从探针部署到全链路可观测
云计算
xingyuzhisuan14 天前
算力租赁平台 GPU 资源隔离方案:显存抢占问题深度排查与解决
大数据·云计算·gpu算力
workbuddy小能手14 天前
腾讯云ADP Agent Portal vs 自建智能体:架构选型对比
架构·云计算·腾讯云
宸津-代码粉碎机14 天前
Spring AI 企业级实战|智能记忆摘要+自动遗忘机制落地,彻底解决上下文爆炸与Token冗余
java·大数据·人工智能·后端·python·spring·云计算
tiancaijiben14 天前
阿里云Elasticsearch搭建网站站内搜索功能:从零到生产级实战指南
云计算