一、连接两台机器或多台
ssy-keygen -t rsa 生成公钥和私钥
ssh-copy -id -i 公钥 root@192.169.17.154 生成的公钥,传给服务器
ssh root@192.1698.17.153 确认连接上另一个服务器
二、ansible常用模块
1.远程命令模块( command / script / shell )
command 作为 Ansible 的默认模块,可以运行远程权限范围所有的 shell 命令,不支持管道符。
shell > ansible Client -m command -a "free -m" # 查看 Client 分组主机内存使用情况
script 的功能是在远程主机执行主控端存储的 shell 脚本文件,相当于 scp + shell 组合。
shell > ansible Client -m script -a "/home/test.sh 12 34" # 远程执行本地脚本
shell 的功能是执行远程主机上的 shell 脚本文件,支持管道符。
shell > ansible Client -m shell -a "/home/test.sh" # 执行远程脚本
-
copy 模块(实现主控端向目标主机拷贝文件,类似于 scp 功能)
shell > ansible Client -m copy -a "src=/home/test.sh desc=/tmp/ owner=root group=root mode=0755" # 向 Client 组中主机拷贝 test.sh 到 /tmp 下,属主、组为 root ,权限为 0755
- stat 模块(获取远程文件状态信息,atime/ctime/mtime/md5/uid/gid 等信息)
shell > ansible Client -m stat -a "path=/etc/syctl.conf" - get_url 模块(实现在远程主机下载指定 URL 到本地,支持 sha256sum 文件校验)
例:
shell > ansible Client -m get_utl -a "url=http://www.baidu.com dest=/tmp/index.html mode=0440 force=yes"
5.yum 模块(软件包管理)
shell > ansible Client -m yum -a "name=curl state=latest"
6.cron 模块(远程主机 crontab 配置)
shell > ansible Client -m cron -a "name='check dirs' hour='5,2' job='ls -alh > /dev/null'"
7.mount 模块(远程主机分区挂载)
shell > ansible Client -m mount -a "name=/mnt/data src=/dev/sd0 fstype=ext4 opts=ro state=present"
8.service 模块(远程主机系统服务管理)
shell > ansible Client -m service -a "name=nginx state=stoped"
shell > ansible Client -m service -a "name=nginx state=restarted"
shell > ansible Client -m service -a "name=nginx state=reloaded"
-
user 服务模块(远程主机用户管理)
shell > ansible Client -m user -a "name=wang comment='user wang'"shell > ansible Client -m user -a "name=wang state=absent remove=yes" # 添加删除用户