标签:png 移动 输入 des ice fst 写入 描述 tab
Ansible可以使用命令行方式进行自动化管理,且ansible的命令行管理工具都是由一系列模块、参数支持的,我们可以通过ansible-doc工具查看模块帮助信息。本篇博文将详细讲述ansible模块功能及操作。命令: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模块
两种状态(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‘
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服务器上查看结果:
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‘
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服务器上相应目录下查看结果:
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‘ #删除
//测试被管理主机是否在线
ansible all -m ping
ansible-doc -s yum
ansible webserver -m yum -a ‘name=httpd‘ #安装httpd
ansible webserver -m yum -a ‘name=httpd state=absent‘ #移除httpd
ansible-doc -s shell
ansible webserver -m user -a ‘name=jerry‘
ansible webserver -m shell -a ‘echo abc123 | passwd --stdin jerry‘
#创建用户,免交互设置密码
在自己服务器设置脚本,其他服务器去执行
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‘
操作完成后,到被管理服务器上查看执行结果:
ansible-doc -s setup
ansible mysql -m setup #查看mysql服务器上所有信息
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服务
标签:png 移动 输入 des ice fst 写入 描述 tab
原文地址:http://blog.51cto.com/13784264/2306698