博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实战Puppet 集中配置管理系统(3)——Puppet dashboard与nginx+passenger安装配置
阅读量:6999 次
发布时间:2019-06-27

本文共 4120 字,大约阅读时间需要 13 分钟。

     本次实验内容紧接前两次实验,第一节内容主要介绍PUPPET的安装认证与资源定义,第二节主要写apache与nginx模块的应用,本次介绍Puppet dashboard与nginx+passenger 的安装,Puppet dashboard 是用以 web 方式管理 puppet。puppet 默认使用基于 Ruby 的WEBRickHTTP 来处理 HTTPS 请求,单个服务器使用Apache/Nginx+Passenger 替换掉 WEBRickHTTP,Passenger 是用于将 Ruby 程序进行嵌入执行的

上次实验内容:

     

     

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

#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//只留下生产环境配置

#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';

# 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'

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

#/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//同步数据

9) 浏览器访问 172.25.254.1:3000 

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 的负载均衡。

参考:

1)[root@server1 mnt]# gem list

*** LOCAL GEMS ***

json (1.5.5)

rack (1.6.4)

2)不够就下载

# gem install passenger-5.0.15.gem rack-1.6.4.gem

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

4) #passenger-install-nginx-module

  //脚本会自动安装 nginx 支持,按提示操作,其它按Enter就好,编译过程比较慢

 

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

# cd /opt/nginx/conf/

# /etc/init.d/puppetmaster stop

# vim nginx.conf

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;

}

# /opt/nginx/sbin/nginx -t //检测 nginx配置文件是否有错

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让客户端获取信息,可以看到获取不到信息

# /opt/nginx/sbin/nginx   ###开启nginx,可以看到客户端可以获取到信息

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

转载地址:http://vjevl.baihongyu.com/

你可能感兴趣的文章
《Groovy极简教程》第7章 Groovy与Gradle
查看>>
Java并发编程:底层实现机制
查看>>
matlab 与数据库操作
查看>>
Vuex 最简单有效的使用
查看>>
前端设计-css网格布局的最佳实践
查看>>
用WijmoJS玩转您的Web应用 —— Ionic
查看>>
Intellij IDEA创建Android项目异常
查看>>
过滤器应用【编码、敏感词、压缩、转义过滤器】
查看>>
JAVA IO流 字节流 字符流 缓冲流的注意点和效率
查看>>
球迷快来领福利!NBA国王队推出粉丝AR应用
查看>>
会投影的智能手表LumiWatch,可在手臂自由地滑动并控制其中的应用
查看>>
如何编写linux下nand flash驱动-2
查看>>
关于防刷票的一些问题
查看>>
蚂蚁金服图像定损「暖科技」升级,以后人人都能成为定损员!
查看>>
机器人与人工智能界的新动向:专业型孵化加速器时代到来
查看>>
AMD 宣布与阿里巴巴合作,瞄准企业云端运算需求
查看>>
菜鸟又出手!家里没人也能收包裹,这个黑科技还获过阿里内部大奖
查看>>
大都会人寿全球首推VR客服平台
查看>>
Alibaba Java Coding Guidelines
查看>>
当东方遭遇西方,机器人们都在谈什么?
查看>>