spring boot项目问题汇总
spring遇到的问题汇总
有关日志的打印和日志如何使用
在实际项目中,我们的程序都是运行在linux上,有错误时也不能在本地的控制台上直观看到,所有合理打印日志对于程序员迅速定位到错误。
打印日志时的步骤
- application.yml配置文件中配置日志级别和日志文件的路径
logging:
level:
learning: debug
file: log/app-user.log
- 在controller中定义log对象
private static final Logger log = LoggerFactory.getLogger(VehicelController.class);
- 打印日志
在关键的节点使用info打印
log.info("程序开始")
log.info("程序结束")
在处理异常处使用error打印
try {
.....
.....
} catch (Exception e) {
e.printStackTrace();
log.error("异常{}", e);
;
}
日志中name和path的关系
logging.file.path 和 logging.file.name 两个同时存在的时候 logging.file.name的优先级更高,所以logging.file.path不会生效;
logging.file.path 默认的日志文件为指定路径下的spring.log,logging.file.name则可以自己指定路径和文件名;
有关静态值的注入
使用@Value
注解static类型的时候,会返回null值。需要注解在非静态方法、变量上。
文章链接:SpringBoot使用@Value给静态变量注入值 - CSDN
SpringBoot中使用@Value()只能给普通变量注入值,不能直接给静态变量赋值。
给普通变量赋值时,直接在变量声明之上添加@Value()注解即可
当要给静态变量注入值的时候,若是在静态变量声明之上直接添加@Value()注解是无效的
虽然没有编译和运行上的报错,经调试可知这种注解方式mailUsername、mailPassword、mailHost的值都是null,也就是说直接给静态变量读取配置文件是无效的
若要给静态变量赋值,可以使用set()方法,其中需要在类上加入@Component注解,方法名(例如setMailUsername)和参数名(例如username)可以任意命名
正确写法:
@Component
public class MyConfig {
private static String env;
public static String getEnv() {
return env;
}
@Value("${env}")
public void setEnv(String env) {
MyConfig.env = env;
}
}
注意一定是在非静态方法setEnv前使用@Value
注解。也就是说要把set方法前面的static去掉。
这里是个坑。要注意
关于return写在finally块里的情况
链接:异常处理中在finally里面写return会怎么样 - CSDN
关于nohup运行程序
示例:
nohup java -Xms4096m -Xmx8192m -XX:PermSize=1024m -XX:MaxPermSize=2048m -XX:MaxNewSize=1024m -jar /opt/fileStore/jar/file-store-0.0.1-SNAPSHOT.jar >> /opt/fileStore/jar/logs/log.txt 2>&1 &
解释:
nohup表示后台运行,需要在末尾加&
中间的是jvm参数
>>/opt/fileStore/jar/logs/log.txt 表示标准输出日志到该位置
2>&1 标准错误输出到同样位置。如果不加会报一句话
nohup: ignoring input and redirecting stderr to stdout
,但是不影响使用。jvm参数解释
-Xms1024m 配置初始堆内存1024m;
-Xmx1024m 配置最大堆内存1024m;
-XX:PermSize=256m Perm(俗称方法区)占整个堆内存的值;
-XX:MaxPermSize=512m 方法区占整个堆内存的最大值
-XX:MaxNewSize=512m 新生代内存上限值
如何使用log4j
spring boot项目问题汇总的更多相关文章
- spring boot项目发布tomcat容器(包含发布到tomcat6的方法)
spring boot因为内嵌tomcat容器,所以可以通过打包为jar包的方法将项目发布,但是如何将spring boot项目打包成可发布到tomcat中的war包项目呢? 1. 既然需要打包成wa ...
- Spring Boot项目的打包和部署
补充一点:搜索了下别人Spring Boot部署方案,大多都说:①packaging设为war:②要添加Spring Boot的tomcat依赖:③修改output路径,但是使用STS新建Spring ...
- 新建一个新的spring boot项目
简单几步,在Eclipse中创建一个新的spring Boot项目: 1.Eclipse中安装STS插件: Help -> Eclipse Marketplace... Search或选择&qu ...
- 用Gradle构建Spring Boot项目
相比起Maven的XML配置方式,Gradle提供了一套简明的DSL用于构建Java项目,使我们就像编写程序一样编写项目构建脚本.本文将从无到有创建一个用Gradle构建的Spring Boot项目, ...
- Spring boot 1: 使用IDEA创建Spring boot项目
项目用到的环境: Windows 10 JDK8 IntelliJ IDEA 2017.1.3 Apache Tomcat 8 Maven 3.3.3 使用IDEA新建spring boot项目 新建 ...
- [读书笔记] 一、Spring boot项目搭建与配置文件
读书笔记:[JavaEE开发的颠覆者 Spring Boot实战] 作者:汪云飞 从今天开始坚持读书,并记录下此读书笔记. 一,初接触 Spring boot 项目Hello world搭建 1.po ...
- spring boot系列01--快速构建spring boot项目
最近的项目用spring boot 框架 借此学习了一下 这里做一下总结记录 非常便利的一个框架 它的优缺点我就不在这背书了 想了解的可以自行度娘谷歌 说一下要写什么吧 其实还真不是很清楚,只是想记录 ...
- spring boot项目如何测试,如何部署
有很多网友会时不时的问我,spring boot项目如何测试,如何部署,在生产中有什么好的部署方案吗?这篇文章就来介绍一下spring boot 如何开发.调试.打包到最后的投产上线. 开发阶段 单元 ...
- 笔记:Spring Boot 项目构建与解析
构建 Maven 项目 通过官方的 Spring Initializr 工具来产生基础项目,访问 http://start.spring.io/ ,如下图所示,该页面提供了以Maven构建Spring ...
随机推荐
- JQuery ajax request及Java服务端乱码问题及设置
今天花了半天功夫才搞定2个乱码问题 1. 原先一直用form提交,现在改作JQuery ajax 提交,发现乱码. 2. window.location url中含有中文提交后,乱码. 第一个问题: ...
- python 无损压缩照片,支持批量压缩,支持保留照片信息
由于云盘空间有限,照片尺寸也是很大,所以写个Python程序压缩一下照片,腾出一些云盘空间 1.批量压缩照片 新建 photo_compress.py 代码如下 1 # -*- coding: utf ...
- matplotlib学习日记(四)-绘制直方统计图形
(一)柱状图-应用在定性数据的可视化场景或者离散型数据,条形图和柱状图相似,只不过是函数barh import matplotlib as mpl import matplotlib.pyplot a ...
- python初学者-从键盘获取信息
name = input(">>> 姓名:") QQ = input(">>>QQ: ") phone_num = inpu ...
- [Python] iupdatable包:获取电脑主板信息(csproduct)
一.说明 使用命令行就可以获取到主板相关的信息 wmic csproduct get /value 输出内容如下: Caption=Computer System Product Descriptio ...
- 4.自定义view-进度条控件
1.效果 2.实现原理 画圆,画圆弧,画文字 外部控制进度,通过invalidate()方法更新 核心代码: @Override protected void onDraw(Canvas canvas ...
- Linux(Centos7)安装、使用 Docker
一.Linux(CentOS7) 上安装 docker 1.docker 是什么? docker 是一种 虚拟化容器技术,一个开源的应用容器引擎. 基于镜像,可以秒级启动各种容器(运行一次镜像就生成一 ...
- idea修改项目名导致无法找到主类
描述 本地创建项目copy或者是修改项目名和文件夹名称后 启动springboot项目失败 控制台报错 错误无法找到主类 解决办法 1. 求助互联网得知 需要执行 mvn clean install( ...
- 微服务痛点-基于Dubbo + Seata的分布式事务(TCC模式)
前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...
- Java虚拟机详解04----GC算法和种类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...