puppet (二)

五.模板应用(添加虚拟主机)node

文件存放在 templates 目录中,以*.erb 结尾mysql

1. vim /etc/puppet/modules/httpd/manifests/init.ppnginx

 

wKioL1fQJTOj1-hiAADocCHvTrM880.png 

 

2.vim /etc/puppet/modules/httpd/templates/httpd_vhost.erbc++

wKiom1fQJTeB3icRAAB7llR--_w319.png 

 

3.vim /etc/puppet/manifests/nodes/server3.ppweb

wKioL1fQJTiQtzStAACAYd8q2EM214.png 

 

4.修改配置文件 vim /etc/puppet/modules/files/httpd.confsql

wKiom1fQJTnDNOkqAAAOv5k0Frg852.png 

5.测试 (记得添加虚拟主机的解析)数据库

Client:puppet agent --server server1.example.com --no-daemonize -vtvim

wKioL1fQJTqjmFtGAAA2qLIFgbQ141.png 

wKiom1fQJTyBTlzUAAA3_EjT_cM874.png 

 

 

六.以web的方式管理puppet ( puppet-dashboard )ruby

1.安装软件服务器

server

wKioL1fQJT2Q1Wd2AAA7wcgTsb8594.png 

yum install -y puppet-dashboard-1.2.12-1.el6.noarch.rpm rubygem-rake-0.8.7-2.1.el6.noarch.rpm ruby-mysql-2.8.2-1.el6.x86_64.rpm

 

注意:

 

wKiom1fQJUKSX44oAAD_hJdrl2c676.png 

 

2.建立数据库

mysql -pwestos -e  "create database dashboard_production character set utf8 "

mysql -pwestos  -e "create user dashboard@localhost identified by 'westos' "

mysql -pwestos -e "grant all on dashboard_production.* to dashboard@localhost "

 

 

3.修改配置服务

server :

 

vim /usr/share/puppet-dashboard/config/database.yml

------ 只留下生产环境配置

wKioL1fQJUOAl9PtAABPaekdTy0277.png 

 

cd /usr/share/puppet-dashboard/config

rake RAILS_ENV=production db:migrate

------ 创建 dashboard 所需的数据库和表

wKioL1fQJUTzXdnvAAB0Aw7p7f8118.png 

rake time:zones:local

----- 查看本地支持的时区

wKiom1fQJUXCcWatAABRpDINVi4180.png 

puppet-dashboard 默认时区不正确,须要修改:

vim  /usr/share/puppet-dashboard/config/settings.yml

wKiom1fQJUbAm_tDAAAkKBGliQk867.png 

 

4.启动服务

/etc/init.d/puppet-dashboard start

wKioL1fQJUfAXyPjAABfIlDivAA540.png 

chmod 666 /usr/share/puppet-dashboard/log/production.log

/etc/init.d/puppet-dashboard-workers start

wKiom1fQJUfx77vDAABULLMFIlU721.png 

5.实时报告汇总:

server :

vim /etc/puppet/puppet.conf

wKioL1fQJUngMCLqAAA1TypZYKs210.png 

/etc/init.d/puppetmaster reload

 

 

Client :

vim /etc/puppet/puppet.conf

wKioL1fQJUqzq8trAAASG8raMyM716.png 

puppet agent --server server1.example.com --no-daemonize -vt

 

访问 172.25.23.3:3000

若配置文件没有改变,则刷新后可看到绿色部分unchanged增长

wKiom1fQJU2DbfnCAAC4XI9eNlE636.png 

若修改了配置文件,则蓝色部分changed增长

点击server3.example.com -> Recent reports -> log 可看到日志

wKiom1fQJVLTD0EJAAEfB5stIrU197.png 

 

 

 

6.在客户端安装完 puppet 后,而且认证完后,咱们能够看到效果,那怎样让它自动与服务器同步呢?默认多少分钟跟服务器同步呢?怎样修改同步的时间呢,这时候咱们须要配置客户端

(1) 配置 puppet 相关参数和同步时间:

vim /etc/sysconfig/puppet

PUPPET_SERVER=puppet.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 reload

 

 

七.nginx+passenger

puppet 默认使用基于 Ruby 的 WEBRickHTTP 来处理 HTTPS 请求,单个服务器使用Apache/Nginx+Passenger 替换掉 WEBRickHTTP,Passenger 是用于将 Ruby 程序进行嵌入执行的Apache 模块,实现对 puppet 的负载均衡。

wKioL1fQJVOxQaDfAABVwUVDpAQ361.png 

 

gem install rack passenger

wKiom1fQJVPiPZrtAABFVEQc8HE934.png 

 

yum install -y gcc gcc-c++ curl-devel zlib-devel openssl-devel ruby-devel

 

passenger-install-nginx-module

wKiom1fQJVrgUjH7AAEiit9lfv4523.png 

 

确保全部的都是yes,为no的则退出,安装相应软件

 

wKioL1fQJZajFgvLAAEBFpFwS14982.png 

 

脚本会自动安装 nginx 支持,按提示操做,基本就是一路回车,除了上图所示

 

 

vim /opt/nginx/conf/nginx.conf

 

wKioL1fQJZeChQG8AAA6XgA-A1c404.png 

......

wKiom1fQJaHC8kDeAAFObGz9cus980.png 

 

mkdir /etc/puppet/rack/{public,tmp} -p

cp /usr/share/puppet/ext/rack/config.ru /etc/puppet/rack/

chown puppet.puppet /etc/puppet/rack/config.ru

/etc/init.d/puppetmaster stop

/opt/nginx/sbin/nginx -t

/opt/nginx/sbin/nginx

puppetmaster 不须要启动 , nginx 启动时会自动调用 puppet。

 

wKiom1fQJaSS5LyVAAA7uaaI_Ko169.png

相关文章
相关标签/搜索