测试环境搭建——Spring Boot 部署

相比传统的 Java Web ,Spring Boot 极大简化了配置,并且遵守约定优于配置的原则即使0配置也能正常运行,是目前最流行的 Java Web 开发框架。 

今天的测试环境小萌新篇给大家介绍关于 Spring Boot 的部署。

图片

运行方式

Spring Boot应用程序有两种运行方式:

  • 以jar包方式运行
  • 以war包方式运行

两种方式应用场景不一样,各有优缺点

jar包运行

通过maven插件spring-boot-maven-plugin,在进行打包时,会动态生成jar的启动类org.springframework.boot.loader.JarLauncher,借助该类对Spring Boot 应用程序进行启动。

优点:

  • 本地无需搭建web容器,方便开发和调试;
  • 因为自带web容器,可以避免由于web容器的差异造成不同环境结果不一致问题;
  • 一个jar包就是全部,方便应用扩展;
  • 借助容器化,可以进行大规模的部署。

缺点:

  • 应用过于独立,难以统一管理;
  • 数据源无法通过界面进行管理;
  • 应用体积过大;
  • 修改web容器相关配置较为困难,需要借助代码实现。

war包运行

以war包方式运行,通过maven插件spring-boot-maven-plugin进行相关配置后,最终生成一个可运行在tomcat,weblogic等java web容器中的war包。

优点:

可以借助web容器管理界面对应用进行管理;

可以管理JNDI数据源;

web容器配置较为灵活,配置和程序分离;

应用体积较小,甚至可以借助web容器的包管理功能(比如weblogic Library)进一步减小应用大小。

缺点:

本地需要搭建web容器,对本地环境要求更高点,学习成本也响应更高;

调试较为困难,需要借助web容器;

无法兼容所有web容器(比如spring boot2.x无法运行在weblogic 11g上);

部署较为困难(比如和weblogic有较多的类冲突)。

在实际的项目中,并没有哪一种方式是最好的,根据不同的需求制定不同的部署方案,比如看中管理功能,要求数据源和tomcat相关配置必须由管理员进行管理,那么选择war包方式;如果希望借助容器化进行大规模部署,那么jar方式更适合。

这里我们介绍 jar 方式。

基本准备

Web 服务器

对于Spring Boot,Spring官方的建议是将Spring Boot应用打包成一个fat jar,通过java命令来启动运行。这个fat jar会把Tomcat内置进来,所以部署时也不需要单独配置Tomcat。

所以我们这里只安装配置向代理服务器——Nginx。

安装按照官方推荐的方式:

# 安装EPEL仓库yum install epel-releaseyum update# 编译与安装yum install nginx# 查看安装版本:nginx –v# 启动服务systemctl start nginx

数据库

我们使用最主流的数据库 MySQL。

安装与配置:

# 下载 MySQL 的 repo 源wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm# 安装 mysql-community-release-el7-5.noarch.rpm包rpm -ivh mysql-community-release-el7-5.noarch.rpm# 安装 MySQL  Serveryum install -y mysql-community-server# 启动服务systemctl restart mysql # 设置密码mysql>use mysql;mysql>update user set password=password(‘123456′) where user=’root’;mysql>exit;# 重启服务systemctl restart mysql# 设置访问权限GRANT ALL PRIVILEGES ON *.* TO root@”%” IDENTIFIED BY “123456″; 

Spring Boot 部署

打包

对于Spring Boot 的打包可以通过编译或者直接使用Maven命令的方式。

IDEA打包:

图片

Maven 命令:

# 清理已存在的编译结果mvn clean # 打包mvn package

打包完成后将在targe目录生成对象的jar包。

注:

Jar的相关依赖信息、包名称等等在pom文件中进行设置。

部署

将打包后的文件放置在部署服务器的指定目录下,并设置指定权限,

在该目录下编辑启动脚本start.sh:

#!/bin/sh #指定JDK目录&AppNameexport JAVA_HOME=/usr/java/jdk1.8.0_191APP_NAME=demo-0.0.1.jarecho $APP_NAME #nohup命令后台启动jar包并写入日志nohup  java -jar $APP_NAME >>logs/start.log 2>>logs/startError.log & #sleep等待15秒后,判断包含AppName的线程是否存在sleep 15if test $(pgrep -f $APP_NAME|wc -l) -eq 0then   echo “Start Failed”else   echo “Start Successed”fi

停止脚本stop.sh:

#!/bin/sh #指定AppNameAPP_NAME=demo-0.0.1.jar #找到包含AppName的进程PROCESS=`ps -ef|grep $APP_NAME|grep -v grep  |awk ‘{ print $2}’`#循环停用进程直到成功while :do  kill -9 $PROCESS > /dev/null 2>&1  if [ $? -ne 0 ];then   break  else   continuefidoneecho ‘Stop Successed’

给两个脚本赋予可执行权限后,即可使用脚本来启动或者停止 Spring Boot 服务。

配置 Nginx

在 /etc/nginx/conf.d 新建APP对应的配置文件demo.conf:

#反向代理配置内容server {    listen       80;        #监听80端口    server_name  10.0.0.16; #绑定的域名    access_log /var/log/nginx/nginx.log;    error_log /var/log/nginx/nginx.error;    location /api {            #转发或处理        proxy_set_header Host $host;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;        proxy_pass http://10.0.0.16:8081/;    }    error_page   500 502 503 504  /50x.html;#错误页    location = /50x.html {        root   /usr/share/nginx/html;    }}

注:

设置完成后重启或者重新加载Nginx

重新加载 Nginx:nginx -s reload

重启 Nginx:systemctl restart nginx

如此几步,简单完成Spring Boot 的部署。

以上步骤为手工完成,如需自动化完成,请关注我们的《测试运维系列之运维从零开始》课程吧

声明:文中观点不代表本站立场。本文传送门:https://eyangzhen.com/186898.html

(0)
联系我们
联系我们
分享本页
返回顶部