先介绍下java系统的日志

日志框架:是一种日志接口,不负责具体的日志输出形式(有点类似于JDBC),可以灵活的切换日志输出形式。常见的日志框架有slf4j、jcl,只提供Logger、LoggerFactory等接口

日志系统:是应用实际使用的日志工具,主要有log4j,jul,logback等。一般在程序中应该避免直接使用,可以保证程序具有一定的灵活性。

Logger:日志输出实例,包含Appender和Layout

Appender:日志输出目标,如控制台,文件,数据库等。多个Appender可以被关联到任何Logger上,所以可以到多个输出文件上记录相同的信息。

Layout:定义日志输出格式:时间戳、线程名称、日志级别、日志内容、对应输出该日志的类、对应输出该日志的方法、行号及MDC信息

Level :日志级别,通过配置不同的日志界别来打印不同的日志信息。

log4j定义了8个级别的log(除去OFF和ALL,可以说分为6个级别),优先级从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。

Log4j建议只使用四个级别,优先级 从高到低分别是 ERROR、WARN、INFO、DEBUG。日志记录器(Logger)的行为是分等级的:

日志记录器(Logger)是日志处理的核心组件。log4j具有5种正常级别(Level)。:

1.static Level DEBUG :

DEBUG Level指出细粒度信息事件对调试应用程序是非常有帮助的。

2.static Level INFO

INFO level表明 消息在粗粒度级别上突出强调应用程序的运行过程。

3.static Level WARN

WARN level表明会出现潜在错误的情形。

4.static Level ERROR

ERROR level指出虽然发生错误事件,但仍然不影响系统的继续运行。

5.static Level FATAL

FATAL level指出每个严重的错误事件将会导致应用程序的退出。

另外,还有两个可用的特别的日志记录级别:

1.static Level ALL

ALL Level是最低等级的,用于打开所有日志记录。

2.static Level OFF

OFF Level是最高等级的,用于关闭所有日志记录。

针对于日志级别的问题分析如下:

一、场景描述:

“xx交易”单交易200并发下稳定执行10分钟,TPS为47,两台门户前置平均cpu占用81%,其中sys利用率达到32%。(日志级别为info)

分析过程

1、抓取并分析javacore文件

阻塞进程共92个。其中85个线程被同一个线程阻塞(即WebContainer:2184),此线程抓取javacore文件的瞬间正在调用org/apache/log4j/spi/LocationInfo方法。线程阻塞现象会降低并发处理性能,因此分析客户登录交易性能差可能与log4j写日志有关。如图所示:

2、验证性测试:降低日志级别测试,即由info级别改为error级别

抓取javacore文件并分析

阻塞线程仅有18个,其中仅有2个线程被同一个线程阻塞(即WebContainer:92)。

3、对比

测试结果对比:相同测试场景分别在info和error级别下,TPS、资源利用率等对比

序号

日志级别

并发数

TPS

两台前置服务器cpu平均利用率

1

Info

200

47

81%(其中sys使用34%)

2

Error

200

108

81%(其中sys使用7.5%)

日志输出量对比:分别在info和error级别下,执行1次客户登录操作,产生的日志量对比

日志文件

Info级别(byte)

Error级别(byte)

portalweb_all.log

28242

396

portalweb_business.log

21567

396

portalweb_db.log

263

0

portalweb_sign.log

0

0

总量

50072

792

结论

日志级别即日志的输出量对系统性能具有一定的影响。

四、建议

建议项目组修改info级别下的日志输出量,以提高系统处理能力。

java日志级别的作用_Java系统日志级别对性能的影响性相关推荐

  1. java 日志框架 详解_java日志框架系列(9):logback框架过滤器(filter)详解

    过滤器放在了logback-classic模块中. 1.logback-classic模块中过滤器 分类(2种):常规过滤器.TurboFilter过滤器. 1.常规过滤器 常规过滤器可以通过自定义进 ...

  2. java 日志管理源码_Java源码初探_logging日志模块实现

    一.用途 程序中记录日志,打印到控制台.文件等方式,记录过程可根据日志级别做筛选,日志格式可以自定义. 大概结构如下所示: 简要说明各个模块: (1) LogManager:管理LoggerConte ...

  3. java类与对象作用_Java类与对象

    ●类和对象的关系: 一:类是对同一类事物(对象)的抽象,对象实际存在的该类的各种实体. 二:面向对编程的核心:找合适的对象来做合适的事. 三:Java中找到对象: 1):sun自己定义好的类,必须知道 ...

  4. java 代码块的作用_Java核心(三):代码块的作用

    Java中用{ }括起来的代码段就是代码块,他分为如下几种类型 位置 作用 局部代码块 在方法当中使用,作用是控制变量的生命周期. 局部代码块的变量,只能在代码块内部使用,在执行结束后会被Java回收 ...

  5. java 中gui的作用_java学习中最应该注意的Java GUI用户界面以何为基础

    java中的GUI编程(Graphic User Interface,图形用户接口),是在它的笼统窗(Abstract Window Toolkit,AWT)上完成的,java.awt是AWT的东西类 ...

  6. java volatile关键字的作用_java volatile关键字作用及使用场景详解

    1. volatile关键字的作用:保证了变量的可见性(visibility).被volatile关键字修饰的变量,如果值发生了变更,其他线程立马可见,避免出现脏读的现象.如以下代码片段,isShut ...

  7. java中flush函数作用_Java语言中flush()函数作用及使用方法详解

    最近在学习io流,发现每次都会出现flush()函数,查了一下其作用,起作用主要如下 //------–flush()的作用--------– 笼统且错误的回答: 缓冲区中的数据保存直到缓冲区满后才写 ...

  8. java 注解处理器的作用_Java注解处理器

    Java中的注解(Annotation)是一个很神奇的东西,特别现在有很多Android库都是使用注解的方式来实现的.一直想详细了解一下其中的原理.很有幸阅读到一篇详细解释编写注解处理器的文章.本文的 ...

  9. java中result的作用_JAVA中的Resultset

    JAVA中的Resultset (2012-04-21 14:53:34) 标签: it JAVA中Resultset是一个类 . 结果集(ResultSet)是数据中查询结果返回的一种对象,可以说结 ...

最新文章

  1. Android模拟器Genymotion使用详解
  2. Java NIO示例:多人网络聊天室
  3. java io 视频 下载_Java下载映客主播视频回放到电脑硬盘
  4. 并发数据结构-1.1 并发的数据结构的设计
  5. python数据挖掘与分析实战pdf_《Python数据分析与挖掘实战》PDF+完整源码
  6. 当SQL Server爱上Linux:配置 SQL Server 2017 上的可用性组初体验
  7. Python文摘:Mixin
  8. 先装vs还是先装sql_止回阀该装在出口阀前还是阀后?
  9. 关于lidroid xUtils 开源项目
  10. 基于python/opencv/tesseract使用传统方法的,表格图片版面分析以及印刷体汉字识别(持续更新,学习备份用)
  11. Python基础语法回顾
  12. Windows上传文件到CentOS系统
  13. 地面监视雷达系统的设计与试验
  14. 这家公司用AI生成颠覆内容创作!
  15. vs无法提示sourcetree的变基修改代码
  16. 武候祠:一千七百年的沉思
  17. matlab和通达信,通达信dllmatlab
  18. 另一个jar包引不了_佛说:失去是另一种拥有(醍醐灌顶,发人深思!)
  19. CTF常规密码学加解密脚本(python)
  20. flink1.13.2源码编译遇到的坑1.Failed to execute goal org.apache.rat:apache-rat-plugin:0.12

热门文章

  1. 1506G. Maximize the Remaining String
  2. 统计源期刊目录_统计源期刊是什么意思
  3. linux vi使用手册,史上最全VIM使用手册
  4. CosiWorksNew
  5. 南京大学c语言试卷,2007年4月南京大学C语言期中试题.doc
  6. 间歇性掉帧卡顿_电脑卡顿问题靠它解决,我只能帮你到这儿了
  7. view类不响应自定义消息_安卓平台如何给控件添加自定义操作?
  8. 神经网络与深度学习——TensorFlow2.0实战(笔记)(五)(Matplotlib绘图基础<1>python)
  9. 【转】理解OAuth 2.0
  10. 静态html js文件上传,js实现动态添加上传文件页面