例如:第一章 Python 机器学习入门之pandas的使用
提示:以下是本篇文章正文内容,下面案例可供参考
(1)程序打包的原因:将程序部署在独立的服务器上
(2)步骤
①:对SpringBoot项目打包(执行Maven构建指令package)
执行 package 打包命令之前,先执行 mvn clean, 删除 target 目录及内容,然后跳过 test 生命周期
cLean成功
跳过 test 生命周期
打包完成生成对应的 jar 文件
②:运行
地址栏输入 cmd 回车
回车后弹出下列窗口
运行项目(执行启动指令) java -jar <打包文件名>
java –jar springboot.jar
③:浏览器访问: http://localhost//pages/books.html
④:注意事项:jar支持命令行启动需要依赖maven插件支持,请确认打包时是否具有SpringBoot对应的maven插件
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
(3)打包插件
如果没有配制springboot 打包插件可能遇到下面的问题:
如果没有配制spring boot 打包插件可能遇到下面的问题:
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
(4)命令行启动常见问题及解决方案
①:Windonws端口被占用
# 查询端口
netstat -ano
# 查询指定端口
netstat -ano |findstr "端口号"
# 根据进程PID查询进程名称
tasklist |findstr "进程PID号"
# 根据PID杀死任务
taskkill /F /PID "进程PID号"
# 根据进程名称杀死任务
taskkill -f -t -im "进程名称"
(1)带属性数启动SpringBoot
java -jar springboot_08_ssmp-0.0.1-SNAPSHOT.jar --server.port=8080
携带多个属性启动SpringBoot,属性间使用空格分隔
(2)属性加载优先顺序
参看https://docs.spring.io/spring-boot/docs/current/reference/html/spring-boot-features.html#boot-features-external-config
(3)小结
(1)临时属性设置
①:带属性启动SpringBoot程序,为程序添加运行属性
(②:通过编程形式带参数启动SpringBoot程序,为程序添加运行参数
public static void main(String[] args) {
String[] arg = new String[1];
arg[0] = "--server.port=8080";
SpringApplication.run(SSMPApplication.class, arg);
}
③:不携带参数启动SpringBoot程序
public static void main(String[] args) {
//可以在启动boot程序时断开读取外部临时配置对应的入口,也就是去掉读取外部参数的形参
SpringApplication.run(SSMPApplication.class);
}
(1)SpringBoot中4级配置文件
(2)小结
#应用环境
#公共配制
spring:
profiles:
active: pro
---
# 设置环境
#生产环境
spring:
config:
activate:
on-profile: test
server:
port: 80
---
#生产环境
spring:
config:
activate:
on-profile: dev
server:
port: 81
---
# 测试环境
spring:
config:
activate:
on-profile: test
server:
port: 82
#应用环境
#公共配制
spring:
profiles:
active: test
(2)环境分类配置文件application-pro.yml
server:
port: 8080
(3)环境分类配置文件application-dev.yml
server:
port: 8081
(4)环境分类配置文件application-test.yml
server:
port: 8082
(5)多环境开发配置文件书写技巧(一)
①:主配置文件中设置公共配置(全局)
②:环境分类配置文件中常用于设置冲突属性(局部)
(6)小结
①:可以使用独立配置文件定义环境属性
②:独立配置文件便于线上系统维护更新并保障系统安全性
(1)主启动配置文件application.yml
spring.profiles.active=dev
(2)环境分类配置文件application-pro.properties
server.port=9081
(3)环境分类配置文件application-dev.properties
server.port=9082
(4)环境分类配置文件application-test.properties
server.port=9083
(5)小结
①:properties文件多环境配置仅支持多文件格式
(1)多环境开发独立配置文件书写技巧(二)
根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下
(2)使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号分隔
spring:
profiles:
active: dev
include: devDB,devMVC
注意事项:
当主环境dev与其他环境有相同属性时,主环境属性生效;其他环境中有相同属性时,最后加载的环境属性生效
The following profiles are active: devDB,devMVC,dev
(3)
spring:
profiles:
active: dev
group:
"dev": devDB,devMVC
"pro": proDB,proMVC
"test": testDB,testRedis,testMVC
注意事项:
使用group属性,会覆盖 主环境dev (active) 的内容,最后加载的环境属性生效
The following profiles are active: dev,devDB,devMVC
(4)小结
(1)日志(log)作用
编程期调试代码
运营期记录信息
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
②:添加日志记录操作
//创建记录日志的对象
private static final Logger log = LoggerFactory.getLogger(BookController.class);
@GetMapping
public String getById(){
System.out.println("SpringBoot is running...");
log.debug("debug ...");
log.info("info ...");
log.warn("warn ...");
log.error("error ...");
return "SpringBoot is running...";
}
③:日志级别
TRACE:运行堆栈信息,使用率低
DEBUG:程序员调试代码使用
INFO:记录运维过程数据
WARN:记录运维过程报警数据
ERROR:记录错误堆栈信息
FATAL:灾难信息,合并计入ERROR
④:设置日志输出级别
# 开启 debug 模式,输出调试信息,常用于检查系统运行状况
debug: true
# 设置日志级别, root 表示根节点,即整体应用日志级别
logging:
level:
root: debug
⑤:设置日志组,控制指定包对应的日志输出级别,也可以直接控制指定包对应的日志输出级别
logging:
# 设置分组
group:
# 自定义组名,设置当前组中所包含的包
ebank: com.yan.controller,com.yan.service,com.yan.mapper
iservice: com.alibaba
level:
root: info
# 设置某个包的日志级别
# com.yan.controller: debug
# 为对应组设置日志级别
ebank: warn
①:使用lombok提供的注解@Slf4j简化开发,减少日志对象的声明操作
@Slf4j
//Rest模式
@RestController
@RequestMapping("/books")
public class BookController {
@GetMapping
public String getById(){
System.out.println("springboot is running...");
log.debug("debug...");
log.info("info...");
log.warn("warn...");
log.error("error...");
return "springboot is running...";
}
}
②:小结
基于lombok提供的@Slf4j注解为类快速添加日志对象
#设置日志模板格式
logging:
pattern:
console: "%d - %m%n"
logging:
pattern:
# console: "%d - %m%n"
console: "%d %clr(%5p) --- [%16t] %clr(%-40.40c){cyan} : %m %n"
(1)设置日志文件
logging:
file:
name: server.log
(2)日志文件详细配置
logging:
file:
name: server.log
logback:
rollingpolicy:
max-file-size: 4KB
file-name-pattern: server.%d{yyyy-MM-dd}.%i.log
(3)小结
①:日志记录到文件
②:日志文件格式设置