如何让NComputing桌面终端用户做到独享指定CPU、内存和磁盘大小
2014-09-15 18:04
225 查看
本文参考了刘宇的《puppet实战》,并得到他的指导。在此,感谢刘宇。
前一篇文章提到,利用Puppet来给客户端自动生成在服务端定义好的文件。
我们这里继续引申,来从服务端定义客户端需要安装的软件。
这里我们以安装httpd举例。
在服务端,需要定义模块,我们定义一个httpd模块,名字就叫httpd。
目录结构如下:
我们这样来建立目录和所需的配置文件:
来看看puppet客户端和服务端的交互过程:
puppet客户端将节点名称和facts信息发送给master
puppet服务端master通过分类判断请求的客户端是谁,它要做什么?这个判断依赖于site.pp中包含的node.pp配置文件完成
puppet服务端将客户端所学的class信息编译到catalog里面去,并把它发送给客户端
客户端对catalog进行验证并执行
客户端通过api把执行结果回报给master
site.pp这个文件是指引去哪里寻找并加载所有主机相关的配置。
这个文件默认放在 /etc/puppet/mainfests中,在这个文件里面我们会定义一些全局变量。
而在site.pp里面可以引用其他模块定义的*.pp文件,以让文件结构显得清晰。
需要提供给客户端的配置信息可以任意定义,只要在site.pp里面import对应的配置文件即可。
我们采用的目录结构配置是:
/etc/puppet/manifests/nodes
/etc/puppet/modules
在上面的步骤里,我们已经创建了模块test,现在我们需要创建测试节点
到此,节点信息、模块信息均已创建。
前面讲过,puppet会首先读取site.pp,我们需要让site.pp能导入节点信息和模块信息
至此,客户端可以来向服务端取信息了,我们可以采用模拟执行的方式,这样,可以看到是否能执行(但并不真正执行)
上面的warning信息,我们暂且不理会,可以看到,已经取到配置信息了。
下面我们给它加个功能,让服务端给客户端安装httpd。
为此,我们要添加一个模块,
mkdir -p /etc/puppet/modules/httpd/{mainfests,templates,files}
编辑httpd模块文件,在里面指定yum源
修改节点信息,添加引用httpd模块:
至此,客户端可以通过向服务端同步信息来安装httpd了。
前一篇文章提到,利用Puppet来给客户端自动生成在服务端定义好的文件。
我们这里继续引申,来从服务端定义客户端需要安装的软件。
这里我们以安装httpd举例。
在服务端,需要定义模块,我们定义一个httpd模块,名字就叫httpd。
目录结构如下:
puppet/ |-- auth.conf |-- environments | `-- example_env | |-- README.environment | |-- manifests | `-- modules |-- fileserver.conf |-- manifests | |-- nodes | | `-- cahou.linux.net.pp | `-- site.pp |-- modules | |-- httpd | | |-- files | | |-- mainfests | | | `-- init.pp | | `-- templates | `-- test | |-- files | |-- manifests | | `-- init.pp | `-- templates | `-- test.erb `-- puppet.conf 15 directories, 9 files
我们这样来建立目录和所需的配置文件:
来看看puppet客户端和服务端的交互过程:
puppet客户端将节点名称和facts信息发送给master
puppet服务端master通过分类判断请求的客户端是谁,它要做什么?这个判断依赖于site.pp中包含的node.pp配置文件完成
puppet服务端将客户端所学的class信息编译到catalog里面去,并把它发送给客户端
客户端对catalog进行验证并执行
客户端通过api把执行结果回报给master
site.pp这个文件是指引去哪里寻找并加载所有主机相关的配置。
这个文件默认放在 /etc/puppet/mainfests中,在这个文件里面我们会定义一些全局变量。
而在site.pp里面可以引用其他模块定义的*.pp文件,以让文件结构显得清晰。
需要提供给客户端的配置信息可以任意定义,只要在site.pp里面import对应的配置文件即可。
我们采用的目录结构配置是:
/etc/puppet/manifests/nodes
/etc/puppet/modules
#下面我们建立了一个叫做test的模块和叫做cahou.linux.net的节点 mkdir -p /etc/puppet/manifests/nodes mkdir -p /etc/puppet/modules/test/{mainfests,templates,files} vi /etc/puppet/modules/test/manifests/init.pp class test { file { "/tmp/$hostname.txt": content => "hello,world 1234567890!\n"; } } #在上面的模块中配置了一个变量,叫做$hostname,这个变量需要传给ERB文件,这个文件就放在test类这个目录下的templates目录中,文件名与类名一致。 cat /etc/puppet/modules/test/templatest/test.erb hostname <% fqdn %>
在上面的步骤里,我们已经创建了模块test,现在我们需要创建测试节点
cat /etc/puppet/manifests/nodes/cahou.linux.net.pp node 'cahou.linux.net' { include test }
到此,节点信息、模块信息均已创建。
前面讲过,puppet会首先读取site.pp,我们需要让site.pp能导入节点信息和模块信息
vi /etc/puppet/manifests/site.pp cat site.pp Package {provider => "yum"} node default { file { "/tmp/puppettest1.txt": content => "hello,first puppet test1234567890!\n";}} import "/etc/puppet/modules/httpd/mainfests/init.pp" import "/etc/puppet/manifests/nodes/*.pp"
至此,客户端可以来向服务端取信息了,我们可以采用模拟执行的方式,这样,可以看到是否能执行(但并不真正执行)
puppet agent --server cahoa.linux.net --test --verbose --no-daemonize --noop Info: Retrieving pluginfacts Info: Retrieving plugin Info: Caching catalog for cahou.linux.net Warning: The package type's allow_virtual parameter will be changing its default value from false to true in a future release. If you do not want to allow virtual packages, please explicitly set allow_virtual to false. (at /usr/lib/ruby/site_ruby/1.8/puppet/type/package.rb:430:in `default') Info: Applying configuration version '1413640549' Notice: Finished catalog run in 0.38 seconds
上面的warning信息,我们暂且不理会,可以看到,已经取到配置信息了。
下面我们给它加个功能,让服务端给客户端安装httpd。
为此,我们要添加一个模块,
mkdir -p /etc/puppet/modules/httpd/{mainfests,templates,files}
编辑httpd模块文件,在里面指定yum源
cat /etc/puppet/modules/httpd/mainfests/init.pp class httpd { yumrepo { "reposohu": descr => "sohu repo", baseurl => "http://mirrors.sohu.com/centos/5.11/os/i386/", gpgcheck => "0", enabled => "1"; } package { "httpd": ensure => installed, require => Yumrepo["reposohu"]; } }
修改节点信息,添加引用httpd模块:
cat /etc/puppet/manifests/nodes/cahou.linux.net.pp node 'cahou.linux.net' { include test include httpd }
至此,客户端可以通过向服务端同步信息来安装httpd了。
[root@cahou ~]# puppet agent --server cahoa.linux.net --test --no-daemonize Info: Retrieving pluginfacts Info: Retrieving plugin Info: Caching catalog for cahou.linux.net Warning: The package type's allow_virtual parameter will be changing its default value from false to true in a future release. If you do not want to allow virtual packages, please explicitly set allow_virtual to false. (at /usr/lib/ruby/site_ruby/1.8/puppet/type/package.rb:430:in `default') Info: Applying configuration version '1413640549' Notice: /Stage[main]/Httpd/Package[httpd]/ensure: created Notice: Finished catalog run in 61.91 seconds [root@cahou ~]# rpm -q httpd [root@cahou ~]# ll -c /etc/httpd/conf/httpd.conf -rw-r--r-- 1 root root 33726 Oct 18 23:54 /etc/httpd/conf/httpd.conf #从上面的httpd.conf的ctime信息,我们可以看到,这正是刚刚安装的httpd。本文出自 “linux与网络那些事” 博客,请务必保留此出处http://khaozi.blog.51cto.com/952782/1565561
相关文章推荐
- 如何获取 Android 设备的CPU核数、时钟频率以及内存大小
- SqlServer如何通过SQL语句获取处理器(CPU)、内存(Memory)、磁盘(Disk)以及操作系统相关信息
- 如何获取 Android 设备的CPU核数、时钟频率以及内存大小
- Centos下查看cpu、磁盘、内存使用情况以及如何清理内存
- 如何从终端发送桌面通知给用户(notify-send)
- C语言把内存的文件保存到硬盘时如何把文件名由用户通过屏幕自己设置,并且保存到指定的路径
- Centos下查看cpu、磁盘、内存使用情况以及如何清理内存
- SqlServer如何通过SQL语句获取处理器(CPU)、内存(Memory)、磁盘(Disk)以及操作系统相关信息
- 2003远程桌面:如何连接指定的用户session?
- 如何获取 Android 设备的CPU核数、时钟频率以及内存大小
- 如何在基于tensorflow的深度学习框架keras中指定GPU内存使用大小
- cpu如何知道内存中一条指令的大小从而使cs:ip寄存器更改自己的值
- Centos下查看cpu、磁盘、内存使用情况以及如何清理内存
- 如何获取 Android 设备的CPU核数、时钟频率以及内存大小
- jpush如何做到指定用户的推送?
- 如何用shell脚本监控服务器负载、cpu、内存、硬盘和登录用户数
- linux性能分析及调优__cpu 性能瓶颈调优可调性能参数 、内存性能瓶颈可调性能参数(操作系统设置swap的目的、在写程序时、如何使自己的内存不被换出swap,常驻物理内存)、磁盘I/O可调性能参
- Centos下查看cpu、磁盘、内存使用情况以及如何清理内存
- C#中如何获取系统版本,内存大小,显卡类型,CPU型号
- 如何让Window XP远程桌面支持多用户