Ansible部署Tomcat

Ansible部署Tomcat

环境

系统平台IP主机名
centos8
redhat8
192.168.229.152ansible
centos8
redhat8
192.168.229.148tomcat

在部署之前需关闭防火墙跟SElinux

## 配置域名
[root@ansible ~]# vim /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.229.148 tomcat

## 设置免密登录
[root@ansible ~]# ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:QE1mMmEAEZJnG7uSkhxllmv0m68HkQD1D4EduYydQPc root@ansible
The key's randomart image is:
+---[RSA 3072]----+
|.oB*==O++        |
|..+Xo=o=.        |
| o=+Oo=E         |
| .o+ Oo.         |
|.oo.  +.S        |
|=..  +           |
|..    o          |
|       o         |
|     .o          |
+----[SHA256]-----+
[root@ansible ~]# ssh-copy-id root@tomcat
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host 'tomcat (192.168.229.148)' can't be established.
ECDSA key fingerprint is SHA256:n2ckGGr820b4Fez6NUHXuOApoQ3oCuf3POTLfTxOsS4.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
root@tomcat's password:

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh 'root@tomcat'"
and check to make sure that only the key(s) you wanted were added.
[root@ansible ~]# mkdir tomcat
[root@ansible ~]# cd tomcat/
[root@ansible tomcat]# cat inventory
[web]
tomcat
[root@ansible tomcat]# cp /etc/ansible/ansible.cfg .  # 复制ansible.cfg文件到当前目录

[root@ansible tomcat]# sed -i '/inventory\      /s/^#//;s/\/etc\/ansible\/hosts/inventory/g' ansible.cfg
[root@ansible tomcat]# grep '^inventory' ansible.cfg
inventory      = inventory


## ping 是否能ping通
[root@ansible tomcat]# ansible tomcat -m ping
tomcat | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": false,
    "ping": "pong"
}


对面的受控主机是否有yum源呢?

配置受控主机的几种方式:

要么下载到本地再用copy模块传过去

关闭防火墙跟SElinux也是可以用这种方法

要么使用脚本的方式下载

我在这里使用脚本方式

[root@ansible tomcat]# pwd
/root/tomcat
[root@ansible tomcat]# mkdir files
[root@ansible tomcat]# cd files/
[root@ansible files]# cat config_yum.sh
#!/bin/bash

rm -rf /etc/yum.repos.d/*
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo
sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo
dnf clean all
dnf makecache

yum install -y https://mirrors.aliyun.com/epel/epel-release-latest-8.noarch.rpm
sed -i 's|^#baseurl=https://download.example/pub|baseurl=https://mirrors.aliyun.com|' /etc/yum.repos.d/epel*
sed -i 's|^metalink|#metalink|' /etc/yum.repos.d/epel*
dnf clean all
dnf makecache
[root@ansible files]# chmod +x  config_yum.sh

[root@ansible tomcat]# cat yum.yml
---
- hosts: tomcat
  tasks:
    - name: config yum
      script: files/config_yum.sh
      
执行此 playbook     

配置 主 playbook


## 提前下载好Tomcat 软件包
[root@ansible files]# pwd
/root/tomcat/files
[root@ansible files]# wget https://archive.apache.org/dist/tomcat/tomcat-9/v9.0.65/bin/apache-tomcat-9.0.65.tar.gz


[root@ansible ~]# cd tomcat/files/
[root@ansible files]# cat tomcat.sh
#!/bin/bash

cd /usr/src
if [ ! -d /usr/local/tomcat ];then
    tar xf apache-tomcat-9.0.65.tar.gz
    mv apache-tomcat-9.0.65 /usr/local/tomcat
fi

mkdir -p /usr/local/tomcat/webapps/tomcat &> /dev/null

cat > /usr/local/tomcat/webapps/tomcat/index.jsp <<EOF
<html>
<head>
        <title>test page</title>
</head>
<body>
        <%
            out.println("Hello Tomcat");
        %>
</body>
</html>
EOF

sed -i '/AJP 1.3/{n;/<!--/d}' /usr/local/tomcat/conf/server.xml
sed -i '/port="8009"/{N;/redirectPort="8443"/{n;/-->/d}}' /usr/local/tomcat/conf/server.xml

grep '<role rolename="manager-gui"/>' /usr/local/tomcat/conf/tomcat-users.xml
if [ $? -ne 0 ];then
sed -i '/<\/tomcat-users>/i <role rolename="manager-gui"/>\n<role rolename="admin-gui"/>\n<user username="tomcat"password="tomcat" roles="manager-gui,admin-gui"/>' /usr/local/tomcat/conf/tomcat-users.xml
fi

sed -i '/allow/c \         allow="192\\.168\\.229\\.\\d+|127\\.\\d+\\.\\d+\\.\\d+|::1|0:0:0:0:0:0:0:1" />' /usr/local/tomcat/webapps/manager/META-INF/context.xml

sed -i '/allow/c \         allow="192\\.168\\.229\\.\\d+|127\\.\\d+\\.\\d+\\.\\d+|::1|0:0:0:0:0:0:0:1" />' /usr/local/tomcat/webapps/host-manager/META-INF/context.xml

cat > /usr/lib/systemd/system/tomcat.service <<EOF
[Unit]
Description=tomcat server daemon
After=network.target sshd-keygen.target

[Service]
Type=forking
ExecStart=/usr/local/tomcat/bin/catalina.sh start
ExecStop=/usr/local/tomcat/bin/catalina.sh stop
ExecReload=/bin/kill -HUP \$MAINPID

[Install]
WantedBy=multi-user.target
EOF

systemctl daemon-reload
systemctl enable --now tomcat

[root@ansible files]# chmod +x tomcat.sh  ## 脚本都要给执行权限



[root@ansible tomcat]# vim tomcat.yml
---
- hosts: tomcat
  gather_facts: no
  tasks:
    - name: install jdk
      dnf:
        name:
          - java-17-openjdk
          - java-17-openjdk-devel
        state: present
    - name: copy software pkgs
      copy:
        src: files/apache-tomcat-9.0.65.tar.gz
        dest: /usr/src/
    - name: exec script
      script: files/tomcat.sh
      
运行此 playbook      
[root@ansible tomcat]# ansible-playbook  tomcat.yml
...运行步骤省略N

IP 访问

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DL5AvQ6b-1661435284691)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661430144681.png)]

Tomcat 首页

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q9gBltE1-1661435284693)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661430199771.png)]

点击 Server status

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u4Y94Lxj-1661435284694)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661430254514.png)]

登录进来后的页面

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sATeizIa-1661435284696)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661433485979.png)]

点击 manager App

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-coiVt6DN-1661435284696)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661433533679.png)]

点击 Host manager

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XSFUuZUM-1661435284698)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661430419066.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-d9fOh0HP-1661435284699)(../../%E5%8D%9A%E5%AE%A2/%E7%A0%B4%E8%A7%A3%E5%AF%86%E7%A0%81/1661434961948.png)]

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux 多tomcat服务 统一安装 统一部署 工具 shell编写 1 引言 基于JAVA开发项目,随着服务的越来越多,配置文件更是眼花缭乱,每次不知道因为配置问题浪费多少时间,更不知道因为配置问题出过多少问题。多台服务器来回切换,如果服务需要依赖,启动更是问题。 1.1 目的 一次修改,统一安装;操作简单,实用高效。 1.2 范围 本项目使用范围包括: * 基于JAVA开发项目 * 项目相关服务繁多 * 服务启动有依赖关系 1.3 读者 本需求规格说明书的阅读者或其他文档干系人有平台总监、产品经理、项目总监、项目经理、开发人员、测试人员、用户体验设计人员等。 2 项目总体描述 2.1 系统总体功能框架 2.2 系统功能列表 Exec 建立信任、初始命令 初始 Tools 提供服务与服务列表 扫描提供服务列表,获取配置信息 Conf 自动获取需要修改配置 自动生成 Bin 执行脚本 提供总执行与单一执行脚本 New 存放修改后配置文件 与bak保留文件成反比 Bak 存放原始配置文件 便于问题分析 Temp 存放临时文件 临时文件将及时删除无任何冗积 Workapp 存放war包 上传war包 3 功能描述 3.1 获取配置文件 通过本系统获取配置文件非常简单,只需用户提供服务列表,其他无需操作。服务列表如下: name ip serve 服务名称 192.168.0.1 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 名词解释: name :服务名称,需与war包名称一致。 ip :服务器ip地址。 serve :Tomcat部署路径。 执行脚本,“.. /unifyDeploy/conf”自动生成用户所需修改配置文件,配置文件是通过筛选后生成,所以一个服务不管需要配置多少文件,这里只生成一个,方便修改与管理。 3.2 自动化统一安装部署 自动化统一安装部署,包括:上传解压war包、同步配置、启动服务、监控服务等。 list.ll one.sh pass.war startup.sh syn.cn two.sh 部署支持统一安装于分布式安装,每个脚本可以拆分开任意组合使用,比如: 1) 一套新环境tomcat中还未部署服务,只需调整上传war包脚本顺序,先上传war后,后续操作正常执行。 2) 迭代更新,功能稍作修改,原配置项无需修改,也只需调整上传war包脚本顺序,先获取原有配置,再上传更新war包,后续操作正常执行。 3.3 优缺点描述 优点描述: * 适用于统一安装部署,也适用于单独服务安装部署。 * 保留原始备份,方便部署前后配置对比。 * 操作简单、需求扩展能力强。 不足描述: * 暂时只适用于基于tomcat服务器项目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值