spring遇到的问题汇总

有关日志的打印和日志如何使用

在实际项目中,我们的程序都是运行在linux上,有错误时也不能在本地的控制台上直观看到,所有合理打印日志对于程序员迅速定位到错误。

打印日志时的步骤

  1. application.yml配置文件中配置日志级别和日志文件的路径
  1. logging:
  2. level:
  3. learning: debug
  4. file: log/app-user.log
  1. 在controller中定义log对象
  1. private static final Logger log = LoggerFactory.getLogger(VehicelController.class);
  1. 打印日志

在关键的节点使用info打印

  1. log.info("程序开始")
  2. log.info("程序结束")

在处理异常处使用error打印

  1. try {
  2. .....
  3. .....
  4. } catch (Exception e) {
  5. e.printStackTrace();
  6. log.error("异常{}", e);
  7. ;
  8. }

日志中name和path的关系

  1. logging.file.path logging.file.name 两个同时存在的时候 logging.file.name的优先级更高,所以logging.file.path不会生效;
  2. 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)可以任意命名

正确写法:

  1. @Component
  2. public class MyConfig {
  3. private static String env;
  4. public static String getEnv() {
  5. return env;
  6. }
  7. @Value("${env}")
  8. public void setEnv(String env) {
  9. MyConfig.env = env;
  10. }
  11. }

注意一定是在非静态方法setEnv前使用@Value注解。也就是说要把set方法前面的static去掉。

这里是个坑。要注意

关于return写在finally块里的情况

链接:异常处理中在finally里面写return会怎么样 - CSDN

关于nohup运行程序

链接: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 &

解释:

  1. nohup表示后台运行,需要在末尾加&

  2. 中间的是jvm参数

  3. >>/opt/fileStore/jar/logs/log.txt 表示标准输出日志到该位置

  4. 2>&1 标准错误输出到同样位置。如果不加会报一句话 nohup: ignoring input and redirecting stderr to stdout ,但是不影响使用。

  5. jvm参数解释

    1. -Xms1024m 配置初始堆内存1024m;
    2. -Xmx1024m 配置最大堆内存1024m;
    3. -XX:PermSize=256m Perm(俗称方法区)占整个堆内存的值;
    4. -XX:MaxPermSize=512m 方法区占整个堆内存的最大值
    5. -XX:MaxNewSize=512m 新生代内存上限值

如何使用log4j

链接:log4j使用说明 - CSDN

spring boot项目问题汇总的更多相关文章

  1. spring boot项目发布tomcat容器(包含发布到tomcat6的方法)

    spring boot因为内嵌tomcat容器,所以可以通过打包为jar包的方法将项目发布,但是如何将spring boot项目打包成可发布到tomcat中的war包项目呢? 1. 既然需要打包成wa ...

  2. Spring Boot项目的打包和部署

    补充一点:搜索了下别人Spring Boot部署方案,大多都说:①packaging设为war:②要添加Spring Boot的tomcat依赖:③修改output路径,但是使用STS新建Spring ...

  3. 新建一个新的spring boot项目

    简单几步,在Eclipse中创建一个新的spring Boot项目: 1.Eclipse中安装STS插件: Help -> Eclipse Marketplace... Search或选择&qu ...

  4. 用Gradle构建Spring Boot项目

    相比起Maven的XML配置方式,Gradle提供了一套简明的DSL用于构建Java项目,使我们就像编写程序一样编写项目构建脚本.本文将从无到有创建一个用Gradle构建的Spring Boot项目, ...

  5. Spring boot 1: 使用IDEA创建Spring boot项目

    项目用到的环境: Windows 10 JDK8 IntelliJ IDEA 2017.1.3 Apache Tomcat 8 Maven 3.3.3 使用IDEA新建spring boot项目 新建 ...

  6. [读书笔记] 一、Spring boot项目搭建与配置文件

    读书笔记:[JavaEE开发的颠覆者 Spring Boot实战] 作者:汪云飞 从今天开始坚持读书,并记录下此读书笔记. 一,初接触 Spring boot 项目Hello world搭建 1.po ...

  7. spring boot系列01--快速构建spring boot项目

    最近的项目用spring boot 框架 借此学习了一下 这里做一下总结记录 非常便利的一个框架 它的优缺点我就不在这背书了 想了解的可以自行度娘谷歌 说一下要写什么吧 其实还真不是很清楚,只是想记录 ...

  8. spring boot项目如何测试,如何部署

    有很多网友会时不时的问我,spring boot项目如何测试,如何部署,在生产中有什么好的部署方案吗?这篇文章就来介绍一下spring boot 如何开发.调试.打包到最后的投产上线. 开发阶段 单元 ...

  9. 笔记:Spring Boot 项目构建与解析

    构建 Maven 项目 通过官方的 Spring Initializr 工具来产生基础项目,访问 http://start.spring.io/ ,如下图所示,该页面提供了以Maven构建Spring ...

随机推荐

  1. JQuery ajax request及Java服务端乱码问题及设置

    今天花了半天功夫才搞定2个乱码问题 1. 原先一直用form提交,现在改作JQuery ajax 提交,发现乱码. 2. window.location url中含有中文提交后,乱码. 第一个问题: ...

  2. python 无损压缩照片,支持批量压缩,支持保留照片信息

    由于云盘空间有限,照片尺寸也是很大,所以写个Python程序压缩一下照片,腾出一些云盘空间 1.批量压缩照片 新建 photo_compress.py 代码如下 1 # -*- coding: utf ...

  3. matplotlib学习日记(四)-绘制直方统计图形

    (一)柱状图-应用在定性数据的可视化场景或者离散型数据,条形图和柱状图相似,只不过是函数barh import matplotlib as mpl import matplotlib.pyplot a ...

  4. python初学者-从键盘获取信息

    name = input(">>> 姓名:") QQ = input(">>>QQ: ") phone_num = inpu ...

  5. [Python] iupdatable包:获取电脑主板信息(csproduct)

    一.说明 使用命令行就可以获取到主板相关的信息 wmic csproduct get /value 输出内容如下: Caption=Computer System Product Descriptio ...

  6. 4.自定义view-进度条控件

    1.效果 2.实现原理 画圆,画圆弧,画文字 外部控制进度,通过invalidate()方法更新 核心代码: @Override protected void onDraw(Canvas canvas ...

  7. Linux(Centos7)安装、使用 Docker

    一.Linux(CentOS7) 上安装 docker 1.docker 是什么? docker 是一种 虚拟化容器技术,一个开源的应用容器引擎. 基于镜像,可以秒级启动各种容器(运行一次镜像就生成一 ...

  8. idea修改项目名导致无法找到主类

    描述 本地创建项目copy或者是修改项目名和文件夹名称后 启动springboot项目失败 控制台报错 错误无法找到主类 解决办法 1. 求助互联网得知 需要执行 mvn clean install( ...

  9. 微服务痛点-基于Dubbo + Seata的分布式事务(TCC模式)

    前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...

  10. Java虚拟机详解04----GC算法和种类

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...