自动化运维管理平台-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

相关文章
|
4月前
|
弹性计算 运维 监控
|
4月前
|
弹性计算 运维 监控
带你读《云上自动化运维宝典》——高弹性、高可用、低成本的云上资源管理最佳实践(1)
阿里云弹性计算技术专家高庆瑞主讲《高弹性、高可用、低成本的云上资源管理最佳实践》。
278 0
|
4月前
|
弹性计算 运维 安全
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(1)
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(1)
401 0
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(1)
|
4月前
|
SQL 弹性计算 运维
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(2)
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(2)
252 1
|
4月前
|
运维 监控 安全
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(3)
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(3)
413 1
带你读《云上自动化运维宝典》——一文读懂云上大规模资源管理的最佳实践(3)
|
存储 资源调度 Kubernetes
企业级运维之云原生与Kubernetes实战课程 - 第二章第3讲 Kubernetes调度和资源管理
本小节主要内容为Pod调度和资源管理,包括Pod调度过程、资源源调度和关系调度、调度相关的配置和使用、K8s组件控制器、SVC创建及使用、Pod生命周期管理及Kubectl常用命令和使用技巧。
企业级运维之云原生与Kubernetes实战课程 - 第二章第3讲 Kubernetes调度和资源管理
OushuDB 管理指南之资源管理(下)
通常,一个查询的并行度会影响一个查询的性能以及系统的吞吐量。资源管理器分配给一个查询的virtual segment个数决定了一个查询的并行度。 一般情况下,用户不需要人为干预资源管理器对virtaul segment个数的分配,OushuDB资源管理器会很好的管理查询的并行度。但有些时候,用户可能想要控制一个查询的并发度,OushuDB提供了多个 可供用户调控的手段。
148 0
OushuDB  管理指南之资源管理(下)
OushuDB 管理指南之资源管理(中)
在资源队列树中,只有叶子节点可以关联用户接受查询。儿子节点的资源是从父节点中分配出来的。其中一个父节点的所有儿子节点的MEMORY_LIMIT_CLUSTER和 CORE_LIMIT_CLUSTER比例值之和必须小于等于100%。
97 0
OushuDB  管理指南之资源管理(中)
Oushu DB 管理指南之资源管理(上)
在任意时刻,OushuDB中可能有很多个并发的查询在运行。这些查询属于不同的用户。用户的优先级可能有高有低。我们需要一种方式 来合理的给各个用户分配其可以使用的系统资源,包括CPU和内存等。
114 0
Oushu DB  管理指南之资源管理(上)
|
资源调度 容器
OushuDB 管理指南之资源管理
如果OushuDB和YARN配合使用,OushuDB可以从YARN申请资源,并把申请到的资源通过资源管理队列重新在查询之间分配。在不使用资源的时候会把资源动态归还给YARN。 你可以在hawq-site.xml中修改如下配置使之生效。
109 0
OushuDB 管理指南之资源管理