Spring Cloud Gateway的部署

发布于:2024-05-07 ⋅ 阅读:(27) ⋅ 点赞:(0)

不要将 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/javaJava运行时的正确路径。你可以通过运行which java来找到它。

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

/opt/mainservice/mainservice.jar

为你的jar包的实际路径

root为运行服务的用户。

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

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

sudo systemctl daemon-reload

sudo systemctl start gatewayservice

3. 设置服务开机自启

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

sudo systemctl enable gatewayservice

4. 检查服务状态

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

sudo systemctl status gatewayservice

5. 停止和重启服务

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

sudo systemctl stop gatewayservice

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

sudo systemctl restart gatewayservice