草庐IT

实战Puppet 集中配置管理系统(2)——apache与nginx模块配置

willis_sun 2023-03-28 原文
    本次实验内容紧接上次实验,上次博客主要介绍PUPPET的安装认证与资源定义,这次主要写apache与nginx模块的应用。上次实验内容:

    实战Puppet 集中配置管理系统(1)——认证与资源定义


本次实验内容:

1.建立节点文件

2.编写apache模块

3.编写nginx模块

4.模板应用(添加虚拟主机配置)


    1.不同节点的定义

    1.1. 在 puppetmaster(服务器server1端) 编辑 site.pp

# vim  /etc/puppet/manifests/site.pp

    import "nodes/*.pp"

    1.2. 建立节点文件

#mkdir -p /etc/puppet/manifests/nodes

# vi /etc/puppet/manifests/nodes/server2.pp

node 'server2.example.com' {

file { "/var/www/html/index.html":

content => "server2.example.com"

}

}

# vi /etc/puppet/manifests/nodes/server3.pp

node 'server3.example.com' {

file { "/var/www/html/index.html":content => "server3.example.com"

}

}

    1.3 在client上测试:

  #puppet agent --server server1.example.com --no-daemonize -vt


2.编写apache模块

#mkdir -p /etc/puppet/modules/httpd/manifests

#mkdir -p /etc/puppet/modules/httpd/files

#cd /etc/puppet/modules/httpd/manifests

#vim install.pp

    class httpd::install {

         package { "httpd" :

         ensure => present

         }

        }

#vim service.pp

    class httpd::service

    {

service {

"httpd":

ensure => running,

require => Class["httpd::install","httpd::config"]

    }

    }

#vim config.pp

        class httpd::config {


file {

"/etc/httpd/conf/httpd.conf":

source => "puppet:///modules/httpd/httpd.conf",

require => Class["httpd::install"],

notify => Class["httpd::service"]

         }

        }

#vim init.pp

        class httpd {

        include httpd::install,httpd::config,httpd::service

        }

#cd /etc/puppet/modules/httpd/files

#cp /etc/httpd/conf/httpd.conf .

#cd /etc/puppet/manifests/nodes

#vim server2.pp

        node 'server2.example.com' {

        include httpd

        file { "/var/www/html/index.html":

        content => "server2.example.com"

        }

        }

在server2上测试:

#puppet agent --server server1.example.com --no-daemonize -vt


3.编写nginx模块

1) #mkdir -p /etc/puppet/modules/nginx/manifests

2) #mkdir -p /etc/puppet/modules/nginx/files

3) #cd /etc/puppet/modules/nginx/manifests

    #vim install.pp

        class nginx::install{

        package {

        ["pcre-devel","gcc","openssl-devel"]:

        ensure => present

        }

        file {

        "/mnt/nginx-1.8.0.tar.gz":

         source => "puppet:///modules/nginx/nginx-1.8.0.tar.gz";

        "/mnt/install-nginx.sh":

        source => "puppet:///modules/nginx/install-nginx.sh"

        }

        exec {

        "install nginx":

        command => "sh /mnt/install-nginx.sh",

        path => "/bin:/usr/bin:/sbin:/usr/sbin",

        require => File["/mnt/install-nginx.sh","/mnt/nginx-1.8.0.tar.gz"],

        creates => "/usr/local/lnmp/nginx/sbin/nginx"

        #provider => shell,

        }

        }

  

#vim service.pp

    class nginx::service {

    exec {

"nginx start":

command => "/usr/local/lnmp/nginx/sbin/nginx",

require => Class["nginx::install"],

creates => "/usr/local/lnmp/nginx/logs/nginx.pid"

    }

    }


#vim config.pp

    class nginx::config {

    file {

"/usr/local/lnmp/nginx/conf/nginx.conf":

source => "puppet:///modules/nginx/nginx.conf",

require => Class["nginx::service"]

    }

    exec {

"nginx reload":

command => "/usr/local/lnmp/nginx/sbin/nginx -s reload",

refreshonly => true,

subscribe => File["/usr/local/lnmp/nginx/conf/nginx.conf"]

    }

    }


#cd /etc/puppet/modules/nginx/files/

#vim install-nginx.sh

#!/bin/bash

    cd /mnt

    tar -zxf nginx-1.8.0.tar.gz

    cd nginx-1.8.0

    ./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module

    make && make install

5)[root@server1 files]# ls

    install-nginx.sh  nginx-1.8.0.tar.gz  nginx.conf

#cd /etc/puppet/manifests/nodes 

#vim server3.pp

    node 'server3.example.com' {

    include nginx

    }

在server3上测试:

  #puppet agent --server server1.example.com --no-daemonize -vt


4. 模板应用(添加虚拟主机配置):

文件存放在 templates 目录中,以*.erb 结尾。

# vim /etc/puppet/modules/httpd/manifests/init.pp

  //#添加以下行

    define httpd::vhost($domainname) {

    file { "/etc/httpd/conf.d/${domainname}_vhost.conf":

    content => template("httpd/httpd_vhost.conf.erb"),

    require => Class["httpd::install"],

    notify => Class["httpd::service"]

    }


    file { "/var/www/$domainname":

    ensure => directory

    }


    file { "/var/www/$domainname/index.html":

    content => $domainname

    }


#cd /etc/puppet/modules/httpd/templates/

# vim httpd_vhost.conf.erb

    <VirtualHost *:80>

    ServerName <%= domainname %>

    DocumentRoot /var/www/<%= domainname %>

    ErrorLog logs/<%= domainname %>_error.log

    CustomLog logs/<%= domainname %>_access.log common

    </VirtualHost>


#vim /etc/puppet/manifests/nodes/server4.pp

    node 'server2.example.com' {

include httpd

httpd::vhost { 'server2.example.com':

domainname => "server2.example.com",

}

httpd::vhost { 'www2.example.com':

        domainname => "www2.example.com",

        }

    }

# vim /etc/puppet/modules/httpd/files/httpd.conf

    990 NameVirtualHost *:80


5)在server2 上测试:

#puppet agent --server server2.example.com --no-daemonize -vt

//在/var/www下会生成server2.example.com  www2.example.com两个目录

6)在主机上添加解析,浏览器上测试

访问server2.example.com

  www2.example.com







有关实战Puppet 集中配置管理系统(2)——apache与nginx模块配置的更多相关文章

  1. ruby - 在 Ruby 中使用匿名模块 - 2

    假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

  2. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  3. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  4. ruby-on-rails - 在混合/模块中覆盖模型的属性访问器 - 2

    我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah

  5. ruby-on-rails - 如何优雅地重启 thin + nginx? - 2

    我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server

  6. ruby-on-rails - 独立 ruby​​ 脚本的配置文件 - 2

    我有一个在Linux服务器上运行的ruby​​脚本。它不使用rails或任何东西。它基本上是一个命令行ruby​​脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg

  7. Ruby Sinatra 配置用于生产和开发 - 2

    我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm

  8. ruby - 当使用::指定模块时,为什么 Ruby 不在更高范围内查找类? - 2

    我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or

  9. ruby - 获取模块中定义的所有常量的值 - 2

    我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c

  10. ruby - 模块嵌套代码风格偏好 - 2

    我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的

随机推荐