puppet使用file资源可以对文件进行管理,可以对文件的内容、权限等管理。


定义一个资源,需要指定资源的类型和资源的title。


file资源语法:

file {"/puppet/file/abc":name=> "/puppet/file/abc",content=>"test\n",owner=> root,mode=> 777;
}

第一行:指定资源是file类型

第二行:资源title,默认是与name的值一样。


执行后,会在/puppet/file目录下面创建abc文件,内容:test(换行),属于root用户,文件权限:777


file类型:

http://docs.puppetlabs.com/references/latest/type.html#file


file { 'resource title':path                    => # (namevar) The path to the file to manage.  Must be fully...ensure                  => # Whether the file should exist, and if so what...backup                  => # Whether (and how) file content should be backed...checksum                => # The checksum type to use when determining...content                 => # The desired contents of a file, as a string...ctime                   => # A read-only state to check the file ctime. On...force                   => # Perform the file operation even if it will...group                   => # Which group should own the file.  Argument can...ignore                  => # A parameter which omits action on files matchinglinks                   => # How to handle links during file actions.  Duringmode                    => # The desired permissions mode for the file, in...mtime                   => # A read-only state to check the file mtime. On...owner                   => # The user to whom the file should belong....provider                => # The specific backend to use for this `file...purge                   => # Whether unmanaged files should be purged. This...recurse                 => # Whether and how to do recursive file management.recurselimit            => # How deeply to do recursive management.  Values...replace                 => # Whether to replace a file or symlink that...selinux_ignore_defaults => # If this is set then Puppet will not ask SELinux...selrange                => # What the SELinux range component of the context...selrole                 => # What the SELinux role component of the context...seltype                 => # What the SELinux type component of the context...seluser                 => # What the SELinux user component of the context...show_diff               => # Whether to display differences when the file...source                  => # A source file, which will be copied into place...source_permissions      => # Whether (and how) Puppet should copy owner...sourceselect            => # Whether to copy all valid sources, or just the...target                  => # The target for creating a link.  Currently...type                    => # A read-only state to check the file...validate_cmd            => # A command for validating the file's syntax...validate_replacement    => # The replacement string in a `validate_cmd` that...# ...plus any applicable metaparameters.
}



ensure=>values
present:文件不存在,会自动创建
absent:删除存在的文件
directory:创建一个目录
link:链接文件


(file资源的文件,需要前面的路径是存在的,如下面的/puppet/file目录是存在的)

1、创建普通文件

在puppet/file目录创建文件名:1,内容为当前操作系统名称。

注:若是创建新文件,只要content有值,那么可以不需要ensure=>present。

file {"/puppet/file/1":ensure=>present,content => $operatingsystem,owner => root,mode => 644;
}

2、创建目录


file {"/puppet/file/mulu":ensure=>directory,mode=>644;
}


3、创建链接


file {"/puppet/file/link":ensure=>link,target=>"/etc/passwd";
}

4、删除文件

file {"/puppet/file/1":ensure=>absent,content => $operatingsystem,owner => root,mode => 644;
}




客户端可以直接运行本地manifest,命令:puppet apply -l /var/log/puppet/a.log 1.pp


[root@pclient test]# puppet apply -l /var/log/puppet/a.log 1.pp
Puppet apply 运行本地manifests
/var/log/puppet/ 这个目录是在/etc/puppet.conf配置  a.log自定义




执行后查看/var/log/puppet/a.log看到以下日志

Mon Apr 14 15:54:58 +0800 2014 Puppet (notice): Compiled catalog for pclient.onepc.com in environment production in 0.12 seconds
Mon Apr 14 15:54:59 +0800 2014 /Stage[main]/Main/File[/puppet/file/1]/ensure (notice): created
Mon Apr 14 15:54:59 +0800 2014 /Stage[main]/Main/File[/puppet/file/link]/ensure (notice): created
Mon Apr 14 15:54:59 +0800 2014 /Stage[main]/Main/File[/puppet/file/mulu]/ensure (notice): created
Mon Apr 14 15:54:59 +0800 2014 Puppet (notice): Finished catalog run in 0.11 seconds


[root@pclient file]# ll
总用量 8
-rw-r--r-- 1 root root    6  4月 14 15:54 1
lrwxrwxrwx 1 root root   11  4月 14 15:54 link -> /etc/passwd
drwxr-xr-x 2 root root 4096  4月 14 15:54 mulu
[root@pclient file]#