Spring Cloud Gateway的部署

不要将 Spring Cloud Gateway 部署到 Tomcat

可以将Spring Cloud Gateway打成jar包,并通过jar包部署,步骤:

1. 修改构建配置

确保你的pom.xml文件中的打包方式为jar。

<packaging>jar</packaging>

2 打包项目

mvn clean package

3.通过Java命令来运行

java -jar gatewayservice.jar

请将gatewayservice.jar替换为你的jar文件的实际名称。

这个命令会启动一个Java虚拟机(JVM),加载并运行jar文件中的程序。Spring Cloud Gateway将开始监听配置的端口,并处理传入的请求。

如果想要传递额外的配置参数或系统属性给Spring Cloud Gateway,你可以在java -jar命令后面添加它们。例如:

java -jar gatewayservice.jar --spring.profiles.active=prod

在这个例子中,--spring.profiles.active=prod是一个Spring Boot属性,用于激活名为prod的配置文件。

另一种更常见方法是使用外部配置文件来覆盖jar包中的默认配置。

你可以将配置文件(如application.yml)复制到特定的目录(例如当前目录或指定的配置目录),然后在运行jar包时通过命令行参数指定该配置文件的位置。例如:

java -jar gatewayservice.jar --spring.config.location=/opt/application.yml

运行时如果不指定配置文件,程序会使用其内置的默认配置。这些默认配置通常是在应用程序的代码中硬编码的,或者在应用程序打包时就已经确定的一些固定值。

在实际应用中,开发人员通常会提供一个或多个外部配置文件来覆盖这些默认配置,以满足特定的应用需求。

以服务的方式运行jar包

在Linux下,将jar包以服务的方式运行通常涉及将jar包的启动脚本集成到系统的服务管理器中,例如使用systemd、upstart或SysV init脚本。

以下是如何使用systemd将jar包作为服务运行的步骤:

1. 创建systemd服务文件

创建一个以.service为后缀的systemd服务文件。它描述了如何启动、停止和重启你的服务。

例如,创建一个名为gatewayservice.service的文件,并将其放置在/etc/systemd/system/目录下:

Unit

Description=distributed gateway demo

After=network.target

Service

Type=simple

ExecStart=/usr/bin/java -jar /opt/mainservice/mainservice.jar --spring.config.location=/opt/mainservice/application.yml

User=root

Restart=on-failure

Install

WantedBy=multi-user.target

注意事项:

确保 /usr/bin/java Java **运行时的正确路径。**你可以通过运行which java来找到它。

如果你的jar包依赖于特定的类路径或系统属性,你可能需要在ExecStart行中添加它们。

/opt/mainservice/mainservice.jar

为你的jar包的实际路径

root为运行服务的用户。

2. 重新加载systemd并启动服务

在创建服务文件后,你需要通知systemd有关新服务的存在,并启动它:

sudo systemctl daemon-reload

sudo systemctl start gatewayservice

3. 设置服务开机自启

如果你想让服务在系统启动时自动运行,你可以使用以下命令:

sudo systemctl enablegatewayservice

4. 检查服务状态

你可以使用以下命令来检查服务的状态:

sudo systemctl statusgatewayservice

5. 停止和重启服务

如果需要停止服务,可以使用:

sudo systemctl stopgatewayservice

如果需要重启服务,可以使用:

sudo systemctl restartgatewayservice

相关推荐
XiaoLeisj17 分钟前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
风象南17 分钟前
SpringBoot实现数据库读写分离的3种方案
java·spring boot·后端
振鹏Dong24 分钟前
策略模式——本质是通过Context类来作为中心控制单元,对不同的策略进行调度分配。
java·策略模式
ChinaRainbowSea33 分钟前
3. RabbitMQ 的(Hello World) 和 RabbitMQ 的(Work Queues)工作队列
java·分布式·后端·rabbitmq·ruby·java-rabbitmq
雾月5533 分钟前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
melck1 小时前
liunx日志查询常用命令总结
java·服务器·网络
守护者1701 小时前
JAVA学习-练习试用Java实现“实现一个Hadoop程序,使用Hive进行复杂查询和数据筛查”
java·学习
程序员 小柴1 小时前
docker的与使用
java·docker·eureka
ゞ 正在缓冲99%…1 小时前
leetcode76.最小覆盖子串
java·算法·leetcode·字符串·双指针·滑动窗口
Seven971 小时前
【Guava】并发编程ListenableFuture&Service
java