package com.djc.boot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @author JIACHENGER
* @Description 配置springboot、jenkins、gitlab自动化部署测试项目
* @since 10/6/2023 3:54 下午
*/
/*
* 2023-10-6 16:28:13
* #@RestController是一个合成注解,由@ReponseBody和@Controller合成,具有两个注解的功能。
* #@ReponseBody:给浏览器返回纯文本。
*
* 2023-10-6 16:29:16
* 关于我们的MyApplication类是 @Rest控制器。这称为刻板印象注释。它为阅读代码的人提供了提示,并为Spring提供了类扮演特定角色的提示。
* 在这种情况下,我们的类是一个web@Controller,所以Spring在处理传入的web请求时会考虑它。
*
*这个@RequestMapping注释提供了“路由”信息。它告诉Spring /路径应映射到home方法 @Rest控制器注释告诉Spring将结果字符串直接返回给调用者。
*
*
* @SpringBootApplication
* 第二个类级注释是@SpringBootApplication。此注释称为元注解,它结合了@SpringBootConfiguration ,
* @enableautoconfiguration和@ComponentScan .
* 其中,我们最感兴趣的注释是@EnableAutoConfiguration .@enableautoconfiguration告诉Spring Boot根据您添加的jar依赖项
* “猜测”您想要如何配置Springspring-boot-starter-web添加了Tomcat和Spring MVC,自动配置假定您正在开发web应用程序并相应
* 地设置Spring。
*
*
*
*/
@RestController
@SpringBootApplication
public class MainApplication {
@RequestMapping("/")
String home() {
return "Hello World! 2023-10-6 16:42:14 DJCKING *** ";
}
public static void main(String[] args) {
SpringApplication.run(MainApplication.class, args);
}
}
参考我这篇文章的命令 Error running ‘Tomcat 8.5.29‘ Address localhost:1099 is already in use
//1-查看端口占用,根据端口号1099,获取PID(进程ID)
netstat -ano | findstr "端口号"
//查看PID对应的进程
tasklist | findstr "进程ID"
//2-根据PID结束进程
taskkill /F /PID PID值
或者
taskkill -f -pid PID值
或者(可能会直接结束intellij IDEA,相当于任务管理器中结束intellij IDEA 2023-10-6 16:56:00 补充)
taskkill /f /t /im PID值
注意
:执行taskkill /F /PID 22096
或taskkill -f -pid 22096
或taskkill /f /t /im 22096
可能会直接结束Intellij IDEA应用
。
SpringBoot 内置了 Tomcat服务器 ,所以不能直接在IDE中配置Tomcat的端口,可以通过配置文件的方式来指定Tomcat的端口。
在项目目录下的src/main/resources
中新建application.properties
文件,配置Tomcat端口8090
:
#符号表示注释
#application.properties配置文件中指定Tomcat端口,解决8080 端口占用问题
#application.properties与application.yml两个配置文件二选一
server.port=8090
或者
在项目目录下的src/main/resources
中新建application.yml
文件,配置配置Tomcat端口8091
:
#符号表示注释
#application.yml与application.properties两个配置文件二选一
#Tomcat
server:
port: 8091
setDefaultProperties()
方法将server.port
设置为8010
。接受一个Map类型键值对参数
,其中key
是属性名
,value
是属性值
。
关键设置端口代码:
//通过代码设置端口 2023-10-6 23:25:24
SpringApplication sapp = new SpringApplication(MainApplication.class);
sapp.setDefaultProperties(Collections.singletonMap("server.port", "8010"));
sapp.run(args);
完整代码:
package com.djc.boot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Collections;
/**
* @author JIACHENGER
* @Description 配置springboot、jenkins、gitlab自动化部署测试项目
* @since 10/6/2023 3:54 下午
*/
/*
* 2023-10-6 16:28:13
* #@RestController是一个合成注解,由@ReponseBody和@Controller合成,具有两个注解的功能。
* #@ReponseBody:给浏览器返回纯文本。
*
* 2023-10-6 16:29:16
* 关于我们的MyApplication类是 @Rest控制器。这称为刻板印象注释。它为阅读代码的人提供了提示,并为Spring提供了类扮演特定角色的提示。
* 在这种情况下,我们的类是一个web@Controller,所以Spring在处理传入的web请求时会考虑它。
*
*这个@RequestMapping注释提供了“路由”信息。它告诉Spring /路径应映射到home方法 @Rest控制器注释告诉Spring将结果字符串直接返回给调用者。
*
*
* @SpringBootApplication
* 第二个类级注释是@SpringBootApplication。此注释称为元注解,它结合了@SpringBootConfiguration ,
* @enableautoconfiguration和@ComponentScan .
* 其中,我们最感兴趣的注释是@EnableAutoConfiguration .@enableautoconfiguration告诉Spring Boot根据您添加的jar依赖项
* “猜测”您想要如何配置Springspring-boot-starter-web添加了Tomcat和Spring MVC,自动配置假定您正在开发web应用程序并相应
* 地设置Spring。
*
*
*
*/
@RestController
@SpringBootApplication
public class MainApplication extends SpringBootServletInitializer {
@RequestMapping("/")
String home() {
return "Hello World! 2023-10-6 16:42:14 DJCKING *** ";
}
public static void main(String[] args) {
//SpringApplication.run(MainApplication.class, args);
//通过代码设置端口 2023-10-6 23:25:24
SpringApplication sapp = new SpringApplication(MainApplication.class);
sapp.setDefaultProperties(Collections.singletonMap("server.port", "8010"));
sapp.run(args);
}
}
如果将项目部署在Docker容器
中,需要Dockerfile
中设置EXPOSE
指令以指定端口。
如下网关服务-gateway.jar
# 基础镜像
FROM anapsix/alpine-java:8_server-jre_unlimited
# author
MAINTAINER djc
# 挂载目录
VOLUME /home/ruoyi202381
# 创建目录
RUN mkdir -p /home/ruoyi202381
# 指定路径 指定工作目录
WORKDIR /home/ruoyi202381
# 复制jar文件到路径
COPY ./jar/gateway.jar /home/ruoyi202381/gateway.jar
# 暴露端口 2023-9-29 00:02:07
# EXPOSE 端口号 例如:EXPOSE 8104
EXPOSE 8096
# 启动用户服务 网关服务
ENTRYPOINT ["java","-jar","gateway.jar"]