当client数量越来越多的情况下,但puppetmaster是无法满足需求的,会导致较高的失败率,类似如time out之类的,这时候就可以做成master群集。步骤如下:
1、相信到了这一步,基本的puppetmaster之类的包肯定都安装完毕了,做成集群还需要一个特殊的包:rubygem-mongrel,安装yum install rubygem-mongrel
2、编辑/etc/sysconfig/puppetmaster,添加下面2行
PUPPETMASTER_PORTS=( 18141 18142 18143 18144 )
PUPPETMASTER_EXTRA_OPTS="--servertype=mongrel --ssl_client_header=HTTP_X_SSL_SUBJECT"
3、下载安装nginx
wget
tar -zxf nginx-0.8.47.tar.gz&&cd nginx-0.8.47
./configure --with-pcre --with-http_realip_module --with-http_sub_module --with-http_stub_status_module --with-http_ssl_module --prefix=/usr/local/nginx && make && make install
4、修改/usr/local/nginx/conf/nginx.conf如下:
user www; worker_processes 5;
error_log /home/logs/nginx/error.log info; pid /home/logs/nginx/nginx.pid;
events { use epoll; worker_connections 65535; }
http {
# include mime.types;
log_format main '$remote_addr - $remote_user [$time_local] "$request" $request_length $request_time $time_local' '$status $body_bytes_sent $bytes_sent $connection $msec "$http_referer" ' '"$http_user_agent" $http_x_forwarded_for $upstream_response_time $upstream_addr $upstream_status ';
sendfile on; tcp_nopush on;
keepalive_timeout 60; tcp_nodelay on; upstream puppet { server 127.0.0.1:18141; server 127.0.0.1:18142; server 127.0.0.1:18143; server 127.0.0.1:18144; }
server { listen 8140; root /etc/puppet; ssl on; ssl_session_timeout 5m; ssl_certificate /var/lib/puppet/ssl/certs/sys.puppetmaster.com.pem; ssl_certificate_key /var/lib/puppet/ssl/private_keys/sys.puppetmaster.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; # File sections
location /production/file_content/files/ { types { } default_type application/x-raw; alias /etc/puppet/manifests/files/; } # Modules files sections
location ~ /production/file_content/modules/.+/ { root /etc/puppet/modules; types { } default_type application/x-raw; rewrite ^/production/file_content/modules/(.+)/(.+)$ /$1/files/$2 break; } # Ask the puppetmaster for everything else
location / { proxy_pass http://puppet; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Client-Verify $ssl_client_verify; proxy_set_header X-SSL-Subject $ssl_client_s_dn; proxy_set_header X-SSL-Issuer $ssl_client_i_dn; proxy_buffer_size 10m; proxy_buffers 1024 10m; proxy_busy_buffers_size 10m; proxy_temp_file_write_size 10m; proxy_read_timeout 120; } access_log /home/logs/nginx/puppet.access.log main;
} }
|
5、启动nginx sh /etc/init.d/nginx start
6、启动puppetmaster service puppetmaster start
如果你的client还是很多,还可以做到把puppetmaster和fileserver分开,很简单,再找台server搭个master,需要注意的是/var/lib/puppet的内容要和master一致,我是做了个rsync的定时同步的。但是fileserver貌似不能做成nginx+master的集群,会报认证失败,有待继续研究。
阅读(2224) | 评论(1) | 转发(0) |