掌握Ansible命令——提高自动化运维效率

目录

一、Ansible命令

1.定义

2.组成

 3.命令格式

4.选项

5.示例

二、常用命令解释

1.ansible-doc

2.ansible-galaxy

3.ansible-playbook

4.ansible-pull

5.ansible-vault

三、高频使用的命令

1.Ping主机

2.执行命令

3.安装软件包

4.管理文件

5.管理服务

6.获取主机信息

7.执行自定义脚本

8.以sudo权限执行命令


在当今的IT自动化领域,Ansible无疑是一个无法被忽视的重要角色。其便利性和高效性受到了广大开发者和系统管理员的一致好评,成为了配置管理和应用部署的首选工具。

一、Ansible命令

1.定义

Ansible 命令是一种强大的自动化工具,它允许系统管理员和开发者在多台机器上自动执行任务。其中,Ad-Hot模式是一个概念性的名称,它与编写Ansible playbook的概念相似,类似于直接在命令行输入shell命令与编写shell scripts之间的关联。

2.组成

  • Ansible 匹配的资产主机:这是你希望在其上执行任务的目标机器或一组机器。
  • 使用的模块 -m:这是你希望执行的具体动作或任务,Ansible提供了许多预定义的模块以供选择。
  • 模块的参数 -a:这允许你为特定模块传递参数,以便进一步定制其行为。

 3.命令格式

ansible [pattern] -m [module] -a '[module arguments]' [options]



[pattern]:用来匹配目标主机或主机组的模式。

-m [module]:指定要使用的模块。

-a '[module arguments]':指定模块的参数。

[options]:其他可选参数。

4.选项

命令选项含义
-a 'Arguments', --args='Arguments'指定模块的参数。
-m NAME, --module-name=NAME指定要执行的模块名。默认使用 command 模块,所以如果只是执行单一命令,可以省略 -m 参数。
-u Username, --user=Username指定执行远程命令的用户,默认使用当前用户。
-U, --sudo-user=SUDO_Usersudo 到哪个用户,默认为 root。
-k, --ask-pass提示输入 SSH 密码,而不是假设基于密钥的验证。
-K, --ask-sudo-pass提示输入 sudo 密码。
-s, --sudo使用 sudo 运行命令。
-S, --su使用 su 命令运行命令。
-f NUM, --forks=NUM指定并行任务数,默认为 5。
--private key=PRIVATE_KEY_FILE指定私钥文件的路径,用于 SSH 连接验证。
-v, --verbose输出详细信息。
all针对 hosts 文件中定义的所有主机执行命令。
-M MODULE_PATH, --module-path=MODULE_PATH指定模块的搜索路径。
-o, --one-line压缩输出,尝试将输出信息压缩到一行中显示。
-B SECONDS, --background=SECONDS在后台运行命令,并指定超时时间。
-P NUM, --poll=NUM在后台模式下,每隔多少秒检查一次作业状态。
-T SECONDS, --timeout=SECONDS设置命令执行的超时时间。
-c CONNECTION, --connection=CONNECTION指定连接类型,如 paramiko (SSH)、ssh 或 local
--tags=TAGS只执行指定标签的任务。
--list-hosts只打印将执行 playbook 的主机列表,并不真正执行 playbook。
--list-tasks列出 playbook 中所有将被执行的任务。
-C, --check只测试命令会改变什么内容,而不会真正执行。
--syntax-check检查 playbook 的语法,但不执行。
-l SUBSET, --limit=SUBSET进一步限制所选主机或主机组。
--skip-tags=SKIP_TAGS跳过标签匹配的任务。
-e EXTRA_VARS, --extra-vars=EXTRA_VARS设置额外的变量。

5.示例

ansible all -m command -a "df -h" --become --become-user root
#以 root 用户身份对所有主机执行 df -h 命令


ansible webservers -m yum -a "name=nginx state=present" -k
#使用 yum 模块安装 nginx,并提示输入密码


ansible appservers -m command -a "uptime" -u john -f 5
#以 john 用户身份对 appservers 主机组执行 uptime 命令,并限制并发数为 5


ansible testhosts -a "/sbin/reboot" -f 10
#重启 testhosts 组的所有机器,每次重启 10 台


ansible-playbook update.yml --extra-vars "hosts=vipers user=admin"
#使用额外的变量执行 playbook


ansible [pattern] -m [module] -a '[module arguments]' --limit=192.168.241.22,192.168.241.23
#只对这个两个 IP 执行任务

二、常用命令解释

1.ansible-doc

ansible-doc -h Usage: ansible-doc [options] [module...]
#该指令用于查看模块信息,常用参数有两个-l 和 -s ,具体如下
ansible-doc -l
#列出所有已安装的模块


ansible-doc -s command
#查看具体某模块的用法,这里如查看command模块

2.ansible-galaxy

ansible-galaxy -h Usage: ansible-galaxy [init|info|install|list|remove] [--help] [options] ...
#ansible-galaxy指令用于方便的从https://galaxy.ansible.com/ 站点下载第三方扩展模块,我们可以形象的理解其类似于centos下的yum、python下的pip

3.ansible-playbook

通过读取playbook 文件后,执行相应的动作

4.ansible-pull

该指令使用需要谈到ansible的另一种模式——pull 模式,这和我们平常经常用的push模式刚好相反

其适用于以下场景:你有数量巨大的机器需要配置,即使使用非常高的线程还是要花费很多时间

5.ansible-vault

ansible-vault主要应用于配置文件中含有敏感信息,又不希望他能被人看到,vault可以帮你加密/解密这个配置文件,属高级用法。主要对于playbooks里比如涉及到配置密码或其他变量时,可以通过该指令加密,这样我们通过cat看到的会是一个密码串类的文件,编辑的时候需要输入事先设定的密码才能打开。这种playbook文件在执行时,需要加上 –ask-vault-pass参数,同样需要输入密码后才能正常执行。

三、高频使用的命令

1.Ping主机

用于测试Ansible是否能够成功连接到远程主机。

ansible all -m ping

2.执行命令

在远程主机上执行特定的shell命令。

ansible all -m command -a "ls -l /etc"

3.安装软件包

 使用yum模块在远程主机上安装软件包。

ansible servers -m yum -a "name=nginx state=present"

4.管理文件

 使用copy模块将本地文件复制到远程主机。

ansible all -m copy -a "src=/path/to/local/file dest=/path/on/remote/host"

5.管理服务

使用service模块启动、停止或重启远程主机上的服务。

ansible webservers -m service -a "name=nginx state=started"

6.获取主机信息

 使用setup模块收集远程主机的系统信息。

ansible all -m setup

7.执行自定义脚本

使用script模块在远程主机上执行本地脚本。

ansible all -m script -a "/path/to/local/script.sh"

8.以sudo权限执行命令

使用--become选项以sudo权限在远程主机上执行命令。

ansible all -m command -a "whoami" --become --become-user root
  • 34
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值