我爱编程

ansible的最少必需知识

2018-04-08  本文已影响76人  xuefly

隶属于文章系列:大数据安全实战 https://www.jianshu.com/p/76627fd8399c


本文为ansible的最简单使用说明。

安装

sudo yum -y install ansible

配置

[hadoop]
172.20.176.68
172.20.176.69
172.20.176.70
172.20.176.71
[test]
172.20.176.35
172.20.176.36
172.20.176.37

中括号内为其下面的一系列主机的整体代号,比如使用hadoop可以同时操作69到71四台主机。

使用

最简单的使用 : 检查主机连接

ansible hadoop -m ping

最常用最有用的使用

在运维中ansible的远程命令、分发文件模块可以覆盖几乎所有的使用场景。

-m 指定要使用的模块
-m shell : 批量执行命令
-m copy : 批量分发文件
-a 后引号之间的内容是具体的操作。
设置环境变量
ansible hadoop  -m shell -a "echo 'export SPARK_HOME=/home/kduser/spark/current' 
src :本地的源路径
dest:远程路径

注意:当要把/etc/hadoop 分发出去的时候:
scp一般这样操作,两者效果一样

scp -r /etc/hadoop  hostname:/etc/
或者
scp -r /etc/hadoop  hostname:/etc/hadoop

ansible在复制文件的时候:下面都符合要求

ansible hadoop  -m copy  -a ' src=~/etc/hadoop/hdfs-site.xml  dest=/etc/hadoop/hdfs-site.xml'
ansible hadoop  -m copy  -a ' src=~/etc/hadoop/hdfs-site.xml  dest=/etc/hadoop/'

但目录的复制,目的路径必须写到父目录,
ansible hadoop -m copy -a ' src=~/etc/hadoop dest=/etc/'
如果dest=/etc/hadoop 则回到生成/etc/hadoop/hadoop

使用进阶

当前用户需要用到root权限才能执行特定命令(比如yum命令),或者操作特定目录(比如/etc目录)。这时候--become选项可以自动sudo到root用户下执行。
例如:

ansible all --become  -m copy -a "src=/home/kduser/JDK8/US_export_policy.jar   dest=/usr/java/jdk1.8.0_144/jre/lib/security/ "

注意:只用--become选项需要当前用户能够免密码sudo到root。当前用户需要输入密码才能sudo到root时,则需要-K 选项,提示输入sudo密码

上一篇 下一篇

猜你喜欢

热点阅读