在自动化运维中,文件分发是一个高频需求场景,例如上传配置文件、分发脚本等。Ansible提供了强大的copy模块,帮助我们快速完成文件的分发任务。本文将结合实际案例,详细讲解copy模块的用法,助你在生产中得心应手。

Copy模块简介

copy 模块用于从Ansible控制节点向目标主机上传文件或目录。支持文件权限设置、内容替换等功能,是实现文件管理的利器。

ansible <pattern> -m copy \
-a "src=<source_path> dest=<destination_path> [other options]"

模块参数:

  • <pattern>:指定要操作的主机或主机组,例如 allwebservers

  • -m copy:指定使用copy模块。

  • src:源文件路径,必须是控制节点上的文件。

  • dest:目标路径,指定文件在目标主机上的存放位置。

  • owner:文件所有者。

  • group:文件所属组。

  • mode:文件权限。

  • content:直接指定文件内容。

基础用法示例

上传文件到远程主机

在控制节点的 /etc/ansible/playbooks/ 目录下,有一个 config.txt 文件需要分发到所有目标主机的 /etc/app/ 目录。

  • Playbook语法示例
- name: 使用 copy 模块上传文件
  hosts: test
  tasks:
    - name: 上传配置文件到目标主机
      ansible.builtin.copy:
        src: /etc/ansible/playbooks/config.txt
        dest: /home/config.txt
        owner: root
        group: root
        mode: '0644'

命令运行:

ansible-playbook -i hosts copy_example.yml
  • ad-hoc语法示例:
ansible test -m copy \
-a "src=/etc/ansible/playbooks/config.txt dest=/home/config.txt owner=root group=root mode=0664"

结果:

文件config.txt被成功上传到目标主机的 /etc/app/目录,权限设置为0644,并且把所有者和组设置为root。

多环境文件分发

在生产环境中,需要将不同的配置文件分发到开发、测试和生产环境。配置文件根据环境名称存储在控制节点的不同目录中:

  • /etc/ansible/configs/dev/config.txt

  • /etc/ansible/configs/test/config.txt

  • /etc/ansible/configs/prod/config.txt

动态路径分发

Playbook 示例:

- name: 多环境配置文件分发
  hosts: all
  vars:
    env: "{{ inventory_hostname | regex_replace('(.*)-(.*)', '\\2') }}"  # 提取环境名
  tasks:
    - name: 根据环境分发配置文件
      ansible.builtin.copy:
        src: "/etc/ansible/configs/{{ env }}/config.txt"
        dest: "/etc/app/config.txt"
        owner: root
        group: root
        mode: '0644'

**hosts**** 文件示例:**

[dev]
dev-server-01 ansible_host=192.168.1.101

[test]
test-server-01 ansible_host=192.168.1.102

[prod]
prod-server-01 ansible_host=192.168.1.103

命令运行:

ansible-playbook -i hosts multi_env_copy.yml

结果:

每个环境的主机接收到对应的配置文件:

  • dev-server-01:收到 dev/config.txt

  • test-server-01:收到 test/config.txt

  • prod-server-01:收到 prod/config.txt

替换目标文件内容

在上传文件时,需要动态替换其中的占位符,例如替换为主机名或IP地址。

使用 content 参数

Playbook 示例:

- name: 动态生成配置文件
  hosts: all
  tasks:
    - name: 根据模板生成配置文件
      ansible.builtin.copy:
        dest: /etc/app/config.txt
        content: |
          主机名:{{ inventory_hostname }}
          IP地址:{{ ansible_default_ipv4.address }}
        owner: root
        group: root
        mode: '0644'

命令运行:

ansible-playbook -i hosts dynamic_content.yml

结果:

目标主机 /etc/app/config.txt 的内容如下:

主机名:dev-server-01
IP地址:192.168.1.101

copy模块 vs template 模块

copy 模块虽然简单高效,但在处理动态内容时需要通过 content 参数显式定义。而 template 模块专为动态内容设计,结合Jinja2模板更灵活。

总结

copy模块是Ansible文件分发的基础工具,无论是单文件上传、多环境管理,还是动态内容生成,它都能快速满足需求。在实际运维中,根据场景选择适当的方法,搭配其他模块使用,可以大大提高自动化效率。快用copy模块在你的工作中试一试吧!