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

[经验分享] Puppet–SSH自动化管理

[复制链接]

尚未签到

发表于 2015-9-16 10:41:58 | 显示全部楼层 |阅读模式

  创建ssh模块相应的目录和文件




[iyunv@master ~]# mkdir -p /etc/puppet/modules/ssh/{manifests,templetes,files}

  前面sudo模块的时候,所有相关的设置都是在init.pp文件中,但再SSH模块中我们尝试着将配置分为init.pp,install.pp,config.pp,service.pp,params.pp。


  创建配置相应文件



[iyunv@master ~]# touch /etc/puppet/modules/ssh/manifests/{install.pp,config.pp,service.pp}

  配置params.pp文件,该文件主要是配置模块的参数



[iyunv@master ~]# vim /etc/puppet/modules/ssh/manifests/params.pp
class ssh::params {
case $operatingsystem {
Solaris: {
$ssh_package_name ='openssh'
$ssh_service_config='/etc/ssh/sshd_config'
$ssh_service_name='sshd'
}

/(Ubuntu|Debian)/: {
$ssh_package_name='openssh-server'
$ssh_service_config='/etc/ssh/sshd_config'
$ssh_service_name='sshd'
}

/(RedHat|CentOS|Fedora)/: {
$ssh_package_name='openssh-server'
$ssh_service_config='/etc/ssh/sshd_config'
$ssh_service_name='sshd'
}
}
}

  编辑ssh模块的init.pp文件



[iyunv@master ~]# vim /etc/puppet/modules/ssh/manifests/init.pp

class ssh{
include ssh::params,ssh::install,ssh::config,ssh::service
}

  编辑install.pp



[iyunv@master ~]# vim /etc/puppet/modules/ssh/manifests/install.pp
class ssh::install {
package {"$ssh::params::ssh_package_name":
ensure=>installed,
}
}

  编辑config.pp



[iyunv@master ~]# vim /etc/puppet/modules/ssh/manifests/config.pp
class ssh::config{
file { $ssh::params::ssh_service_config:
ensure=>present,
owner=>'root',
group=>'root',
mode=>0600,
source=>"puppet://$puppetserver/modules/ssh/sshd_config",
require=>Class["ssh::install"],
notify=>Class["ssh::service"],
}
}

  Notify在这里是发出通知到对应的类,即如果ssh:config改变了,就notify通知ssh::service类。


  编辑service.pp



[iyunv@master ~]# vim /etc/puppet/modules/ssh/manifests/service.pp

class ssh::service{
service{ $ssh::params::ssh_service_name:
ensure=>running,
hasstatus=>true,
hasrestart=>true,
enable=>true,
require=>Class["ssh::config"],
}
}

  设置hasstatus告诉puppet该服务支持status命令,即类似service sshd status


  设置hasrestart告诉puppet该服务支持restart命令,即类似service sshd restart


  复制默认的sshd_config文件到模块的files目录下



[iyunv@master ~]# cp /etc/ssh/sshd_config   /etc/puppet/modules/ssh/files/

  Ssh模块设置完成,下面是将该模块应用到节点上


  编辑nodes.pp



[iyunv@master ~]# vim /etc/puppet/manifests/nodes.pp

class base {
include sudo,ssh
}

node 'client1.centos' {
include base
}

node 'client2.centos' {
include  base
}

  到节点上验证配置是否正确



[iyunv@client1 ~]# puppetd   --server  master.puppet --test
notice: Ignoring --listen on onetime run
info: Caching catalog for client1.centos
info: Applying configuration version '1330052716'
--- /etc/ssh/sshd_config        2011-12-08 04:25:10.000000000 +0800
+++ /tmp/puppet-file20120224-27947-1eierk0-0    2012-02-24 11:06:15.203891553 +0800
@@ -1,3 +1,4 @@
+# puppet auto configuration
#      $OpenBSD: sshd_config,v 1.80 2008/07/02 02:24:18 djm Exp $

# This is the sshd server system-wide configuration file.  See
info: FileBucket adding {md5}853a26a0f4b8a7fc8529e45ed57fe67b
info: /Stage[main]/Ssh::Config/File[/etc/ssh/sshd_config]: Filebucketed /etc/ssh/sshd_config to puppet with sum 853a26a0f4b8a7fc8529e45ed57fe67b
notice: /Stage[main]/Ssh::Config/File[/etc/ssh/sshd_config]/content: content changed '{md5}853a26a0f4b8a7fc8529e45ed57fe67b' to '{md5}4a860a0861932b44d8af13e64d953b39'
info: /Stage[main]/Ssh::Config/File[/etc/ssh/sshd_config]: Scheduling refresh of Service[sshd]
notice: /Stage[main]/Ssh::Service/Service[sshd]: Triggered 'refresh' from 1 events
notice: Finished catalog run in 0.81 seconds

运维网声明 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-114364-1-1.html 上篇帖子: puppet使用 apache passsenger 作为前端 (debian) 下篇帖子: puppet使用 apache passsenger 作为前端 (centos)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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