当前位置: 代码迷 >> 综合 >> ansible 简易教程
  详细解决方案

ansible 简易教程

热度:44   发布时间:2023-12-09 22:25:52.0

安装命令

pip3 install ansible# 用密码登陆远程主机需要额外装sshpass
sudo apt install sshpass

配置

ansible --version

config_file = None

这时要在 /etc/ansible/ 目录下手动创建 ansible.cfg 和 hosts 文件。

在ansible.cfg中配置,跳过初次ssh时的客户端可信校验。

[defaults]
host_key_checking = False

添加hosts

hosts文件示例如下:

[group_name]
123.123.123.123:22 ansible_ssh_user=root ansible_ssh_pass='password'
123.123.123.124:22 ansible_ssh_user=root ansible_ssh_pass='password'

分别是IP,端口,账号和密码,一个[group]可以有多台服务器。

测试

ansible groupname -m ping

-m表示调用的模块名称。

实例

fetch: 从远程copy文件到本地,注意目前支持文件,不支持文件夹递归copy

拷贝单个文件:

ansible hosts -m fetch -a "src=/remote/dir/file dest=/local/dir" #-a表示模块的参数

copy:从本地到远程

shell:运行shell

find: 查找文件

unarchive: 解压

archive:压缩

ansible-playbook

ansible playbook 在 ansible命令行的基础上提供了跟家强大的流程编写功能。

写一个yaml文件 p.yml:

---  #固定格式, 这个脚本演示了把一个远程文件夹里的多个文件拷贝到本地的/tmp/目录- name: Fetch_dir_from_remotehosts: IP or Groupnametasks:- name: findfind:paths: /var/www/htmlpatterns: "*"recurse: yesregister: file_2_fetch  #注册变量- name: fetch_findfetch:src: "{
   { item.path }}"dest: /tmp/flat: yeswith_items: "{
   { file_2_fetch.files }}"  #遍历find的结果

执行yml

ansible-playbook p.yml