自动化运维管理平台-Puppet资源管理

简介:

当我们配置完毕puppet相关信息时,我们需要更近一步来部署puppet真正应用,那puppet怎么使用呢?希望帮助到初学的朋友,一起交流和学习,欢迎大家分享!

 
  1. Puppet常用资源:  
  2.  
  3. 常用的资源主要有以下几个:  
  4.  
  5. file:主要负责管理文件  
  6.  
  7. package:软件包的安装管理   
  8.  
  9. service:系统服务的管理     
  10.  
  11. cron:配置自动任务计划    
  12.  
  13. exec:远程执行运行命令  
  14.  
  15. 更多资源详细资料,可参见:http://puppet.wikidot.com  
  16.  
  17. 写一个默认配置:vi  /etc/puppet/manifests/site.pp  
  18.  

一、File资源:

 
  1. file {  
  2.  "/tmp/test.txt":  
  3.  content => "hello";  
  4.   }  
  5.  
  6. 意思是在/tmp新建一个test.text文件,文件内容为hello。  
  7.  

二、Package资源:

 
  1. package {  
  2.  
  3.  ["screen","ntp"]:  
  4.  ensure => "installed";  
  5.  
  6.  "pppoe":  
  7.  ensure => "absent";  
  8.   }  
  9.  
  10. 定义的意思是yum install screen 和ntp服务,并且卸载pppoe安装包。  
  11.  

三、Service资源:

 
  1. service {    
  2.  "sshd":    
  3.  ensure => running;    
  4.  "nfs":    
  5.  ensure => stopped;    
  6.    
  7.   }    
  8.    
  9. 意思是定义启动sshd服务,停止nfs服务。 

四、 Cron资源:

 
  1. cron{  
  2.  "ntpdate":  
  3.   command => "/usr/sbin/ntpdate pool.ntp.org",  
  4.   user => root,  
  5.   hour => 0,  
  6.   minute => 0,  
  7.   }  
  8.  
  9. 意思是在客户端写入一个计划任务:0 0  * * *  /usr/sbin/ntpdate pool.ntp.org 自动同步时间!  
  10.  

五、向客户端推送本地脚本:

 
  1. 首先修改vi /etc/puppet/fileserver.conf 文件,添加如下三行:  
  2.  
  3. [files]  
  4. path  /etc/puppet/files  
  5. allow *  
  6.  
  7. 然后cp所需要的脚本到 /etc/puppet/files目录,没有这个目录则新建!  
  8.  
  9. file {  
  10.    "/tmp/nginx_install.sh":  
  11.    source => "puppet://master.puppet.com/files/nginx_install.sh",  
  12.    group => root,  
  13.    owner => root,  
  14.    mode => "755"  
  15. }   
  16.  
  17. 意思是把 /etc/puppet/files/nginx_install.sh这个脚本推送到客户端的/tmp/下!  
  18.  

六、Exec远程执行脚本:

如第五步,我们把nginx_install.sh推送过去后,这时候我们就可以执行了如下:

 
  1. exec {  
  2.   "/tmp/nginx_install.sh":  
  3.   cwd => "/tmp",  
  4.   user => root,  
  5.   path => ["/usr/bin","/usr/sbin","/bin","/bin/sh"],  
  6.   }  
  7.  

这样的配置后,你可以在客户端测试,测试结果已经自动安装完nginx!如下结果

 
  1. [root@master tmp]# puppetd --server=master.puppet.com --test  
  2. info: Caching catalog for master.puppet.com  
  3. info: Applying configuration version '1337450399'  
  4. notice: /Stage[main]//Node[default]/Exec[/tmp/nginx_install.sh]/returns: executed successfully  
  5. notice: Finished catalog run in 49.96 seconds  
  6.  
  7. 但是这里有个地方需要注意,这每次同步都会执行这个脚本,所以我们要设置一个参数,如果nginx_install.sh有更新才执行:  
  8.  
  9. exec {  
  10.   "/tmp/nginx_install.sh":  
  11.   cwd => "/tmp",  
  12.   user => root,  
  13.   path => ["/usr/bin","/usr/sbin","/bin","/bin/sh"],  
  14.  
  15.   subscribe => File["/tmp/nginx_install.sh"],  
  16.  
  17.   refreshonly => true;   
  18.     
  19.   }  
  20.  

七、执行命令:

 
  1. ###更新sysctl.conf  
  2.        file { "/etc/sysctl.conf":  
  3.    source =>     "puppet://master.puppet.com/files/sysctl.conf",  
  4.        owner => "root",  
  5.        group => "root",  
  6.        mode => 644,  
  7.         }  
  8.     
  9.  
  10. exec {  
  11.       "sysctl refresh kernel config":  
  12.        path => ["/usr/bin", "/usr/sbin", "/bin", "/sbin"],  
  13.        command  => "/sbin/sysctl -p",  
  14.        subscribe => File["/etc/sysctl.conf"],  
  15.        refreshonly => true  
  16.      }  
  17.  

有更新才在客户端执行!如果没有更新则不执行!

更深入的moudules配置、更多资源等内容后期不断更新!



本文转自 wgkgood 51CTO博客,原文链接:http://blog.51cto.com/wgkgood/869767

相关文章
|
5月前
|
数据采集 运维 监控
爬虫与自动化技术深度解析:从数据采集到智能运维的完整实战指南
本文系统解析爬虫与自动化核心技术,涵盖HTTP请求、数据解析、分布式架构及反爬策略,结合Scrapy、Selenium等框架实战,助力构建高效、稳定、合规的数据采集系统。
1011 62
爬虫与自动化技术深度解析:从数据采集到智能运维的完整实战指南
|
6月前
|
运维 监控 自动驾驶
低代码运维平台:是“运维福音”,还是“甩手掌柜”?
低代码运维平台:是“运维福音”,还是“甩手掌柜”?
195 29
|
6月前
|
运维 Linux 网络安全
自动化真能省钱?聊聊运维自动化如何帮企业优化IT成本
自动化真能省钱?聊聊运维自动化如何帮企业优化IT成本
216 4
|
8月前
|
运维 监控 安全
从实践到自动化:现代运维管理的转型与挑战
本文探讨了现代运维管理从传统人工模式向自动化转型的必要性与路径,分析了传统运维的痛点,如效率低、响应慢、依赖经验等问题,并介绍了自动化运维在提升效率、降低成本、增强系统稳定性与安全性方面的优势。结合技术工具与实践案例,文章展示了企业如何通过自动化实现运维升级,推动数字化转型,提升业务竞争力。
|
9月前
|
运维 监控 Linux
WGCLOUD运维平台的分布式计划任务功能介绍
WGCLOUD是一款免费开源的运维监控平台,支持主机与服务器性能监控,具备实时告警和自愈功能。本文重点介绍其计划任务功能模块,可统一管理Linux和Windows主机的定时任务。相比手动配置crontab或Windows任务计划,WGCLOUD提供直观界面,通过添加cron表达式、执行指令或脚本并选择主机,即可轻松完成任务设置,大幅提升多主机任务管理效率。
|
机器学习/深度学习 人工智能 运维
机器学习+自动化运维:让服务器自己修Bug,运维变轻松!
机器学习+自动化运维:让服务器自己修Bug,运维变轻松!
492 14
|
存储 人工智能 运维
阿里云操作系统控制台评测:国产AI+运维 一站式运维管理平台
本文详细评测了阿里云操作系统控制台,作为一款集运维管理、智能助手和系统诊断于一体的工具,它为企业提供了高效管理云资源的解决方案。文章涵盖登录与服务开通、系统管理与实例纳管、组件管理与扩展功能、系统诊断与问题排查以及实时热点分析与性能优化等内容。通过实际操作展示,该平台显著提升了运维效率,并借助AI智能助手简化了复杂操作。建议进一步完善组件库并增强第三方兼容性,以满足更多高级运维需求。
802 2
|
人工智能 运维 负载均衡
智能运维新时代:AI在云资源管理中的应用与实践
智能运维新时代:AI在云资源管理中的应用与实践
1205 23
|
机器学习/深度学习 人工智能 运维
基于AI的自动化事件响应:智慧运维新时代
基于AI的自动化事件响应:智慧运维新时代
600 11

推荐镜像

更多