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

[经验分享] 企业级自动化管理工具-Puppet

[复制链接]

尚未签到

发表于 2018-8-1 12:42:19 | 显示全部楼层 |阅读模式
2,user:  Manage users
  属性:
  name:用户名,/
  uid:UID,
  gid:基本组ID,
  groups:附加组,不能包含基本组,
  comment:注释,
  expiry:过期时间,
  home:家目录,
  shell:默认shell类型,
  system:是否为系统用户,
  ensure:present/absent,
  password:加密后的密码串,
  资源引用:
  Type;['']
  类型的首字母必须大写;
  关系元参数:before/require
  A before B:B依赖于A,定于在A资源中;
  {
  ...
  before  => Type['B'],
  ...
  }
  B require A: B依赖于A,定义在B资源中;
  {
  ...
  require => Type['A'],
  ...
  }
  3,Package:
  Manage package
  属性:
  ensure:installed,present,latest,absent,
  name:包名,
  source:程序包来源,仅对不会自动下载的相关程序包的privide有用,例如:rpm或dbkg
  provider:指明安装方式
  4,service
  puppet describe service -s -m :查看service资源的简单介绍
  Manage running service
  属性:
  ensure:running/true or stopped/false
  enable:ture or false
  name:
  path:脚本的搜索路径,默认为/etc/init.d
  hasrestart:
  hasstatus:
  start:手动定于启动命令,
  stop:
  status:
  restart:可自定义,通常用于定义reload操作
  5,file
  Manage files
  属性:
  ensure:present、absent、file、directory、link
  file:类型为普通文件,
  link:类型为符号链接文件,必须由target属性指明其链接的目标文件,
  directory:类型为目录,可通过source指向的路径复制生成,recurse属性指明是否是递归复制,
  path:文件路径,
  source:源文件,
  content:文件内容,
  target:符号链接的目标文件,
  owner:属主,
  group:属组,
  mode:权限,
  atime/ctime/mtime:时间戳
  资源有特殊属性:
  名称变量
  name可省略,此时将由title表示
  ensure:
  定义资源的目标状态
  元参数:metaparameters
  依赖关系:
  before
  require
  通知关系:通知相关的其他资源进行刷新操作
  notify
  A notify B:B依赖于A,且A发生改变后会通知B;
  {
  ...
  notify => Type['B'],
  ...
  }
  subscribe
  B subscribe A:B依赖于A,且B监控A资源的变化产生的事件;
  {
  ...
  subscribe => Type['A'],
  ...
  }
  示例:file{'test.txt':
  path => '/tmp/test.txt',
  ensure => file,
  source => '/etc/fstab',
  }
  file{'test.symlink':
  path => '/tmp/test.txt',
  ensure => link,
  target => '/tmp/test.txt'
  require => File['test.txt'],
  }
  file{'test.dir':
  path => '/tmp/test.dir',
  ensure => directory,
  source => '/etc/yum.repo.d/',
  recurse => true,
  }
  示例2:service{'httpd':
  ensure => running,
  enable => true,
  restart => 'systemctl restart httpd.service'
  }
  package{'httpd':
  ensure=>true,
  }
  file{'httpd.conf':
  path=>'/etc/httpd/conf/httpd.conf'
  source=>'/root/manifests/httpd.conf',
  ensure=>file,
  notify=>Service['httpd'],
  }
  Package['httpd']-> File['httpd.conf']->Service['httpd']
  6,exec:
  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:仅接收到订阅的资源的通知时方才运行;
  cron:
  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的名称;
  示例:
  cron{'timesync':
  command => '/usr/sbin/ntpdate 172.16.0.1 &> /dev/null',
  ensure  => present,
  minute  => '*/3',
  user    => 'root',
  }
  notify:
  Sends an arbitrary message to the agent run-time log.
  属性:
  message:信息内容
  name:信息名称;
  核心类型:
  group: 组
  user:用户
  packge:程序包
  service:服务
  file:文件
  exec:执行自定义命令,要求幂等
  cron:周期性任务计划
  notify:通知

运维网声明 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-544796-1-1.html 上篇帖子: Puppet的部署与应用(转) 下篇帖子: Puppet的安装和初配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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