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

[经验分享] puppet结合SVN版本控制系统实现版本的集中化备份与恢复

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-6-9 08:39:32 | 显示全部楼层 |阅读模式
一、介绍通过安装部署Puppet C/S模型,实现Puppet Server端管理所有被控制机的整个生命周期:从初始化到软件升级、从配置文件创建到测试部署、从系统维护到服务器迁移等。Puppet能够持续化的与被控制机进行交互,从而实现配置文件的及时检测更新。结合SVN版本控制系统,puppet可在更新之前将当前正在运行的环境以版本的方式保存到SVN版本控制系统中,方便以后通过puppet更新出错或者需要回滚到之前的某一个环境时快速恢复。

二、环境介绍序号    服务器类型                     版本/IP参数 1    PuppetMaster         RHEL6.4 x86_64(192.168.100.110) 2    PuppetAgent             RHEL5.8 x86_64(192.168.100.111)和RHEL5.7 x86_64(192.168.100.112) 3    SVN Service端     RHEL6.4 x86_64(192.168.100.110) 4    SVN Service端     RHEL6.4 x86_64(192.168.100.110)和Windows 8.1 x86_64(192.168.100.2)编号      类型       主机名/软件名称    系统/软件版本                    其他信息 1    Software    Subversion        1.6.11-7    rpm                 package 2    Software    TortoiseSVN        1.8.2.24708-x64-svn-1.8.3        msi三、部署流程1 SVN Server端部署1.1 安装相关软件包
[iyunv@puppetserver ~]# yum install subversion[iyunv@puppetserver ~]# svnserve –version  #通过查看版本验证安装是否成功svnserve, version 1.6.11 (r934486)   compiled Apr 12 2012, 11:09:11Copyright (C) 2000-2009 CollabNet.Subversion is open source software, see http://subversion.tigris.org/This product includes software developed by CollabNet (http://www.Collab.Net/).The following repository back-end (FS) modules are available:* fs_base : Module for working with a Berkeley DB repository.* fs_fs : Module for working with a plain file (FSFS) repository.Cyrus SASL authentication is available.1.2 创建第一个版本库
[iyunv@puppetserver ~]# mkdir /svndata[iyunv@puppetserver ~]# svnadmin create /svndata/puppet[iyunv@puppetserver ~]# ll /svndata/puppet/total 24drwxr-xr-x 2 root root 4096 Oct 22 13:29 confdrwxr-sr-x 6 root root 4096 Oct 22 13:29 db-r--r--r-- 1 root root    2 Oct 22 13:29 formatdrwxr-xr-x 2 root root 4096 Oct 22 13:29 hooksdrwxr-xr-x 2 root root 4096 Oct 22 13:29 locks-rw-r--r-- 1 root root  229 Oct 22 13:29 README.txt2 通过Apache+ssl安全认证访问SVN服务器2.1    安装相关软件包
[iyunv@puppetserver ~]# yum install httpd httpd-devel mod_dav_svn2.2    创建SVN虚拟主机
[iyunv@puppetserver svndata]# vim /etc/httpd/conf.d/subversion.confLoadModule dav_svn_module     modules/mod_dav_svn.soLoadModule authz_svn_module   modules/mod_authz_svn.soListen 8142<VirtualHost *:8142><Location /svndata>DAV svnSVNListParentPath onSVNPath "/svndata/puppet"AuthType BasicAuthName "Subversion repository"AuthUserFile "/svndata/puppet/conf/authfile"#AuthzSVNAccessFile /svndata/puppet/conf/svn-acl-confRequire valid-userSVNAutoversioning onModMimeUsePathInfo on</Location></VirtualHost>2.3    创建svn权限配置文件
[iyunv@puppetserver svndata]# vim puppet/conf/authz  [groups]admin = puppet[admin:/]@admin = rw[/]* = r[$name:/]test = rw">>/svndata/puppet/conf/authz2.4    创建用户名及密码并设置相应权限[iyunv@puppetserver ~]# /usr/bin/htpasswd -c /svndata/puppet/conf/authfile puppet #创建SVN服务器账户puppet密码为redhatNew password: redhatRe-type new password: redhatAdding password for user puppet[iyunv@puppetserver ~]# chown apache /svndata/puppet -R[iyunv@puppetserver ~]# echo "puppet = redhat" >>/svndata/puppet/conf/passwd2.5    配置SVN服务信息
[iyunv@puppetserver svndata]# vim /svndata/puppet/conf/svnserve.conf [general] anon-access = noneauth-access = writepassword-db = /svndata/puppet/conf/passwdauthz-db = /svndata/puppet/conf/authzrealm = puppet Repository2.6    通过浏览器测试访问
[iyunv@puppetserver svndata]# /etc/rc.d/init.d/httpd restart #重启httpd服务http://192.168.100.110:8142/svndata/svn版本控制测试界面
svn版本控制测试界面
2.7    通过其他linux节点访问测试
[iyunv@agent1 ~]# svn checkout http://192.168.100.110:8142/svndata/  /mnt/Authentication realm: <http://192.168.100.110:8142> Puppet Subversion repositoryPassword for 'root': Authentication realm: <http://192.168.100.110:8142> Puppet Subversion repositoryUsername: puppet Password for 'puppet':-----------------------------------------------------------------------ATTENTION!  Your password for authentication realm:   <http://192.168.100.110:8142> Puppet Subversion repositorycan only be stored to disk unencrypted!  You are advised to configureyour system so that Subversion can store passwords encrypted, ifpossible.  See the documentation for details.You can avoid future appearances of this warning by setting the valueof the 'store-plaintext-passwords' option to either 'yes' or 'no' in'/root/.subversion/servers'.-----------------------------------------------------------------------Store password unencrypted (yes/no)? noChecked out revision 0.2.8    通过Windows客户端TortoiseSVN访问测试
svn版本控制测试界面
svn版本控制测试界面
svn版本控制测试界面
备注:由于还为import版本,所以查看的内容为空
3 整合puppet server端3.1    将puppet server模块目录导入到版本库中
[iyunv@puppetserver ~]# svn import /etc/puppet/environments/testinghttp://192.168.100.110:8142/svndata/puppet -m "Puppet Initial repository" Authentication realm: <http://192.168.100.110:8142> Puppet Subversion repositoryPassword for 'root': Authentication realm: <http://192.168.100.110:8142> Puppet Subversion repositoryUsername: puppetPassword for 'puppet': Adding         /etc/puppet/environments/testing/groupsAdding         /etc/puppet/environments/testing/groups/modulesAdding         /etc/puppet/environments/testing/groups/modules/grubAdding         /etc/puppet/environments/testing/groups/modules/grub/filesAdding         /etc/puppet/environments/testing/groups/modules/grub/manifests…Committed revision 1.备注:由于SVN服务器端和puppetserver在同一台服务器上,也可以通过以下方式进行导入
[iyunv@puppetserver ~]# svn import /etc/puppet/environments/testing  file:///svndata/puppet -m "Puppet Initial repository"3.2    通过IE浏览器访问SVN服务器
svn版本控制测试界面
3.3    通过Windows客户端TortoiseSVN checkout最新的版本库到本地
svn版本控制测试界面
svn版本控制测试界面
svn版本控制测试界面
3.4    删除puppetserver端testing目录,并将版本库中的数据导出
[iyunv@puppetserver ~]# cd /etc/puppet/environments/testing/[iyunv@puppetserver testing]# rm -rf *  #删除之前建议备份[iyunv@puppetserver testing]# svn checkouthttp://192.168.100.110:8142/svndata/puppet  /etc/puppet/environments/testing Authentication realm: <http://192.168.100.110:8142> Puppet Subversion repositoryPassword for 'puppet':Please type 'yes' or 'no': noA    groupsA    groups/modulesA    groups/modules/grubA    groups/modules/grub/filesA    groups/modules/grub/manifestsChecked out revision 1.[iyunv@puppetserver testing]# ls -a.  ..  agents  environment  groups  manifests  .svn[iyunv@puppetserver testing]# ls .svn/  #每个目录下面都会生成.svn隐藏目录,用于保存当前版本的信息all-wcprops  entries  prop-base  props  text-base  tmp备注:checkout之后,在/etc/puppet/environments/testing目录下就会有一份SVN服务器上最新版本的副本。4 部署SVN hooks4.1    设置pre-commit
设置pre-commit钩子可以提交文件到SNV服务器之前对puppet语法进行检查,语法通过则提交成功,语法错误则提交失败。
[iyunv@puppetserver hooks]# chmod 774 pre-commit^C[iyunv@puppetserver hooks]# cp pre-commit.tmpl pre-commit[iyunv@puppetserver hooks]# chmod 774 pre-commit [iyunv@puppetserver hooks]# vim pre-commit #!/bin/sh# SVN pre-commit hook to check Puppet syntax for .pp files# Modified from http://mail.madstop.com/pipermai ... -March/002034.html# Access http://projects.puppetlabs.com/p ... rsion_controlREPOS="$1"TXN="$2"tmpfile=`mktemp`export HOME=/SVNLOOK=/usr/bin/svnlook$SVNLOOK changed -t "$TXN" "$REPOS" | awk '/^[^D].*\.pp$/ {print $2}' | while read linedo    $SVNLOOK cat -t "$TXN" "$REPOS" "$line" > $tmpfile    if [ $? -ne 0 ]    then        echo "Warning: Failed to checkout $line" >&2    fi#    puppet --color=false --confdir=/etc/puppet --vardir=/var/lib/puppet --parseonly --ignoreimport $tmpfile >>/var/log/puppet/svn_pre-commit.log 2>&1    puppet --color=false --confdir=/etc/puppet --vardir=/var/lib/puppet --parser --ignoreimport $tmpfile >>/var/log/puppet/svn_pre-commit.log 2>&1    if [ $? -ne 0 ]    then        echo "Puppet syntax error in $line." >>/var/log/puppet/svn_pre-commit.log 2>&1        exit 2    fidoneres=$?rm -f $tmpfileif [ $res -ne 0 ]then    exit $resfi4.2    设置post-commit
设置post-commit钩子可以在正确提交文件至SVN服务器之后,puppetmaster的模块目录/etc/puppet/environments/testing会自动从SNV服务器上update最新的版本库到本地。
#!/bin/sh# POST-COMMIT HOOKREPOS="$1"REV="$2"#mailer.py commit "$REPOS" "$REV" /path/to/mailer.confexport LANG=en_US.UTF-8SVN=/usr/bin/svnPUPPET_DIR=/etc/puppet#/usr/bin/svn  up /etc/puppet -non-interactive$SVN  update $PUPPET_DIR --username puppet --password 123.com >>/var/log/puppet/svn_post-commit.log5 SVN Client端部署测试5.1    本地测试
1)导出版本数据库文件到本地
[iyunv@puppetserver ~]# svn checkout file:///svndata/puppet  /puppet/puppet2)、创建并添加新的目录及文件
[iyunv@puppetserver puppet]# svn add ssh3)、将修改后的文件提交到SVN服务器,此时版本库版本加1
[iyunv@puppetserver .svn]# svn commit -m "add ssh modules" /puppet/puppet/*5.2    远程测试(Linux)
[iyunv@agent1 svndata]#  svn checkout http://172.16.200.100/svndata/  /mnt/5.3    客户端TortoiseSVN测试(Windows)
svn-puppet-12.jpg svn版本控制测试界面
svn-puppet-13.jpg svn版本控制测试界面


运维网声明 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-75297-1-1.html 上篇帖子: puppet配置 下篇帖子: puppet结合SVN版本控制系统实现版本的集中化备份与恢复 控制系统
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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