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 matching
  links                   => # How to handle links during file actions.  During
  mode                    => # 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]#