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

[经验分享] 实战Puppet 集中配置管理系统(3)——Puppet dashboard与nginx+passen...

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-11-2 08:49:29 | 显示全部楼层 |阅读模式
实战Puppet 集中配置管理系统(3)——Puppet dashboard与nginx+passenger安装配置
   本次实验内容紧接前两次实验,第一节内容主要介绍PUPPET的安装认证与资源定义,第二节主要写apache与nginx模块的应用,本次介绍Puppet dashboard与nginx+passenger 的安装,Puppet dashboard 是用以 web 方式管理 puppet。puppet 默认使用基于 Ruby 的WEBRickHTTP 来处理 HTTPS 请求,单个服务器使用Apache/Nginx+Passenger 替换掉 WEBRickHTTP,Passenger 是用于将 Ruby 程序进行嵌入执行的

上次实验内容:

     实战Puppet 集中配置管理系统(1)——认证与资源定义

     实战Puppet 集中配置管理系统(2)——apache与nginx模块配置


1 . Puppet dashboard安装配置
1)所需软件包
  puppet-dashboard-1.2.23-1.el6.noarch.rpm
        ruby-mysql-2.8.2-1.el6.x86_64.rpm
        rubygem-rake-0.8.7-2.1.el6.noarch.rpm

  依赖性:
  * Ruby 1.8.7
  * RubyGems
  * Rake >= 0.8.3
  * MySQL server 5.x
  * Ruby-MySQL bindings 2.7.x or 2.8.x
2)安装
    #yum install puppet-dashboard-1.2.23-1.el6.noarch.rpm
       ruby-mysql-2.8.2-1.el6.x86_64.rpm rubygem-rake-0.8.7-2.1.el6.noarch.rpm -y
wKioL1gYa3HhIt_oAAAgaqvr1x8628.png
#mysql 5.1 遇到的信息包过大问题 用客户端导入数据的时候,遇到错误代码: 1153 - Got a
packet bigger than 'max_allowed_packet' bytes 终止了数据导入,可以使用如下参数解决:
(rhel6.3 上未遇到)
# vi /etc/my.cnf
[mysqld]
max_allowed_packet = 32M#添加此行

3)配置 mysql 数据库
# /etc/init.d/mysqld start
# mysql_secure_installation设置root密码为willis

# cd /usr/share/puppet-dashboard/
# vim config/database.yml//只留下生产环境配置
wKiom1gYbB-CWWAlAAAgiSa2DBg354.png

wKiom1gYbB_wBsPvAAAv-Bnu6LU170.png
#vim config/add.sql

CREATE DATABASE dashboard_production CHARACTER SET utf8;
CREATE USER 'dashboard'@'localhost' IDENTIFIED BY 'willis';
GRANT ALL PRIVILEGES ON dashboard_production.* TO 'dashboard'@'localhost';
wKioL1gYbR_Bdd67AAAKiVndm08398.png
# rake RAILS_ENV=production db:migrate
  //建立 dashboard 所需的数据库和表

4)修改puppet-dashboard 默认时区
#//查看puppet-dashboard 默认支持的时区
#rake gems:refresh_specs
#rake time:zones:local
# vim /usr/share/puppet-dashboard/config/settings.yml
      //puppet-dashboard 默认时区不正确,需要修改
    time_zone: 'Beijing'
wKiom1gYbUCQBE8bAABgzb4bqwo461.png
wKiom1gYbcDA4whcAAAr_8PA5oA968.png

5)启动服务
#/etc/init.d/puppet-dashboard start

6)修改日志文件权限
# cd /usr/share/puppet-dashboard/log
#chmod 666 /production.log
#/etc/init.d/puppet-dashboard-workers start

7)修改服务器的配置文件
# vim /etc/puppet/puppet.conf
[main]//添加以下两项
reports = http
reporturl = http://172.25.254.1:3000/reports
wKiom1gYblDTGd7jAABQpMcA8UY820.png
#/etc/init.d/puppetmaster restart

8)设置 client 端
      server2与server3同时设置如下

#vim /etc/puppet/puppet.conf
[agent]//添加以下行
report = true

# puppet agent --server server1.example.com --no-daemonize -vt//同步数据
wKioL1gYbm-T6NhWAABRCAAbWwA264.png
wKioL1gYbsvwr-LrAAEZYUhT1T0178.png

9) 浏览器访问 172.25.254.1:3000
wKioL1gYdtviCFfCAACDWGosQmM410.png


10)在客户端安装完 puppet 后,并且认证完后,我们可以看到效果,那怎样让它自动与服务器同步呢?默认多少分钟跟服务器同步呢?怎样修改同步的时间呢,这时候我们需要配置客户端:
<1>配置 puppet 相关参数和同步时间:
# vim /etc/sysconfig/puppet
PUPPET_SERVER=server1.example.com    #puppet master 的地址
PUPPET_PORT=8140    #puppet 监听端口
PUPPET_LOG=/var/log/puppet/puppet.log    #puppet 本地日志
#PUPPET_EXTRA_OPTS=--waitforcert=500 【默认同步的时间,我这里不修改这行参数】
<2>默认配置完毕后,客户端会半个小时跟服务器同步一次,我们可以修改这个时间
# vim /etc/puppet/puppet.conf
[agent]
runinterval = 60//代表 60 秒跟服务器同步一次

#/etc/init.d/puppet start

2.nginx+passenger 安装配置

Apache 模块,实现对 puppet 的负载均衡。
参考:https://docs.puppetlabs.com/guides/passenger.html

1)[iyunv@server1 mnt]# gem list
*** LOCAL GEMS ***
json (1.5.5)
rack (1.6.4)
wKiom1gYdtrygdr4AAAfaU5B7j8437.png
2)不够就下载
# gem install passenger-5.0.15.gem rack-1.6.4.gem
wKiom1gYebHhbJ3NAABD-b_GrjU102.png

wKioL1gYekrTHr9TAACyAlTC1C4866.png

3) # yum install -y gcc gcc-c++ curl-devel zlib-devel openssl-devel ruby-devel
# tar zxf nginx-1.8.0.tar.gz -C /mnt

wKiom1gYekmS10AkAAA_a_wFHTY509.png

4) #passenger-install-nginx-module
  //脚本会自动安装 nginx 支持,按提示操作,其它按Enter就好,编译过程比较慢
wKiom1gYe6DjHU-mAAD-HEgtb8c210.png

wKioL1gYe5-BdxJ-AAAmD9u86iY639.png

wKiom1gYe5-ANi82AAAjv2r9Wy4635.png

wKioL1gYe57T_8nAAABWFD46_F0638.png

wKiom1gYe57yt5-lAABS9Vz8E8E045.png

wKiom1gYfQ_gaDNUAAChD_uWI3c328.png

wKioL1gYfrqj-ghrAACJ2TBDfg0801.png

wKioL1gYhP-zwde-AACT2cDU0Cc102.png

5) nginx 默认安装在/opt/nginx 目录:
# cd /opt/nginx/conf/

# /etc/init.d/puppetmaster stop
# vim nginx.conf
wKioL1gYgG3TReodAAAiJgVP1cY031.png
server {
        listen       8140;
        server_name  server1.example.com;

        root    /etc/puppet/rack/public;
        passenger_enabled on;
        passenger_set_header X_CLIENT_DN $ssl_client_s_dn;
        passenger_set_header X_CLIENT_VERIFY $ssl_client_verify;

        ssl on;
        ssl_session_timeout 5m;
        ssl_certificate /var/lib/puppet/ssl/certs/server1.example.com.pem;
        ssl_certificate_key /var/lib/puppet/ssl/private_keys/server1.example.com.pem;
        ssl_client_certificate /var/lib/puppet/ssl/ca/ca_crt.pem;
        ssl_crl /var/lib/puppet/ssl/ca/ca_crl.pem;
        ssl_verify_client optional;
        ssl_ciphers SSLv2:-LOW:-EXPORT:RC4+RSA;
        ssl_prefer_server_ciphers on;
        ssl_verify_depth 1;
        ssl_session_cache shared:SSL:128m;
}
wKioL1gYhYnjDLCoAAEEdhX9LwA162.png
# /opt/nginx/sbin/nginx -t //检测 nginx配置文件是否有错
wKiom1gYhgSCeno0AABVI2jWnmo060.png

6)添加目录
# cd /etc/puppet/
# mkdir /etc/puppet/rack/{public,tmp}  -p
# cd rack/
# cp /usr/share/puppet/ext/rack/config.ru /etc/puppet/rack/
# chown puppet.puppet /etc/puppet/rack/config.ru
# /etc/init.d/puppetmaster stop
#chkconfig puppetmaster off
# /opt/nginx/sbin/nginx//启动nginx
    //puppetmaster 不需要启动 , nginx 启动时会自动调用 puppet。

7) 测试
# /opt/nginx/sbin/nginx stop   #关闭nginx让客户端获取信息,可以看到获取不到信息
wKiom1gYhsaSVzahAABiW6Mazsk626.png
# /opt/nginx/sbin/nginx   ###开启nginx,可以看到客户端可以获取到信息

#ps -ax   ###查看进程启动情况




运维网声明 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-294529-1-1.html 上篇帖子: 实战Puppet 集中配置管理系统(2)——apache与nginx模块配 下篇帖子: puppet权威指南pdf完整版带目录免费下载 (无需金币)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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