实战Puppet 集中配置管理系统(3)——Puppet dashboard与nginx+passenger安装配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

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

wKiom1gYbK3R4O4XAABPwDVWRH0643.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'

wKioL1gYbR_Bdd67AAAKiVndm08398.png

wKiom1gYbUCQBE8bAABgzb4bqwo461.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

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

wKiom1gYblDTGd7jAABQpMcA8UY820.png

wKioL1gYbm-T6NhWAABRCAAbWwA264.png


9) 浏览器访问 172.25.254.1:3000 

wKioL1gYbsvwr-LrAAEZYUhT1T0178.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)[root@server1 mnt]# gem list

*** LOCAL GEMS ***

json (1.5.5)

rack (1.6.4)

wKiom1gYcoaw-Fg6AAAWV4DT4Lo998.png

2)不够就下载

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

wKioL1gYdtviCFfCAACDWGosQmM410.png


wKiom1gYdtrygdr4AAAfaU5B7j8437.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

wKiom1gYebHhbJ3NAABD-b_GrjU102.png


4) #passenger-install-nginx-module

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

 wKioL1gYekrTHr9TAACyAlTC1C4866.png


wKiom1gYekmS10AkAAA_a_wFHTY509.png


wKiom1gYe6DjHU-mAAD-HEgtb8c210.png


wKioL1gYe5-BdxJ-AAAmD9u86iY639.png


wKiom1gYe5-ANi82AAAjv2r9Wy4635.png


wKioL1gYe57T_8nAAABWFD46_F0638.png


wKiom1gYe57yt5-lAABS9Vz8E8E045.png


wKiom1gYfQ_gaDNUAAChD_uWI3c328.png


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

# cd /opt/nginx/conf/

# /etc/init.d/puppetmaster stop

# vim nginx.conf

wKioL1gYfrqj-ghrAACJ2TBDfg0801.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;

}

wKioL1gYhP-zwde-AACT2cDU0Cc102.png

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

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

wKioL1gYhYnjDLCoAAEEdhX9LwA162.png

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

wKiom1gYhgSCeno0AABVI2jWnmo060.png

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

wKiom1gYhsaSVzahAABiW6Mazsk626.png


本文转自willis_sun 51CTO博客,原文链接:http://blog.51cto.com/willis/1868229,如需转载请自行联系原作者

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
2月前
|
编解码 应用服务中间件 Linux
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
298 1
|
6月前
|
应用服务中间件 Linux 网络安全
Centos 8.0中Nginx配置文件和https正书添加配置
这是一份Nginx配置文件,包含HTTP与HTTPS服务设置。主要功能如下:1) 将HTTP(80端口)请求重定向至HTTPS(443端口),增强安全性;2) 配置SSL证书,支持TLSv1.1至TLSv1.3协议;3) 使用uWSGI与后端应用通信(如Django);4) 静态文件托管路径设为`/root/code/static/`;5) 定制错误页面(404、50x)。适用于Web应用部署场景。
720 87
|
6月前
|
负载均衡 应用服务中间件 nginx
Nginx配置与命令
Nginx 是一款高性能的 HTTP 和反向代理服务器,其配置文件灵活且功能强大。本文介绍了 Nginx 配置的基础结构和常用指令,包括全局块、Events 块、HTTP 块及 Server 块的配置方法,以及静态资源服务、反向代理、负载均衡、HTTPS 和 URL 重写等功能实现。此外,还提供了常用的 Nginx 命令操作,如启动、停止、重载配置和日志管理等,帮助用户高效管理和优化服务器性能。
|
2月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
257 18
|
2月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
322 17
|
3月前
|
数据建模 应用服务中间件 PHP
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
本示例演示如何通过Docker挂载同一宿主目录至Nginx与PHP容器,实现PHP项目运行环境配置。需注意PHP容器中监听地址修改为0.0.0.0:9000,并调整Nginx配置中fastcgi_pass指向正确的IP与端口。同时确保Nginx容器中/var/www/html权限正确,以避免访问问题。
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
|
4月前
|
应用服务中间件 网络安全 nginx
配置Nginx以支持Websocket连接的方法。
通过上述配置,Nginx将能够理解WebSocket协议的特殊要求,代理Websocket流量到合适的后端服务器。注意,Websocket并不是HTTP,尽管它最初是通过HTTP请求启动的连接升级,因此保证Nginx了解并能够妥善处理这种升级流程是关键。
1088 10
|
3月前
|
Ubuntu 应用服务中间件 Linux
在Ubuntu上配置Nginx实现开机自启功能
至此,Nginx应该已经被正确地设置为开机自启。在Ubuntu中利用 `systemd`对服务进行管理是一种高效的方式,为系统管理员提供了强大的服务管理能力,包括但不限于启动、停止、重启服务,以及配置服务的开机自启动。通过这些简洁的命令,即使是对Linux不太熟悉的用户也能轻松地进行配置。
179 0
|
5月前
|
安全 应用服务中间件 网络安全
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
360 0
Nginx SSL/TLS协议栈中配置深度解析与实践指南-优雅草卓伊凡
|
5月前
|
JSON 前端开发 应用服务中间件
配置Nginx根据IP地址进行流量限制以及返回JSON格式数据的方案
最后,记得在任何生产环境部署之前,进行透彻测试以确保一切运转如预期。遵循这些战术,守卫你的网络城堡不再是难题。
251 3

推荐镜像

更多