设为首页 收藏本站
查看: 3870|回复: 0

[经验分享] puppet常用资源类型与使用方法

[复制链接]

尚未签到

发表于 2018-8-1 12:37:15 | 显示全部楼层 |阅读模式
通用
  1、puppet describe -l   查看puppet支持的资源类型
  puppet describe  typename  查看某个资源类型的Parameters,Providers--详细
  puppet describe  -s  typename  -m  查看某个资源的参数等--简单
  2、puppet apply  [-d|--debug] [-v|--verbose] [-e|--execute] [--noop] <file>
  puppet help apply  查看帮助
  puppet apply  -v   查看详情
  -d   调试模式
  -l 保存在指定文件中
  --noop  干跑,不执行
一、group:
  1、Manage groups
  属性:
  name:组名;
  gid:GID;
  system:是否为系统组,true OR false;
  ensure:目标状态,present/absent;
  members:成员用户;
  2、例子:创建组
  (1) vim group.pp
  group{'mygrp':
  ensure => present
  }
  (2)执行
  puppet apply -v  --noop  group.pp 先看看是否有错
  puppet apply -v group.pp  真正执行
二、user
  1、Manage users.
  属性:
  name:用户名;
  uid: UID;
  gid:基本组ID;
  groups:附加组,不能包含基本组;
  comment:注释;
  expiry:过期时间 ;
  home:家目录;
  shell:默认shell类型;
  system:是否为系统用户 ;
  ensure:present/absent;
  password:加密后的密码串;
  2、例子:创建用户
  (1)用户名为user2,不写name。默认是跟title一直,都是user2
  vim user.pp
  user{'user2':
  ensure => present,
  uid => 1021,
  groups => 'redhat',
  }
  (2)执行
  puppet apply  -v  --noop user.pp
  puppet apply  -v   user.pp
三、package
  1、Manage packages.
  属性:
  ensure:installed, present, latest, absent, any version string (implies present)
  name:包名;
  source:程序包来源,仅对不会自动下载相关程序包的provider有用,例如rpm或dpkg;
  provider:指明安装方式;
  2、例子:安装包
  安装memcached包
  package{'memcached':
  ensure => installed,
  }
四、service
  1、Manage running services.
  属性:
  ensure:Whether a service should be running. Valid values are stopped (also called false), running (also called true)
  enable:Whether a service should be enabled to start at boot. 开机启动Valid values are true, false, manual.
  name:
  path:The search path for finding init scripts.  Multiple values should be separated by colons or provided as an array. 脚本的搜索路径,默认为/etc/init.d/;
  hasrestart:true |false   false :init 脚本中的restart命令将不能用,使用stop ,start,默认false
  hasstatus:true|false   stasus 命令是否使用
  start:手动定义启动命令;
  stop:
  status:
  restart:Specify a restart command manually.  If left unspecified, the service will be stopped and then started. 通常用于定义reload操作;
  2、例子:安装包并启动服务
  package{'memcached':
  ensure => installed,
  }
  service{'memcached':
  ensure => running,
  enable => false,
  }
五、file
  1、Manages files, including their content, ownership, and permissions. 管理文件,包括它们的内容、所有权和权限。
  ensure:Whether the file should exist, and if so what kind of file it should be. Possible values are present, absent, file, directory, and link.
  file:类型为普通文件,其内容由content属性生成或复制由source属性指向的文件路径来创建;
  link:类型为符号链接文件,必须由target属性指明其链接的目标文件;
  directory:类型为目录,可通过source指向的路径复制生成,recurse属性指明是否递归复制;
  path:文件路径;
  source:源文件;
  content:文件内容;
  target:符号链接的目标文件;
  owner:属主
  group:属组
  mode:权限;
  atime/ctime/mtime:时间戳;
  2、例子
  (1)例子1:将'/root/manifects/files/redis.conf 的文件复制到/tmp/redis.conf
  file{'/tmp/redis.conf':
  ensure => file,
  source => '/root/manifects/files/redis.conf',
  }
  (2)例子2:基于内容复制
  将hello
  hi  内容给/tmp/test.txt
  file{'/tmp/test.txt':
  ensure => file,
  content => &quot;hello\nhi\n&quot;,
  }
六、exec
  1、Executes external commands. Any command in an exec resource must be able to run multiple times without causing harm --- that is, it must be idempotent.
  command (namevar):要运行的命令;
  cwd:The directory from which to run the command.
  creates:文件路径,仅此路径表示的文件不存在时,command方才执行;
  user/group:运行命令的用户身份;
  path:The search path used for command execution. Commands must be fully qualified if no path is specified.
  onlyif:此属性指定一个命令,此命令正常(退出码为0)运行时,当前command才会运行;
  unless:此属性指定一个命令,此命令非正常(退出码为非0)运行时,当前command才会运行;
  refresh:重新执行当前command的替代命令;
  refreshonly:仅接收到订阅的资源的通知时方才运行;
  2、例子
DSC0000.jpg

  (1)指定包为redis
  (2)指定复制的文件,并修改复制后文件的所属人owner,所属组root,权限的0640
  (3)除非pidof redis-server  不成功才执行上面的命令,重启服务(以守护进程方式启动)
  (4)->   代表依赖关系,~> 代表触发
七、cron
  1、Installs and manages cron jobs.  Every cron resource created by Puppet requires a command and at least one periodic attribute (hour, minute, month, monthday, weekday, or special).
  command:要执行的任务;
  ensure:present/absent;
  hour:
  minute:
  monthday:
  month:
  weekday:
  user:以哪个用户的身份运行命令
  target:添加为哪个用户的任务
  name:cron job的名称;
  2、例子:每3分钟同步一次服务器时间
  cron{'timesync':
  command => '/usr/sbin/ntpdate 172.16.0.1 &> /dev/null',
  ensure  => present,
  minute  => '*/3',
  user    => 'root',
  }
八、notify
  1、Sends an arbitrary message to the agent run-time log.  向代理运行时日志发送任意消息。
  属性:
  message:信息内容
  name:信息名称;
  核心类型:
  group: 组
  user:用户
  packge:程序包
  service:服务
  file:文件
  exec:执行自定义命令,要求幂等
  cron:周期性任务计划
  notify:通知
  官方地址:
  https://docs.puppet.com/puppet/5.2/cheatsheet_core_types.html#notify/
  2、例子:
  当redis的配置文件改变了,会重启服务
DSC0001.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-544791-1-1.html 上篇帖子: linux运维学习之自动化运维工具Puppet-Linux运维 下篇帖子: Puppet自动化管理(1)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表