不要将 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