当前位置 : 主页 > 网络安全 > 测试自动化 >

Ansible常用模块详解

来源:互联网 收集:自由互联 发布时间:2021-06-19
Ansible可以使用命令行方式进行自动化管理,且ansible的命令行管理工具都是由一系列模块、参数支持的,我们可以通过ansible-doc工具查看模块帮助信息。本篇博文将详细讲述ansible模块功
Ansible可以使用命令行方式进行自动化管理,且ansible的命令行管理工具都是由一系列模块、参数支持的,我们可以通过ansible-doc工具查看模块帮助信息。本篇博文将详细讲述ansible模块功能及操作。

Ansible命令参数:

  • -v:输出详细信息(可以使用多个v)
  • -i PATH:指定hosts文件位置
  • -f NUM :指定开启的进程数(默认为5)
  • -m MOULE :指定module的名称(默认为command)
  • -m DIRECTORY:指定module的目录来加载module,默认是/usr/share/ansible
  • -a,MODULE_ARGS:指定module模块的参数
  • -k:提示输入ssh的密码,而不是使用基于ssh的密钥认证
  • -u USERNAME:指定移动端的执行用户

    Ansible模块:

    1、command模块

    命令:ansible [主机] [-m 模块] [-a args]
    ansible-doc -l #列出所有安装模块(q退出)
    ansible-doc -s yum #列出yum模块描述信息和操作动作
    ansible all -m command -a ‘date‘ #查询date
    ansible all -a ‘ls /‘ #如果不加-m模块,默认运行command模块


2、cron模块

两种状态(state):present表示添加        absent 表示移除
ansible-doc -s cron                      #查看cron模块信息
ansible all -m cron -a ‘minute="*/1" job="/usr/bin/echo heihei >> /opt/test.txt" name="test cron"‘          
#-a: 指定添加参数     */1:每分钟执行      job:执行内容

ansible mysql -a ‘crontab -l‘        #查看crontab信息
ansible mysql -m cron -a ‘name="test cron" state=absent‘

3、user模块

ansible-doc -s user
ansible all -m user -a ‘name=test‘ #创建用户


操作成功后,到被管理服务器上查看结果:

ansible mysql -m command -a ‘tail /etc/passwd‘
ansible mysql -m user -a ‘name=test01 state=absent‘ #删除用户


操作成功后,到mysql服务器上查看结果:

4、group模块

ansible mysql -m group -a ‘name=mysql gid=330 system=yes‘
ansible mysql -a ‘tail /etc/group‘

ansible mysql -m user -a ‘name=test02 uid=330 group=mysql system=yes‘
#新建用户test02;设定UID=306;将test02添加到mysql组
ansible mysql -a ‘id test02‘

5、copy模块

ansible-doc -s copy
ansible all -m copy -a ‘src=/etc/fstab dest=/opt/fstab.bk owner=root mode=644‘
#src:原文件 dest:复制后目标文件 owner:属主 mode:权限
ansible mysql -a ‘ls -l /opt‘ #在控制主机上查看


操作成功后,到被管理服务器上相应目录下查看结果:

ansible mysql -m copy -a ‘content="hello world!" dest=/opt/hello.txt‘
#复制文件hello.txt中写入“hello world!”
ansible mysql -a ‘cat /opt/test.txt‘ #在控制主机上查看


操作成功后,到mysql服务器上相应目录下查看结果:

6、file模块

ansible-doc -s file
touch /opt/file.txt
ansible mysql -m file -a ‘path=/opt/file.txt owner=test02 group=mysql mode=666‘
#对test文件设置属主、属组、权限


操作完成后,到mysql服务器下检查结果:

ansible mysql -m file -a ‘src=/opt/test.txt path=/opt/test.txt.link state=link‘
#将src指的文件链接到path指的路径下


操作完成后,到mysql服务器相应目录下检查结果:

当然,也可以创建空文件,操作相对简单
ansible mysql -m file -a ‘path=/opt/abc.txt state=touch‘ #创建空文件
ansible mysql -m file -a ‘path=/opt/abc.txt state=absent‘ #删除

7、ping模块

//测试被管理主机是否在线
ansible all -m ping

8、yum模块

ansible-doc -s yum
ansible webserver -m yum -a ‘name=httpd‘ #安装httpd
ansible webserver -m yum -a ‘name=httpd state=absent‘ #移除httpd

9、shell模块

ansible-doc -s shell
ansible webserver -m user -a ‘name=jerry‘
ansible webserver -m shell -a ‘echo abc123 | passwd --stdin jerry‘
#创建用户,免交互设置密码

10、script模块

在自己服务器设置脚本,其他服务器去执行
ansible-doc -s script
#!/bin/bash
echo "this is test script" > /opt/script.txt
chmod 666 /opt/script.txt #设置权限
chmod +x test.sh #为脚本添加执行权限
ansible all -m script -a ‘test.sh‘


操作完成后,到被管理服务器上查看执行结果:

11、setup模块

ansible-doc -s setup
ansible mysql -m setup #查看mysql服务器上所有信息

12、service模块

ansible-doc -s service
ansible webserver -m service -a ‘name=httpd enabled=true state=started‘
#开启httpd服务 ; enabled:开机自启动ansible webserver -m service -a ‘name=httpd enabled=true state=stopped‘ #关闭httpd服务

网友评论