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

[经验分享] puppet学习之使用git实现puppet版本控制

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-7-23 08:34:04 | 显示全部楼层 |阅读模式
本文通过创建用户资源的例子介绍为多台agent同时添加用户账户、git仓库的创建、puppet加入git仓库、通过远程管理主机管理配置文件及文件版本的回滚处理。
一、系统环境
系统平台:Centos6.6_x86_64
主机规划:
192.168.115.21   puppet1.hnr.com  master
192.168.115.22   puppet2.hnr.com  agent
192.168.115.23   puppet3.hnr.com  agent
192.168.115.24   puppet4.hnr.com  远程管理主机

二、准备环境
实现agent端自动添加指定的用户
1.服务端上配置
创建user模块,模块目录为user,user类里有一个user资源目的是在agent主机上创建一个指定uid的用户
# mkdir -p/etc/puppet/modules/user/{manifests,templates,files}
# vi /etc/puppet/modules/user/manifests/init.pp
class user {
    user { 'hnr':
            ensure => present,
            uid => '520',
    }
}
# mkdir  /etc/puppet/manifests/nodes
在nodes目录下创建客户端文件
wKioL1WvYieAuOp8AADXqZO3ANQ236.jpg

wKioL1WvYkLwmnCpAADYzl8Eanc109.jpg
修改site.pp文件
# vi /etc/puppet/manifests/site.pp
import "nodes/*.pp"
2.客户端puppet2上运行如下命令
wKioL1WvYm3gEJJCAAJg7zwao7M620.jpg
此时,在客户端puppet2上已经创建好hnr用户
puppet默认30分钟会推送数据到客户端上,从日志上可以看出数据已经推送到puppet3上
wKiom1WvYJeSNmE9AAhpAuBQxrI447.jpg

三、git实现puppet版本控制
在puppet服务器上配置
1.安装配置git
# yum install git-daemon git
2.初始化puppet服务端git仓库
创建puppet repo目录
# mkdir -p /data/git/puppet.git
创建git仓库
# cd /data/git/puppet.git
# git --bare init
启动git,为了远程管理主机连接
# git-daemon --base-path=/data/git --detach --listen=0.0.0.0 --export-all --enable=receive-pack --enable=upload-pack --enable=upload-archive
wKioL1WvYqKxZeWjAAD0uOnoX6o154.jpg

3.将puppet加入git
将puppet master上的/etc/puppet目录加入仓库
# cd /etc
仓库克隆过程目录下的数据会删除,所以事先将/etc/puppet目录下的数据备份到/tmp目录下
# mv puppet/* /tmp/puppet
# git clone git://127.0.0.1/puppet.git
# cd /etc/puppet
# cp /tmp/puppet/* .
# git add *
# git commit -m "Add puppet to git repo"
wKiom1WvYM3imXcKAAX4TmGu11A822.jpg
# git push -u origin master
wKiom1WvYNzSZerNAAIDpePICKI915.jpg
仓库已创建好,包含了puppet的配置文件及清单

4.在管理主机创建副本,在/tmp目录下创建
# cd /tmp/
# git clone git://192.168.115.21/puppet.git
wKiom1WvYOzgbXwCAAHhLFn3ds4954.jpg
至此,管理主机上git仓库副本已经创建完成
修改文件并提交,增加一个testpuppet用户指定shell为/bin/sh
# vi /tmp/puppet/modules/user/manifests/init.pp
wKiom1WvYPeiAmv6AAGnX-b0wDo047.jpg
修改完后提交
# git add /tmp/puppet/modules/user/manifests/init.pp
# git commit -m "add a testpuppet user"
wKiom1WvYQPBNBxQAAQGEfJMBMc827.jpg
# git push
wKiom1WvYSSgwCAvAAGVGwce3m8727.jpg
5.在puppet master的/etc/puppet目录下
# git pull
wKiom1WvYTTiX5L3AAJUXilsXEs834.jpg

6.在puppet2客户端上执行如下命令
wKioL1WvYyjQcrDAAAIBKUeNXcw461.jpg

wKioL1WvYzfQr2OFAAEJKZ-n0gg464.jpg
至此,puppet2上已经创建好testpuppet用户

四、文件版本回滚
1.创建标签
# git tag -m 'first release' 1.0.0
wKioL1WvY2DRuNjCAAF0QrGHAkw703.jpg
2.修改文件,增加一个用户test2puppet
wKiom1WvYYizHPyuAAGr4vUhh6w261.jpg
# git add modules/user/manifests/init.pp
# git commit -m "add test2puppet user"
# git push
3.服务端上也执行了git pull,然后回滚至1.0.0版本
wKiom1WvYZuCYaBqAAM4pAXEBKg276.jpg
此时,查看文件发现test2puppet用户已经没有
wKioL1WvY47xFqmgAAFCAAfxSvk082.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-89625-1-1.html 上篇帖子: linux安装curl、git、ruby、mysql、postgreSQL、OpenSSL、Redis、ImagMagck、RubyGems、Bundler 下篇帖子: 使用git管理nodejs+socket.io+redis+juicer+waterfall+ubuntu+aws ec2开发网站
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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