ping 命令

 #测试单个主机
[root@node1 opt]# ansible -m ping 10.0.0.22 #获取多个主机
[root@node1 opt]# ansible 10.0.0.22,10.0.0.23 -m ping #测试hosts文件中的所有主机
[root@node1 opt]# ansible all -m ping

主机分组,在/etc/ansible/hosts 文件中修改

[web]
10.0.0.22
10.0.0.23
[db]
10.0.0.[23:24] #从23到24

通过分组来查看主机信息

#用来获取符合条件的机器
[root@node1 opt]# ansible web --list-hosts
hosts (2):
10.0.0.22
10.0.0.23 #探测组内的机器
[root@node1 opt]# ansible web -m ping #获取web和db的交集
[root@node1 opt]# ansible 'web:&db' -m ping #获取web和db的并集
[root@node1 opt]# ansible 'web:db' -m ping
[root@node1 opt]# ansible web,db -m ping #获取web和db的差集,在web中存在但是在db中不存在
[root@node1 opt]# ansible 'web:!db' -m ping

模块

获取模块帮助信息

[root@node1 opt]# ansible-doc -h
Usage: ansible-doc [-l|-F|-s] [options] [-t <plugin type> ] [plugin] -j, --json #以json的方式返回所有模块的信息
-l # 列出所有的模块
-s, --snippet # 以片段式显示模块的帮助信息,没有-s显示详细信息 ansible-doc -l |wc -l #统计ansible的模块

command模块

command用户执行远程命令,为默认值,不写 -m command也可执行

chdir #切换目录
creates # 如果存在,就不执行,如果不存在,就执行
removes # 如果不存在,就不执行,如果存在,就执行
获取远程机器的工作目录
[root@node1 opt]# ansible web -m command -a "pwd"

chdir :切换目录,一般在做编译安装时使用

[root@node1 opt]# ansible web -m command -a "chdir=/tmp pwd"

creates:当crestes右边条件成立时,不会被执行,不成立是会被执行

#不会执行,因为/tmp目录已经存在
[root@node1 opt]# ansible web -m command -a "creates=/tmp pwd" #会被执行,因为/tmp2目录不存在
[root@node1 opt]# ansible web -m command -a "creates=/tmp2 pwd"

removes:当removes等号右边成立时,会被执行,不成立是不会执行

#会被执行,因为/tmp目录已经存在
[root@node1 opt]# ansible web -m command -a "removes=/tmp pwd" #不会被执行,因为 /tmp2目录不存在
[root@localhost ~]# ansible web -m command -a "removes=/tmp2 pwd"

shell:执行远程机器的脚本

创建用户并为用户设置 密码

[root@node1 opt]# ansible db -a "useradd wl"

[root@node1 opt]# ansible web -m shell -a "echo 'wanglan'|passwd --stdin wl" 

执行shell脚本

[root@node1 opt]# ansible 10.0.0.22 -m shell -a "bash /opt/a.sh"
[root@node1 opt]# ansible 10.0.0.22 -m shell -a "/opt/a.sh" #a.sh要有执行权限

执行python脚本

[root@node1 opt]#ansible 10.0.0.22 -m shell -a "/root/a.py"
[root@node1 opt]#ansible 10.0.0.22 -m shell -a "python a.py" #a.py要有执行权限

script:执行管控机上的脚本

执行本地的脚本,管控机上的脚本

[root@node1 opt]# ansible web -m script -a "/opt/b.sh"

判断远程机器是否存在,如果不存在,就不执行,如果存在,就执行

[root@node1 opt]# ansible db -m script -a "creates=/root/a.sh /root/a.sh"

判断远程机器是否存在,如果不存在,就执行,如果存在,就不执行

[root@node1 opt]# ansible db -m script -a "removes=/root/a.sh /root/a.sh"

copy

参数说明

backup   #创建备份文件,以时间戳结尾
content #直接写内容
dest #目标地址
group #文件的属组
mode #文件的权限
owner  #文件的属主
src  #原文件

复制文件

[root@node1 opt]# ansible web -m copy -a "src=/opt/a.sh  dest=/opt/a.sh"

复制并修改权限

[root@node1 opt]# ansible web -m copy -a "src=/opt/a.sh  dest=/opt/a.sh  mode=755"

复制并修改权限和属主

[root@node1 opt]# ansible web -m copy -a "src=/opt/a.sh  dest=/opt/a.sh  mode=755 owner=wl"

复制文件夹

[root@node1 opt]# ansible web -m copy -a "src=/etc/init.d  dest=/tmp/"

复制文件夹下的所有文件

[root@node1 opt]# ansible web -m copy -a "src=/etc/init.d/  dest=/tmp/"

复制文件夹,并改变文件夹的属性,文件夹的文件的属性也会跟着改变

[root@node1 opt]# ansible web -m copy -a "src=/etc/init.d dest=/tmp/ owner=wl"

直接写文字,覆盖写入,要慎用

[root@node1 opt]# ansible web -m copy -a "content='大弦嘈嘈如急雨,小弦切切如私语' dest=/tmp/a.sh" 

备份文件,如果远程机器上有就会备份,没有要备份的文件,即使指定了backup=yes 也不会去备份文件

[root@node1 opt]# ansible wb -m copy -a "src=/root/a.sh dest=/root/a.sh mode=755 owner=alex backup=yes" 

file

参数

ccess_time # 访问时间
group # 属组
mode #权限
owner #属主
path #路径
src # 原文件,link和hard的时候使用
state:
directory 文件夹
file
touch 空文件
link 软连接
hard 硬链接
absent 删除

创建一个目录

[root@node1 opt]# ansible web -m file -a "path=/tmp/wl state=directory"

创建一个目录,并制定属主,权限

[root@node1 opt]# ansible web -m file -a "path=/tmp/wl state=directory owner=wl  mode=644"

创建一个文件,并制定属主,权限

[root@node1 opt]# ansible web -m file -a "path=/tmp/wl state=touch owner=wl  mode=644"

创建一个软连接,当state=link时,必学要有src

[root@node1 opt]# ansible web -m file -a "path=/tmp/f src=/etc/fstab state=link"

删除

[root@node1 opt]# ansible web -m file -a "path=/tmp/f state=absent" 

fetch

fetch将远程机器上的文件拉取到本地,以IP或者主机名生成目录,并保留原来的目录结构

参数

dest #目标地址
src #源地址 [root@node1 opt]# ansible db -m fetch -a "dest=/tmp src=/var/log/cron"

通过ansible以非root用户登录远程机器

[root@node1 opt]# ansible db -a 'pwd' -u baoyuan2 -k

k #输入远程机器的密码

yum

系统的yum

yum源的配置

[root@node1 opt]# ll /etc/yum.repos.d/

配置文件详解

[epel]     # 名称
name=Extra Packages for Enterprise Linux 7 - $basearch # 描述信息
baseurl=http://mirrors.aliyun.com/epel/7/$basearch # yum源的地址
failovermethod=priority
enabled=1 # 指定yum源是否可用,1代表可用,0代表不可用
gpgcheck=0 # 是否检查gpgkey文件,0代表不检查,1代表的检查
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7

包组

查看包组

[root@node1 opt]# yum grouplist

其中有一个名为  Development Tools 的开发包组,对其进行安装

[root@node1 opt]# yum groupinstall 'Development Tools' # groupinstall:安装包组

ansible的yum

参数

disable_gpg_check # 是否要检查key
disablerepo # 禁用repo
enablerepo #启用repo
name # 包名
state # 状态 installed removed

使用

ansible db -m yum -a "name=python2-pip" # 安装一个包
ansible db -m yum -a "name='@Development Tools'" # 安装包组
ansible db -m yum -a "name=redis,python2-pip" # 同时安装多个包
ansible db -m yum -a "name=redis state=absent" # 卸载

查看包安装状态

yum list|grep redis #@epel代表安装成功
rpm -q redis #查看包是否安装
rpm -qa #查看所有的包
rpm -ql #查看包安装生成的文件

pip

系统的pip

pip list #查看所有的python第三方包
pip freeze > a.txt # 导出
pip install -r a.txt # 安装

ansible的pip

requirements #导出的文件
name # 包名
virtualenv # 虚拟环境
ansible db -m pip -a "name=django==1.11.18" # 安装
ansible db -m pip -a "name=flask

service

系统命令

ps -ef|grep redis  # 查看进程
ss -tnlp #查看端口信息
# 启动服务
systemctl start redis #centos7
service redis start # centos6
# 开机自启动
systemctl enable redis #centos7
chkconfig redis on #centos6

ansible的service

enabled # 设置开机自启动
name # 名称
state
started
stoped
restarted
reloaded
ansible web -m service -a "name=redis state=started" # 启动
ansible web -m service -a "name=redis state=stopped" # 关闭
ansible web -m service -a "name=redis state=started enabled=yes" # 启动并设置开机自启动

cron

系统的crontab

* * * * * job
分 时 日 月 周 任务
1 * * * * job # 代表每小时的第一个分钟
2/* * * * * job # 每隔2分钟执行job
1 10-19 * * * job # 代表10到19点的第一分钟
0-59 0-23 1-31 1-12 0-7 job
* * * * * tar -zcf /opt/etc.tar.gz /etc
分钟不要用*,最好是指定时间
分钟不要用*,最好是指定时间
分钟不要用*,最好是指定时间
crontab -l # 查看计划任务
crontab -r # 删除所有的计划任务
crontab -e # 编辑计划任务

ansible的cron

day # 天
hour # 小时
job #任务
minute #分钟
month # 月
name #名字,描述信息,不可以重复
state # 状态
user # 执行计划任务的用户
weekday # 周
disabled # 禁止
ansible web -m cron -a "minute=21 job='touch /tmp/cron.txt' name=touchfile" # 设置计划任务 name为描述
ansible web -m cron -a "minute=23 job='touch /tmp/cron.txt' name=touchfile4 disabled=yes" # 禁用计划任务,表现为加注释
ansible web -m cron -a "name=touchfile4 state=absent" # 删除计划任务

user

系统中的user

用户的分类
超级管理员 root 0
其他用户
系统用户 启动服务来专门设置的用户 1-999 centos7 1-499 centos6
登陆用户 普通的登陆用户 1000-65535 centos7 500-65535 centos6 useradd
-d # 指定家目录
-g # 组id
-G, --groups GROUPS # 附加组
-r, --system # 创建系统用户
-s, --shell SHELL # 登陆shell
-u, --uid UID #用户id
useradd -s /sbin/nologin -u 2000 -d /opt/wl wl #创建用户,指定用户的登陆shell,id,家目录
useradd -s /sbin/nologin -G root,wusir -d /opt/wl1 wl1#指定附加组,最大的后面+1
useradd -r wl # 创建系统用户,从999倒序
userdel wl1 # 删除用户
userdel -r wl2 # 删除用户并删除用户的家目录

ansible中的user

group # 组
groups #附加组
home #家目录
name #用户名
password #密码
shell #登陆shell
remove # 删除用户并删除用户的家目录
state # 状态
system #系统用户
uid # 用户id
ansible db -m user -a "name=wl shell=/sbin/nologin home=/opt/alex2 uid=2000 group=root" # 创建用户,并指定用户的家目录,登陆shell,uid,组
ansible db -m user -a "name=wl1 system=yes" #创建系统用户
ansible db -m user -a "name=wl2 state=absent" # 删除用户
ansible db -m user -a "name=wl3 state=absent remove=yes" # 删除用户并删除用户的家目录

group

系统的group

用户组的分类
超级组 root 0
其他组
系统组 1-999 centos7 1-499 centos6
普通组 1000-65535centos7 500-65535 centos6 -g #指定组的id
-r #指定系统组
groupadd #添加用户组
groupdel #删除用户组

ansible中的user

gid #组的id
name # 组名
state #状态
system #系统组
ansible db -m group -a "name=canglaoshi" #创建普通组
ansible db -m group -a "name=wutenglan system=yes" # 创建系统组
ansible db -m group -a "name=wutenglan state=absent" # 删除组

ansible命令及模块的更多相关文章

  1. ansible命令执行模块使用

    ansible命令执行模块使用 1.命令执行模块-command 在远程节点上运行命令. 命令模块使用命令名称,接上空格-的分割符作为参数使用,但是不支持管道符和变量等,如果要使用这些,那么可以使用s ...

  2. Ansible 命令相关模块command, shell, raw, expect, script, telnet[转]

    本文主要介绍Ansible的几个命令模块,包括: command - 在远程节点上执行命令 shell - 让远程主机在shell进程下执行命令 script - 将本地script传送到远程主机之后 ...

  3. ansible笔记(6):常用模块之命令类模块

    ansible笔记():常用模块之命令类模块 command模块 command模块可以帮助我们在远程主机上执行命令 注意:使用command模块在远程主机中执行命令时,不会经过远程主机的shell处 ...

  4. ansible的安装及命令相关模块

    ansible 第一步:下载epel源 curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos- ...

  5. Ansible常用模块之命令类模块

    Command模块 在远程节点上执行命令 [root@tiandong ~]# ansible all -m command -a "ls" 在远程主机上执行ls命令. [root ...

  6. ansible使用shell模块在受控机上执行命令(ansible2.9.5)

    一,ansible的shell模块和command模块的区别? shell模块:在远程主机上执行主控端发出的shell/python脚本 command模块:不能调用shell指令,没有bash的环境 ...

  7. ansible使用临时命令通过模块来执行任务

    使用临时命令通过模块来执行任务 一.查看系统上安装的所有模块 ansible-doc -l 查看ping模块帮助文档 ansible-doc ping 1.ansible模块 文件模块: copy:将 ...

  8. Ansible4:Ad-hoc与命令执行模块【转】

    Ad-Hoc 是指ansible下临时执行的一条命令,并且不需要保存的命令,对于复杂的命令会使用playbook.Ad-hoc的执行依赖于模块,ansible官方提供了大量的模块. 如:command ...

  9. ansible命令应用基础

    ansible命令应用基础:    Usage: ansible <host-pattern> [-f forks] [-m module_name][-a args]        -f ...

随机推荐

  1. centos6.5/centos7安装部署企业内部知识管理社区系统wecenter

    企业内部知识系统wecenter社区系统安装及部署 centos 6.5环境安装 因为是公司内部使用在线人数不会太多,使用yum安装lamp环境即可 1.安装lamp基本环境 yum -y insta ...

  2. Clipboard深度实践与采坑记录

    1.css禁止选择导致IOS无法复制 body{ -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: ...

  3. Android之 看“马达”如何贯通Android系统 (从硬件设计 --> 驱动 --> HAL --> JNI --> Framework --> Application)

    在Android 2.3(Gingerbread) 系统的时候,我写过一篇关于“Android 震动马达系统“的文章,当时的Linux内核还是2.6版本的.写那篇文章的目的,是想彻底的了解从硬件到驱动 ...

  4. LeetCode(46):全排列

    Medium! 题目描述: 给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [ ...

  5. C++ code:main参数

    main函数的参数结构为两项参数: int main(int argc,char** argv){……} main的参数由操作系统传递,所以比较特殊.两个形参名一般是采用习惯名称argc和argv,表 ...

  6. 目标检测-yolo2

    转载自:http://blog.csdn.net/qq_34784753/article/details/78825493 对于现在的最好的检测系统来说,yolo_v1 的问题主要出现在两方面,也就是 ...

  7. 2018-2019 2 20165203 《网络对抗技术》Exp5 MSF基础

    2018-2019 2 20165203 <网络对抗技术>Exp5 MSF基础 实验内容 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: ...

  8. 2018-2019 2 20165203 《网络对抗技术》 Exp3 免杀原理与实践

    2018-2019 2 20165203 <网络对抗技术> Exp3 免杀原理与实践 免杀原理与实践说明及基础问答部分 实验任务 正确使用msf编码器(0.5分),msfvenom生成如j ...

  9. 2017-2018-2 20155225《网络对抗技术》实验五 MSF基础应用

    2017-2018-2 20155225<网络对抗技术>实验五 MSF基础应用 ms08_067 用search命令,搜索与ms08_067相关的模块,如图: 找到了对应的攻击模块expl ...

  10. 2017-2018-2 20155309 南皓芯 Exp7 网络欺诈防范

    实践内容 本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法.具体实践有 1,简单应用SET工具建立冒名网站 2.ettercap DNS spoof 3.结合应用两种技术,用 ...