Puppet 部署tomcat

 Puppet 部署tomcat

Tomcat运行需要java环境,所以需要同时安装tomcat和java, 相对应的puppet也需要编写两个模块 tomcat 和java(puppet一般以模块的形式来部署软件)

一、java模块

1.1创建模块目录结构
    [[email protected] ~]# mkdir –vp /etc/puppet/modules/java7/{files,templates,manifests}

files目录存放需要分发给客户端的文件

templates目录存放配置文件模板

manifests  存放配置文件,包括如何安装和运行

1.2编辑全局配置文件init.pp

init.pp是每个模块的必需初始化文件,puppet会根据init.pp寻找其他文件中定义的类

vim java7/manifests/init.pp

class java7 {

include java7::install,java7::env

}

1.3 编辑安装配置文件:

先简单介绍下exec 资源管理及其主要参数

exec:命令用来执行外部的命令或脚本,包括以下主要参数:

cwd    -------命令执行的路径

creates  ------------命令创建的一个文件。加入这个参数设置的话,只有这个文件不存在的时候命令才会执行,即有条件的执行

command  -------指定要执行的命令

path     ---------命令执行搜索的路径

group    ---------执行命令运行的用户组

user     ---------执行命令的用户

正式编辑:

vi/etc/puppet/modules/java7/manifests/install.pp

class java7::install {

file {

"/usr/java/jdk-7u79-linux-x64.gz": #指明文件下载到客户端的哪个路径

source=> "puppet:///modules/java7/jdk-7u79-linux-x64.gz", #服务器上被下载的源文件

owner => root,

group => root,

mode => 755

}

exec { "install jdk":

cwd => "/usr/java",

command => "tar zxvfjdk-7u79-linux-x64.gz",

user => "root",

group => "root",

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

creates =>"/usr/java/jdk1.7.0_79",

require =>File["/usr/java/jdk-7u79-linux-x64.gz"]

}

}

1.4编辑 env.pp

安装完java后, 还需要配置JAVA_Homd等环境变量用于tomcat的运行,所以需要再创建一个配置文件用于设置环境变量

Vim /etc/puppet/modules/java7/manifests/env.pp

classjava7::env {

file {

"/usr/java/env":

owner => "root",

group => "root",

source =>"puppet:///modules/java7/env"

}

exec {

"set env": #set JAVA_HOME

command =>" cat /usr/java/env>>/etc/profile && source /etc/profile",

user => "root",

group => "root",

path =>["/usr/local/sbin","/usr/local/bin","/sbin","/bin","/usr/sbin","/usr/bin"],

unless => "grep -i java_home /etc/profile",#if the return value is 1,do this command.

require =>File["/usr/java/env"]

}

}

1.5应用模块

模块配置完成,需要配置节点文件nodes.pp才能真正的应用模块

配置节点three.s.com应用java7模块

vi  /etc/puppet/manifests/nodes.pp

node ‘three.s.com‘ {

include java7

}

site.pp导入 节点配置文件node.pp

vi   /etc/puppet/manifests/site.pp

import "nodes.pp"

配置完成后,客户端执行puppet agent --test ,查看结果

二、tomcat模块

2.1创建相关目录结构

2.2编辑init.pp文件,定义全局配置

vim  /etc/puppet/modules/tomcat7/manifests/init.pp
      class tomcat7 {
        include tomcat7::install

}

这里tomcat7只包含一个install子类,并没有涉及到运行配置等子类,完全根据自身需求配置

2.3.编辑install.pp文件

class tomcat7::install {

file {

"/usr/apache-tomcat-7.0.63.tar.gz":

source =>"puppet:///modules/tomcat7/apache-tomcat-7.0.63.tar.gz",

owner => "root",

group => "root",

mode => 755

}

exec {"install tomcat":-----标题

cwd => "/usr",

command => "tar zxvfapache-tomcat-7.0.63.tar.gz && mv apache-tomcat-7.0.63 tomcat7",

user => "root",

group => "root",

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

creates => "/usr/tomcat7",

require => File["/usr/apache-tomcat-7.0.63.tar.gz"]

}

}

2.4应用模块

配置节点three.s.com应用tomcat7模块

vi  /etc/puppet/manifests/nodes.pp

node ‘three.s.com‘ {

include java7,tocamt7

}

配置完成后,客户端执行puppet agent --test ,查看结果

时间: 2024-12-20 09:58:56

Puppet 部署tomcat的相关文章

利用Puppet全自动部署tomcat

上一篇聊了puppet的安装部署方法,如果你还没有安装puppet,请点击下方链接查看具体安装方法: <搭建Puppet自动化部署环境> 这篇来看一下如何利用Puppet全自动部署tomcat,在Puppet中有很多资源,其中比较常用的包括: package    通过程序安装软件 service    启动或停止服务 file      文件传输 exec      执行命令 由于tomcat用源码包安装的居多,所有下面主要用到file和exec资源 一.打开文件传输功能 1.vim /et

部署Tomcat服务器实现负载均衡

部署tomcat及负载均衡 简介: Tomcat最初是由Sun的软件架构师詹姆斯.邓肯.戴维森开发的,Tomcat服务器是一个免费的开放源代码的web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍应用,是开发和调试jsp程序的首选,Tomcat通常是作为一个Servlet和jsp容器,单独运行在后端.主要是作为使用java程序语言开发的网站部署的web服务器. 下面通过在虚拟机中搭建实验,来说明tomcat的使用并实现tomcat服务器的负载均衡 一.部署to

3-linux下部署tomcat应用

linux下部署tomcat应用 相关软件下载 jdk      http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html tomcat     http://tomcat.apache.org/ 解压jdk以及tomcat包 [r[email protected] soft]# tar -zxvf apache-tomcat-8.0.30.tar.gz [[email protecte

IntelliJ IDEA 15 部署Tomcat及创建一个简单的Web工程

一.部署Tomcat 二.创建一个简单的Web工程 2.1创建一个新工程 创建一个新工程 设置JDK及选择Web Application (创建的是Web工程) 点击Next,选择工作空间,起个工程名 2.2项目部署 在工具栏点击 Project: 无需任何设置,选择默认编译目录(或自定义编译目录) Modules: 将Tomcat加入 Libraries:无需任何设置.这里描述了此项目的依赖. Facets: 无需任何设置.这里描述了此项目所适配的服务框架 Artifacts: 无需任何配置.

一次puppet部署自动化的尝试

背景: 大约有20台的生产和测试主机(Centos5.3),有6个大模块,以前都是用手动安装的,费时费力,有时也会手动操作出错. 目标: 希望用puppet来实现部署的自动化 下面以其中的一个模块的自动化部署尝试来讲解如何实现用puppet的部署自动化. 前提: 在一台测试机上安装puppet master,一台装puppet agent.具体的安装和配置过程就不再讲述了,网上的资料一堆堆的. 现在着重讲述如何配置puppet的类. 创建一个模块,叫ppe/etc/puppet/modules/

在Mac OS X中部署Tomcat的经验

因为前几天重装了Mac的系统.准备接下来把一些必需的实验环境都搭建起来.这里简单总结一下在Mac OS X上部署Tomcat应该注意的事情: 下载Tomcat的相应版本号,如http://tomcat.apache.org/download-70.cgi里面的zip. 下载在希望部署的文件夹下解压.这里须要解决两个问题,一个是脚本的权限问题. 在终端中定位到tomcat文件夹下,输入 sudo chmod 755 ./bin/*.sh 另外一个是Java的环境变量问题.这个还略微有点复杂,能够參

puppet部署与应用

防伪码:忽如一夜春风来,千树万树梨花开. 第十二章 puppet部署与应用 前言:作为一名运维工程师,就需要寻找一款能够降低工作量的工具.那么今天就给大家介绍一批工具,这批工具是"可编程"的,只需要为这批工具写上几行代码,它便会自动完成所有的工作,这批工具就是运维自动化puppet(为什么说是一批工具,因为软件不止一个).Puppet可以针对多台服务器进行统一的操作,例如:软件分发,统一执行脚本,在服务器上写好脚本分发给客户机,客户机就会自动执行,减少了人力及误操作风险.Puppet与

【中级篇】部署Tomcat+Nginx负载均衡集群

部署Tomcat+Nginx负载均衡集群 1.          实验需求: 1)     2台服务器同时部署tomcat; 2) 部署Nginx 3) 搭建负载均衡,测试其效果. 2.          实验环境: Linux服务器系统版本:CentOS-6.5 -S02 IP:192.168.10.15  ( tomcat 2 ) Linux服务器系统版本:CentOS-6.5 -S03 IP : 192.168.10.18  ( Nginx) Linux服务器系统版本:  RedHat6.

Linux之部署Tomcat及其负载均衡

Linux之部署Tomcat及其负载均衡 一.案例 案例要求 1. 在1.10和1.20上分别部署tomcat服务,并创建java的web站点.在本机上分别验证是否能访问创建的web站点(如http://192.168.1.10:8080/index.jsp) 2. 在1.100的主机上部署nginx服务,修改主配置文件,实现nginx为前端,tomcat为后端的负载均衡的功能. 3.在client主机访问nginx服务器,验证是否能实现负载均衡. 二.开始部署 1.环境配置 (使用Vmware