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

[经验分享] puppet-10846468

[复制链接]

尚未签到

发表于 2018-8-2 07:27:54 | 显示全部楼层 |阅读模式
  运维工具
  puppet rubby开放 支持多平台 c/s构架 可管理配置文件,cron任务 图形化配置
  saltstack  python开发
  ansible实现批量操作系统配置,程序部署,命令执行 python开发
  puppet的安装和配置
  修改主机名 把ip+主机名添加到hosts文件中
  写计划任务:crontab -e :*/10 * * * * ntpdate time.windows.com
  安装puppet源rpm -ivh “http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm”
  rpm -ivh puppetlabs-release-6-7.noarch.rpm --force --nodeps
  服务端:chkconfig puppetmaster on     yum -y install puppet-server
  客服端:listen = true,server =服务器名,runinterval=30(服务器与客服端更新时间)   chkconfig puppet on   yum -y install puppet
  配置认证  让两者之间信任
  客服端:puppet agent --test --server 信任服务端名    客服端生成ssl证书
  puppet agent --verbose --no-daemonize 测试是否同步与更新
  服务端:查看已认证客服端列表 puppet cert list --all      puppet cert sign 客服端名 服务端指定客服端证书
  puppet cert clean 客服端删除指定客服端证书     puppet cert clean --all 删除所有证书
  puppet agent --test --server 信任服务端名    客服端生成ssl证书
  删除认证客服端后必须删除/var/lib/puppet/ssl/*下的所有证书 重启后才能生成新的证书
  puppet配置自动签发证书
  1 删除所有的以前配置
  2 在服务端配置文件中加入 autosign=true
  3.vi /etc/puppet/autosign.conf    ======= *.*   允许所有的用户名
  4 重启服务   查看认证。
  puppet证书测试。
  vi /etc/puppet/manifests/site.pp
  node default {        定义所有的类
  file { "/tmp/1.txt":   文件目录
  content =>"test,test";}}    文件内容
  重启服务
  puppet安装和配置---定义模块管理  模块--<<类--<<资源
  1,在./etc/puppet/modules 下创建名为testm的模块  mkdir /etc/puppet/modules/testm
  2. 在testm目录下创建三个目录:files 存放文件目录 manifests模块的主配置文件 templates 模板与配置文件
  3.  vi /etc/puppet/modules/manifests/init.pp   编译一个初始模块
  class testm{     定义类名testm 随意定义
  file {"/tmp/cisco.txt":定义在客服端创建的文件名
  owner => "root", 属主
  group =>"root",属组
  mode =>0400, 权限
  source=>"puppet://$puppetserver/modules/testm/cisco.txt" 获取资源的目录
  }}
  这是新建目录的方式:也可以在上一目录下
  class test{  定义类 可以自定义。随意。
  file {"/usr/apache":
  owner => "root", 属主
  group =>"root",属组
  mode =>0400, 权限
  source=>"puppet://$puppetserver/modules/test/apache",
  recurse =>true,递归查询
  purge => true 文件同步
  }
  }
  说明:类名字也叫做testm, 类下面定义了一个资源file,文件名字叫做/tmp/cisco.txt ,owner,group,mode定义文件的属主、数组以及权限,source定义这个文件从哪里获取。 $puppetserver一会也要定义一下,这里指的是puppet server服务器上/etc/puppet/modules/testm/files/1.txt
  vi /etc/puppet/manifests/site.pp
  $puppetserver='主服务器名‘
  node 客服端名 {
  include testm   定义客服端需要加载的模块名
  include test
  }
  说明:$puppetserver 定义服务端的主机名,node后面为客户端的主机名,这里面定义该客户端要加载的模块
  配置完成后,在客户端执行命令:puppet agent --test  --server=master.aming.com   //如果客户端上启动了puppet服务,不用执行这命令,它也会自动同步的上面的模块其实只是同步了一个文件而已,
  那么要想同步一个目录如何做?我们可以通过实现同步一个目录来做一个包发布系统。 比如在一台机器上编译安装好了apache,那么就可以通过这样的模块把这个apache目录整个分发到其他机器上。
  远程执行命令
  exec {"aaa" 执行命令的名字
  unless => "test -f /tmp/1.txt", 判断是否有这文件
  onlyif => "test -f /tmp/1.txt",   只有文件存在时或是一个文件才去创建
  path => ["/usr","/sbin","/usr/bin"], 定义一个环境变量
  command => "touch /tmp/1.txt"  如判断无文件 就创建文件
  }
  说明:unless后面的命令作为一个条件,当条件成立时,不会执行下面的命令,如果想要条件成立时,执行下面的命令,用 onlyif。要注意的是,我们一定要给执行的这条命令加个条件,使用unless就可以,必须满足这个条件才能执行命令,否则这个命令会一直执行,不太妥当。
  puppet的任务计划
  cron {"linux":
  command =>"/sbin/ntpdate time.windows.com",
  user => "root",
  minute => "*/5",
  monthday =>"1-10",
  #ensure => "sbsent"
  }
  puppet的几种模块下的类:
  module目录下建立一个模块:
  puppet模块下的文件
  files(用于下载文件)
  manifests(用于存放puppet的配置)包含的配置文件(init.pp管理模块所有pp文件配置,config.pp.server.pp,site.pp,install.pp,params.pp)
  templates(用于存放模块,方便pp调用))在

运维网声明 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-545001-1-1.html 上篇帖子: puppet补充--搭建lnmp 以及dashboard,passenger 下篇帖子: Puppet -->Language: Basics
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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