ansible file模块

file模块

管理文件和目录的属性,如状态(是否存在)、权限、所有权等。

1、创建文件:

使用file模块的state参数设置为**touch**可以创建文件。例如:

bash 复制代码
ansible 组名 -m file -a "path=/csdn/jingyu state=touch"
bash 复制代码
- name: 创建一个文件
  file:
    path: /csdn/jingyu
    state: touch
    mode: '0755'

在/csdn目录下创建一个jingyu文件。(如果不存在,则创建,如果已存在则不会创建。)

mode是设置文件的权限0755给予所有者读写执行权限,组用户和其他用户只有读和执行权限。

2、创建目录

使用file模块的state参数设置为directory可以创建文件。例如:

bash 复制代码
ansible 组名 -m file -a "path=/csdn/jingyu state=directory mode=0755"
bash 复制代码
- name: Ensure the directory exists
  file:
    path: /csdn/jingyu
    state: directory
    mode: '0755'

在/csdn目录下创建一个jingyu目录。(如果不存在,则创建,如果已存在则不会创建。)

mode是设置文件的权限0755给予所有者读写执行权限,组用户和其他用户只有读和执行权限。

3、修改文件权限:

  • owner: 设置文件的所有者用户名。
  • group: 设置文件的所属组名。
  • mode: 设置文件的权限。
bash 复制代码
- name: Change file permissions and ownership
  file:
    path: /csdn/jingyu
    owner: jingyu
    group: root
    mode: '0644'

修改/csdn/jingyu文件属性属主是jingyu;属组是root,文件权限是0644.给于所有者读写权限,组和其他用户都是读权限。

其他参数

  • recurse: 当与state: directory一起使用时,递归地更改目录内所有文件和子目录的属性。
  • srcdest: 在复制文件时使用,类似于copy模块,但只用于属性管理,不涉及内容复制。
  • selevel, serole, setype, seuser: 用于设置SELinux上下文。
  • src: 指定原始文件或目录的路径,即软链接指向的目标。
  • dest: 指定要创建的软链接的路径。
  • state: link 表示要创建一个软链接。如果已有同名文件或链接存在,Ansible会根据情况更新或创建链接以指向新的src路径。
bash 复制代码
ansible jingyu -m file -a "src=/csdn/jingyu dest=/media/jingyu state=link"
bash 复制代码
- name: Create a symbolic link
  file:
    src: /csdn/jingyu
    dest: /media/jingyu
    state: link

将/csdn目录下的jingyu文件或者目录创建软连接到客户机的/media目录下名称是jingyu。

5**、创建软连接hard**

  • src: 指定原始文件或目录的路径,即软链接指向的目标。
  • dest: 指定要创建的软链接的路径。
  • state: hard 表示要创建一个硬链接。如果已有同名文件或链接存在,Ansible会根据情况更新或创建链接以指向新的src路径。
bash 复制代码
ansible jingyu -m file -a "src=/csdn/jingyu dest=/media/jingyu state=hard"
bash 复制代码
- name: Create a symbolic link
  file:
    src: /csdn/jingyu
    dest: /media/jingyu
    state: hard

将/csdn目录下的jingyu文件或者目录创建硬连接到客户机的/media目录下名称是jingyu。

相关推荐
企鹅侠客2 小时前
Ansible 流程控制
ansible·ansible流程控制
小叶子来了啊3 天前
千锋教育Ansible自动化运维实战教程从入门到精通
运维·自动化·ansible
Johny_Zhao3 天前
阿里云Ansible自动化运维平台部署
linux·人工智能·ai·信息安全·云计算·ansible·shell·yum源·系统运维·itsm
xbd_zc5 天前
【Ansible自动化运维实战:从Playbook到负载均衡指南】
运维·自动化·ansible·负载均衡
#暖瓶7 天前
基于openEuler系统利用 Kolla-Ansible 工具多节点安装OpenStack平台
ansible·openstack
杨凯凡7 天前
Linux批量管理:Ansible自动化运维指南
linux·运维·服务器·自动化·ansible
好的明天qaz10 天前
Ansible安装配置
ansible
xbd_zc10 天前
【Vagrant+VirtualBox创建自动化虚拟环境】Ansible测试Playbook
linux·ubuntu·自动化·ansible·虚拟机·vagrant·virtualbox
Linux运维老纪10 天前
Ansible 铸就 Linux 安全之盾(Ansible Builds Linux Security Shield)
linux·服务器·网络·安全·云计算·ansible·运维开发
AquaPluto25 天前
Ansible-Playbook详解
ansible·playbook·roles