puppet 部署
admin
2023-02-27 23:02:20
0

1 修改每个主机的主机名和hosts文件

192.168.0.13 master
192.168.0.14 slave
vim /etc/hostname #修改主机名
slave
vim /etc/hosts #增加DNS解析
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.0.13 master
192.168.0.14 slave
192.168.0.16 web1.yang.com #提供静态资源的服务器
192.168.0.19 proxy1.yang.com #反代服务器

2.安装master端,agent端

yum install epel-release.noarch -y
yum install puppet-server.noarch
#记得启动 systemctl restart pupetmaster
安装agent端
yum install puppet -y
vim /etc/puppet/puppet.conf #修改agent端配置,加入以下配置
server = master #指定服务器的主机名,记住ping 下测试能不能正常解析到服务器IP
runinterval = 10 #每隔10s 刷新一次

3.证书认证

agent端运行
puppet agent --test --server master #向master主机发送证书请求

master端
puppet cert list --all        # 查看所有证书
puppet cert list               #只看未签发的
puppet cert sign --all      #签发所有未签发的 
puppet cert sign slave    #只签发名为"slave"的证书
puppet cert clean slave #吊销指定的客户端的证书,并删除与其相关的所有文件
rm -rf  /var/lib/puppet/ssl/ #这个文件夹是agent端存放证书的,前面服务器端先吊销证书,这边客户端在删除存放证书的文件夹,在重新申请,已达到重新申请的效果
自动签发
方法一
在/etc/puppet下新加配置文件autosign.conf,将要自动签发的域名写入该文件
vim /etc/puppet/autosign.conf
*.xxx.com
方法二
vim /etc/puppet/puppet.conf
autosign = true
补充
ll /var/lib/puppet/ssl/ca/requests
#服务器端查看请求证书 (这个文件夹是未签的证书)
ll /var/lib/puppet/ssl/ca/signed/
#服务器端查看已经签署的证书(这个文件夹是已签的证书)
/var/lib/puppet/ssl/
#agent端证书位置,如果需要换证书将里面的内容全部删除重新想server发申请即可

4.pp文件的解释

puppet 部署

manifests --size.pp :这个文件是导航文件,用于匹配用户调用类的
vim /etc/puppet/manifests/site.pp
node default{
#默认匹配,表示只要证书被签发的,都会下发下面的类
     include nginx
         #调用名为nginx的类
}
node /web[0-9]+\.yang\.com/{
#正则匹配,表示匹配主机名以web开头的后面带数字的且后面是.yang.com 才下发下面的类 我用来匹配"web1.yang.com"的
     include web
}
node /proxy[0-9]+\.yang\.com/{
#正则匹配,表示匹配主机名以proxy开头的后面带数字的且后面是.yang.com 才下发下面的类
     include proxy
}

puppet 部署

modules:这个文件夹是存放模块的,我建立三个模块,nginx  proxy  web,nginx被默认"node default"所调用,作用是用来安装nginx程序包的
vim /etc/puppet/modules/nginx/manifests/init.pp
class nginx {
#注意,类名要和文件夹名一致,否则无法被size.pp 文件调用
      package {"nginx":
      ensure=> present,
              }
            }
web是被"node /web[0-9]+\.yang\.com/"所调用,用来修改nginx配置文件的
class web($nginx_port="8080"){
#先定义一个变量
      file{'/etc/nginx/nginx.conf':
            #复制客户机的那个路径::wq
      ensure => file,
      content => template('/etc/puppet/modules/web/files/nginx.conf'),
            # 模板文件的位置,该模块内部的files文件夹就是用来存放模板文件的
      owner => 'root',
      group => 'root',
      mode => '0644',
          }
    }

puppet 部署

配置文件的重点就是 默认的80端口,替换成了<%= @proxy_port %> ,在复制的过程当中会被替换成刚才前面定义的8080
proxy是被"node /proxy[0-9]+\.yang\.com/"所调用,也是用来修改nginx配置文件的不过这边复制的反代的模板,配置和上面web 差不多

5.测试

agent端默认请求资源时间是30分钟等不了,可用 puppet agent -t 手动请求资源
puppet 部署
#可以看到nginx已经被安装了,这个是第一个模块"nginx",安装的
puppet 部署
#打开nginx的配置文件可以看到,这边端口已经被替换成了8080,这是第二个模块"web"产生的效果

相关内容

热门资讯

中国第一台高能加速器:北京正负... 感谢IT之家网友 的线索投递! 5 月 7 日消息,中国科学院高能物理研究所今日官宣,2026 年...
最强计算组合刷新大分子模拟纪录 量子计算机最具前景的应用方向之一,就是模拟蛋白质,助力新药研发。但眼下这类设备误差率仍然偏高。据英国...
贵州高校借力“中国天眼”勇攀科... “中国天眼”(FAST)。 新华社记者 欧东衢 摄 4月8日,遵义师范学院青年教师吴庆东以第一作者身...
Claude牵手马斯克,调用限... 智东西 作者 | 程茜 编辑 | 李水青 智东西5月7日报道,今日凌晨,Anthropic在开发者大...
男子称爷爷30年前向天津美院捐... 5月6日,天津康先生反映,1996年他爷爷捐赠40件书画到天津美术学院,如今部分书画去向不明。
寒武纪股价再成A股最贵,半导体... 一方面,受益于AI产业发展,不少半导体公司业绩上涨;另一方面,美股半导体的上涨也带动了A股行情 文|...
OpenAI两大劲敌联手!马斯... AIPress.com.cn报道 奥特曼今晚能安然入睡吗? 就在刚刚,OpenAI的两大死对头美美牵...
原创 张... 文|唐辰 图|网络资料 张一鸣也没有余粮了么? 这两天,“豆包 付费”的话题持续高热,因为豆包要收费...
陈毓川院士逝世!他带领数千人干... ◎ 科技日报记者 操秀英5月6日,中国工程院院士,著名矿床地质学家陈毓川永远停下了跋涉的脚步,享年9...
利用中国国民党主席郑丽文形象的... 【大河财立方消息】 5月7日消息,上海证监局日前开出行政处罚决定书,对上海雷根资产管理有限公司实际控...