文档章节

java_web_Log4j

天呀鲁哇
 天呀鲁哇
发布于 2015/02/11 10:16
字数 2963
阅读 34
收藏 3
点赞 0
评论 0

以Tomcat6.0为例,其Tomcat目录结构如下: 

bin (运行脚本) 
conf (配置文件) 
lib (核心库文件) 
logs (日志目录) 
temp (临时目录) 
webapps (自动装载的应用程序的目录) 
work (JVM临时文件目录[java.io.tmpdir]) 

让我们看看这些目录那些可以被多个Tomcat实例公用,其实只有 bin 和 lib 目录,其它目录conf、logs、temp、webapps和work每个Tomcat实例必须拥有其自己独立的备份。 
明白了上述关系就容易理解catalina.home和catalina.base的用途了。 
catalina.home指向公用信息的位置,就是bin和lib的父目录。 
catalina.base指向每个Tomcat目录私有信息的位置,就是conf、logs、temp、webapps和work的父目录。 
仅运行一个Tomcat实例时,这两个属性指向的位置是相同的。 

========================= 


如果希望将debug、info等写入日志文件的信息同时打印到控制台, 

需要在log4j中配置控制台,并且在为log4j.rootLogger赋值时,最后一个添加控制台信息, 



我目前的配置结果如下: 

log4j.rootLogger=debug,infofile,errorlogfile,D,stdout 



log4j.appender.infofile = org.apache.log4j.DailyRollingFileAppender 
log4j.appender.infofile.Threshold = INFO 
log4j.appender.infofile.File = E/://logs//20101222//loginfo 

log4j.appender.infofile.Append = true 
log4j.appender.infofile.ImmediateFlush = true 
log4j.appender.infofile.DatePattern = '_'yyyyMMdd'.log ' 
log4j.appender.infofile.layout = org.apache.log4j.PatternLayout 
log4j.appender.infofile.layout.ConversionPattern = /#ARCHIVEINFO/#%d{yyyy-MM-dd HH/:mm/:ss}%m%n 



log4j.appender.D = org.apache.log4j.RollingFileAppender 
log4j.appender.D.File = E/://logs//20101222//logdebug.log 
log4j.appender.D.MaxFileSize=1024KB 
log4j.appender.D.MaxBackupIndex = 10000 
log4j.appender.D.Append = true 
log4j.appender.D.Threshold = DEBUG 
log4j.appender.D.layout = org.apache.log4j.PatternLayout 
log4j.appender.D.layout.ConversionPattern = [%d{yyyy-MM-dd HH/:mm/:ss}]%-5p %c(line/:%L) %x-%m%n 



log4j.appender.errorlogfile = org.apache.log4j.RollingFileAppender 
log4j.appender.errorlogfile.Threshold = ERROR 
log4j.appender.errorlogfile.File = E/://logs//20101222//logerror.log 
log4j.appender.errorlogfile.Append = true 
log4j.appender.errorlogfile.layout = org.apache.log4j.PatternLayout 
log4j.appender.errorlogfile.layout.ConversionPattern =%d{yyyy-MM-dd HH:mm:ss} [%c] %m -(:%L)%n 



log4j.appender.stdout = org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.Target = System.out 
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern = [%d{yyyy-MM-dd HH/:mm/:ss}]%-5p %c(line/:%L) %x-%m%n 


===================================== 

Log4j的组成: 
Log4j由三个重要的组成构成:日志记录器(Loggers),输出端(Appenders)和日志格式化器(Layout)。 



A).Logger对象的获得或创建: 
Logger被指定为实体,由一个String类的名字识别。Logger的名字是大小写敏感的,且名字之间具有继承关系,子名用父名作为前缀,用点“.”分隔,例如x.y是x.y.z的父亲。 
root Logger(根Logger)是所有Logger的祖先,它有如下属性: 
1.它总是存在的。 
2.它不可以通过名字获得。 



B)日志级别 
每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为: 
A:off         最高等级,用于关闭所有日志记录。 
B:fatal       指出每个严重的错误事件将会导致应用程序的退出。 
C:error      指出虽然发生错误事件,但仍然不影响系统的继续运行。 
D:warm     表明会出现潜在的错误情形。 
E:info         一般和在粗粒度级别上,强调应用程序的运行全程。 
F:debug     一般用于细粒度级别上,对调试应用程序非常有帮助。 
G:all           最低等级,用于打开所有日志记录。 



C)输出端Appender 
Appender用来指定日志信息输出到哪个地方,可以同时指定多个输出目的地。Log4j允许将信息输出到许多不同的输出设备中,一个log信息输出目的地就叫做一个Appender。 
每个Logger都可以拥有一个或多个Appender,每个Appender表示一个日志的输出目的地。可以使用Logger.addAppender(Appender app)为Logger增加一个Appender,也可以使用Logger.removeAppender(Appender app)为Logger删除一个Appender。 
以下为Log4j几种常用的输出目的地。 
a:org.apache.log4j.ConsoleAppender:将日志信息输出到控制台。 
b:org.apache.log4j.FileAppender:将日志信息输出到一个文件。 
c:org.apache.log4j.DailyRollingFileAppender:将日志信息输出到一个日志文件,并且每天输出到一个新的日志文件。 
d:org.apache.log4j.RollingFileAppender:将日志信息输出到一个日志文件,并且指定文件的尺寸,当文件大小达到指定尺寸时,会自动把文件改名,同时产生一个新的文件。 
e:org.apache.log4j.WriteAppender:将日志信息以流格式发送到任意指定地方。 
f::org.apache.log4j.jdbc.JDBCAppender:通过JDBC把日志信息输出到数据库中。 




log4j.rootCategory=DEBUG, stdout, R 

#Console config 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=<%d> <%-5p> <%c> - %m(%F:%M:%L)%n 

#File config 

log4j.appender.R=org.apache.log4j.DailyRollingFileAppender 
#每天输出一个日志文件 
log4j.appender.R.DatePattern='_'yyyy-MM-dd'.log' 
#昨天的日志文件名Sendmsg+“昨天日期”.log 
log4j.appender.R.File=${catalina.home}/webapps/SSH/logs/Sendmsg.log 
#日志文件的路径,${catalina.home} 即Tomcat下 
log4j.appender.R.layout=org.apache.log4j.HTMLLayout 
#日志文件输出格式 
log4j.appender.R.layout.ConversionPattern=%d{yyyy:MM:dd:HH:mm:ss} %-5p [%C] (%F:%L) - %m%n 





============================= 

Log4j:每天或每个月产生一个日志文件配置方法(全)  

2010-01-12 17:00:14|  分类: 工作日志 |字号 订阅 
Log4j:每天或每个月产生一个日志文件,这样文件不至于过大。 或者根据日志文件大小来判断,超过规定大小,日志自动增加新文件。 

Log4j配置内容如下: 
看一个简单的java属性配置文件log4j.properties: 
properties 代码 
#指定根Logger,及日志输出级别,大于等于该级别的日志将被输出( DEBUG < INFO < WARN < ERROR < FATAL ) 设为OFF可以关闭日志   
log4j.rootLogger=DEBUG, A1,A2   
#指定log输出目的,这里设为输出日志到指定目录的文件my.log中   
log4j.appender.A1=org.apache.log4j.FileAppender   
log4j.appender.A1.File=\\logs\\my.log   #当前根目录下 
#指定日志信息的格式   
log4j.appender.A1.layout=org.apache.log4j.PatternLayout    
log4j.appender.A1.layout.ConversionPattern=%r %d{yyyy-MM-dd HH:mm:ss} %c %p -%m%n   
  
#把A2输出到控制台   
log4j.appender.A2=org.apache.log4j.ConsoleAppender   
log4j.appender.A2.layout=org.apache.log4j.SimpleLayout    
  
#还可以单独指定输出某个包的日志级别   
#log4j.logger.com.study.HelloLog4j=INFO 

1、配置根Logger,其语法为: 
log4j.rootLogger = [ level ] , appenderName, appenderName2 
level:日志的级别,指定这条日志信息的重要性。分为ALL < DEBUG < INFO < WARN <error fatal=""></error>一般常用的为 DEBUG , INFO ,WARN ,ERROR四种,分别对应Logger类的四种方法 
debug(Object message ) ; 
info(Object message ) ; 
warn(Object message ) ; 
error(Object message ) ; 
如果设置级别为INFO,则优先级大于等于INFO级别(如:INFO、WARN、ERROR)的日志信息将可以被输出,小于该级别的如:DEBUG将不会被输出 
appenderName :就是指定日志信息输出目的地,比如(打印到控制台,输出到文件等)。同一条日志信息可以配置多个输出目的地。 
2、配置log输出目的地 
Log4j提供以下几种: 
org.apache.log4j.ConsoleAppender(控制台) 
org.apache.log4j.FileAppender(文件) 
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) 
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件) 
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) 
3、log信息的格式 
org.apache.log4j.HTMLLayout(HTML表格形式) 
org.apache.log4j.SimpleLayout(简单格式的日志,只包括日志信息的级别和指定的信息字符串 ,如:DEBUG - Hello) 
org.apache.log4j.TTCCLayout(日志的格式包括日志产生的时间、线程、类别等等信息) 
org.apache.log4j.PatternLayout(灵活地自定义日志格式) 
当使用org.apache.log4j.PatternLayout来自定义信息格式时,可以使用 
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p -%m%n 来格式化信息 
%c    输出所属类的全名,可写为 %c{Num} ,Num类名输出的范围  如:"com.sun.aaa.classB", %C{2}将使日志输出输出范围为:aaa.classB 
%d    输出日志时间其格式为 可指定格式 如 %d{HH:mm:ss}等 
%l    输出日志事件发生位置,包括类目名、发生线程,在代码中的行数 
%n    换行符 
%m    输出代码指定信息,如info(“message”),输出message 
%p    输出日志的优先级,即 FATAL ,ERROR 等 
%r    输出从启动到显示该条日志信息所耗费的时间(毫秒数) 
%t    输出产生该日志事件的线程名 

三、按照一定时间产生日志文件,配置文件如下: 
    # Set root logger level to ERROR and its only appender to A1. 
    log4j.rootLogger=ERROR,R 

    # R is set to be a DailyRollingFileAppender. 
    log4j.appender.R=org.apache.log4j.DailyRollingFileAppender 

    log4j.appender.R.File=backup.log 
    log4j.appender.R.DatePattern = '.'yyyy-MM-dd 
    log4j.appender.R.layout=org.apache.log4j.PatternLayout 
    log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n 
     
    以上配置是每天产生一个备份文件。其中备份文件的名字叫backup.log。 
    具体的效果是这样:当天的日志信息记录在backup.log文件中,前一天的记录在名称为   backup.log.yyyy-mm-dd 的文件中。 
    类似的,如果需要每月产生一个文件可以修改上面的配置: 
    将 
      log4j.appender.R.DatePattern = '.'yyyy-MM-dd 
    改为 
        log4j.appender.R.DatePattern = '.'yyyy-MM 
如下所示: 
#Global variable definition 
LOG_FILE=F:/logs/backup.log 
LOG_LEVEL=DEBUG 
# File Appender Definition 
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.logfile.File=${LOG_FILE} 
log4j.appender.logfile.DatePattern = '.'yyyy-MM 
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout 
log4j.appender.logfile.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n 
# com.microsoft Logger 
log4j.logger.org.stephencat.cat=${LOG_LEVEL}, logfile 
log4j.additivity.org.stephencat.cat=false(文件日志将只输出到logfile中) 
四、根据日志文件大小自动产生新日志文件 
    配置文件内容如下: 

# Set root logger level to ERROR and its only appender to A1. 
log4j.rootLogger=ERROR,R 

# R is set to be a RollingFileAppender. 
log4j.appender.R=org.apache.log4j.RollingFileAppender 

log4j.appender.R.File=backup.log 
#log4j.appender.R.MaxFileSize=100KB 

# Keep one backup file 
log4j.appender.R.MaxBackupIndex=1 
log4j.appender.R.layout=org.apache.log4j.PatternLayout 
log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n 


其中: 
#日志文件的大小 
log4j.appender.R.MaxFileSize=100KB  
# 保存一个备份文件 
log4j.appender.R.MaxBackupIndex=1 
五 
log4j支持把error的信息输出到日志文件,而把info的信息输出到控制台,log4j分别输出该怎么解决 





这里有一个小例子: 

  

  edit.properties文件 

  

  log4j.rootLogger=info,A1,A2 

  

  

  log4j.appender.A1=org.apache.log4j.FileAppender 

  log4j.appender.A1.File=test.info 

  log4j.appender.A1.Append=true 

  log4j.appender.A1.Threshold=info 

  log4j.appender.A1.layout=org.apache.log4j.PatternLayout 

  log4j.appender.A1.layout.ConversionPattern=%-d - %m%n 

  

  log4j.appender.A2=org.apache.log4j.FileAppender 

  log4j.appender.A2.File=test.error 

  log4j.appender.A2.Append=true 

  log4j.appender.A2.Threshold=error 

  log4j.appender.A2.layout=org.apache.log4j.PatternLayout 

  log4j.appender.A2.layout.ConversionPattern=%-d - %m%n 

六.将某个包或某个类下的日志信息输出到日志文件的配置 

log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout 
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c.%M(%L) - %m%n 
log4j.appender.logfile.datePattern='.'yyyy-MM-dd 
log4j.appender.logfile.append=true 
log4j.appender.logfile.File=F:/qc.log 

log4j.logger.com.study.HelloLog4j=info, logfile 

Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout,Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远 存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。 

Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。 

Layout的作用是控制Log信息的输出方式,也就是格式化输出的信息。 

Log4j中将要输出的Log信息定义了5种级别,依次为DEBUG、INFO、WARN、ERROR和FATAL,当输出时,只有级别高过配置中规定的级别的信息才能真正的输出,这样就很方便的来配置不同情况下要输出的内容,而不需要更改代码,这点实在是方便啊。 

2、Log4j的配置文件 



log4j.logger.myTest1=INFO,A   
log4j.appender.A=org.apache.log4j.DailyRollingFileAppender   
log4j.appender.A.File=c:/rolling.log   
log4j.appender.A.layout=org.apache.log4j.PatternLayout   
log4j.appender.A.layout.ConversionPattern=%d%m%n   
  
log4j.logger.myTest2=INFO,B   
log4j.appender.B=org.apache.log4j.ConsoleAppender   
log4j.appender.B.layout=org.apache.log4j.PatternLayout   
log4j.appender.B.layout.ConversionPattern=%l%d%m%n  






------------------------------------ 
今天在调试程序时,发觉eclipse console控制台中打印了很多无用的信息,比如: 

2009-04-01 18:52:21,406 http-8088-1 WARN  (CommonsLogger.java:46) - Could not find property [struts.valueStack] 
2009-04-01 18:52:22,000 http-8088-1 WARN  (CommonsLogger.java:46) - Could not find property [__cleanup_recursion_counter] 
2009-04-01 18:52:22,000 http-8088-1 WARN  (CommonsLogger.java:46) - Could not find property [org.apache.catalina.jsp_file] 

还有hibernate的一些日志,我想要总体设置log级别为INFO,而对于个别类中的log级别设置为ERROR,这样个别类的log就不会出现了。我上网查了查,发现了http://sllizhimei.javaeye.com/blog/359949 这位作者的作法,但是他只介绍了在log4j.xml中的修改方式,即: 

在log4j.xml里面添加下面的一段话: 
    <category name="com.opensymphony.xwork2.ognl.OgnlValueStack"> 
       <priority value="error"/> 

  </category> 

但我是用log4j.properties配置的log。所以这篇文章只给了我提示,我又上网一通找,终于让我找到以下文章 

http://wolfsquare.javaeye.com/blog/38686 

从这篇文章中我发现了新大陆,原来在property文件的最底下加入这句话就OK了: 

log4j.logger.com.opensymphony.xwork2=ERROR,stdout 

这句话的意思是:把com.opensymphony.xwork2下的所有的类的输出级别都提高到了ERROR,而其他的类还是按原来的log级别显示, 

这个问题,搞定! 

附上我的log4j.properties,供大家参考: 



log4j.rootLogger=INFO, stdout, logfile 

log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=%d %p [%l] - %m%n 
log4j.appender.stdout.Target=System.out 
log4j.appender.stdout.Threshold=INFO 


log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.logfile.Threshold=INFO 
log4j.appender.logfile.File=D:/tomcat6.0/logs/g.log 
log4j.appender.logfile.Append=true 
log4j.appender.logfile.DatePattern='.'yyyy-MM-dd 
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout 
log4j.appender.logfile.layout.ConversionPattern=%d %p [%l] - %m%n 
log4j.logger.com.opensymphony.xwork2=ERROR,stdout, logfile 
log4j.logger.org.hibernate.cfg=ERROR,stdout, logfile 


© 著作权归作者所有

共有 人打赏支持
天呀鲁哇
粉丝 8
博文 82
码字总数 42007
作品 0
长宁
程序员
java 日志框架——log4j

Log4J是JAVA下的一款日志组件 下载: http://logging.apache.org/log4j/2.x/download.html 下面的示例我使用最新版本2.7无法正常运行,最新版本使用方法可能不同。本文示例使用log4j-1.2.15测...

xundh ⋅ 05/09 ⋅ 0

Spring MVC-集成(Integration)-集成LOG4J示例(转载实践)

以下内容翻译自:https://www.tutorialspoint.com/springmvc/springmvc_log4j.htm 说明:示例基于Spring MVC 4.1.6。 以下示例说明如何使用Spring Web MVC框架来触发LOG4J。首先,让我们使用...

easonjim ⋅ 2017/09/10 ⋅ 0

Java混乱的日志体系(logback)(转)

作为一名 Java 程序员,日常开发工作中肯定会接触日志系统,但是众多的框架,包括 Log4j、Log4j2、Logback、Slf4j、Apache Common logging 等等,引用的 maven 依赖众多,到底可以去掉哪些,...

easonjim ⋅ 2017/12/27 ⋅ 0

ELK实时日志分析平台部署搭建详细实现过程

原文地址:http://www.linuxidc.com/Linux/2016-09/135137.htm 1、ELK平台介绍 在搜索ELK资料的时候,发现这篇文章比较好,于是摘抄一小段: 日志主要包括系统日志、应用程序日志和安全日志。...

tanga842428 ⋅ 2017/07/27 ⋅ 0

你不知道的System.out.println()

这篇博客是为了解释System.out.println是什么以及它的工作原理。 什么是System.out.println() System.out.println是一个Java语句,一般情况下是将传递的参数,打印到控制台。 System - 是 ...

为了美好的明天 ⋅ 2017/09/16 ⋅ 1

MyBatis3-配置使用log4j输出日志

这篇文章的思路源自http://www.cnblogs.com/EasonJim/p/7050312.html这个错误的解决,还是使用上一章http://www.cnblogs.com/EasonJim/p/7065330.html的例子代码,使用的是log4j1.x版本,目的...

easonjim ⋅ 2017/06/22 ⋅ 0

Log4j 2.0在开发中的高级使用详解

log4j与slf4j、logback比较 而log4j slf4j logback就是目前主流的日志框架。但后两者效率高是第一个。推荐使用:slf4j 或者 logback(spring-boot默认日志实现) log4j是apache实现的一个开源日...

spinachgit ⋅ 04/22 ⋅ 0

自定义log4j2配置文件地址

默认情况下,只要把log4j配置文件放在 CLASSPATH 环境变量所指定的目录, JAVA 启动时会制动加载。实际项目中经常需要把配置文件与打包分离,方便修改,所以需要自定义配置文件加载地址。 Sp...

如风达 ⋅ 04/20 ⋅ 0

如何在ABAP Netweaver和CloudFoundry里记录并查看日志

Netweaver 要记录日志需要有一个checkpoint group,可以自行创建也可以使用标准的。这里我重用标准的group:DEMOCHECKPOINTGROUP。 tcode SAAB,点Display <->Activate进入编辑模式,将Logpo...

JerryWang_SAP ⋅ 06/10 ⋅ 0

日志部分,项目使用,面试不面的

Log4j.properties配置详解 一、Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局)。这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。...

u012557298 ⋅ 01/01 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

BS与CS的联系与区别【简】

C/S是Client/Server的缩写。服务器通常采用高性能的PC、工作站或小型机,并采用大型数据库系统,如Oracle、Sybase、InFORMix或 SQL Server。客户端需要安装专用的客户端软件。 B/S是Brower/...

anlve ⋅ 51分钟前 ⋅ 0

发生了什么?Linus 又发怒了?

在一个 Linux 内核 4.18-rc1 的 Pull Request 中,开发者 Andy Shevchenko 表示其在对设备属性框架进行更新时,移除了 union 别名,这引发了 Linus 的暴怒。 这一次 Linus Torvalds 发怒的原...

问题终结者 ⋅ 今天 ⋅ 0

在树莓派上搭建一个maven仓库

在树莓派上搭建一个maven仓库 20180618 lambo init 项目说明 家里有台树莓派性能太慢。想搭建一个maven私服, 使用nexus或者 jfrog-artifactory 运行的够呛。怎么办呢,手写一个吧.所在这个...

林小宝 ⋅ 今天 ⋅ 0

Spring发展历程总结

转自与 https://www.cnblogs.com/RunForLove/p/4641672.html 目前很多公司的架构,从Struts2迁移到了SpringMVC。你有想过为什么不使用Servlet+JSP来构建Java web项目,而是采用SpringMVC呢?...

onedotdot ⋅ 今天 ⋅ 0

Python模块/包/库安装(6种方法)

Python模块/包/库安装(6种方法) 冰颖机器人 2016-11-29 21:33:26 一、方法1: 单文件模块 直接把文件拷贝到 $python_dir/Lib 二、方法2: 多文件模块,带setup.py 下载模块包(压缩文件zip...

cswangyx ⋅ 今天 ⋅ 0

零基础学习大数据人工智能,学习路线篇!系统规划大数据之路?

大数据处理技术怎么学习呢?首先我们要学习Python语言和Linux操作系统,这两个是学习大数据的基础,学习的顺序不分前后。 Python:Python 的排名从去年开始就借助人工智能持续上升,现在它已经...

董黎明 ⋅ 今天 ⋅ 0

openJdk和sun jdk的区别

使用过LINUX的人都应该知道,在大多数LINUX发行版本里,内置或者通过软件源安装JDK的话,都是安装的OpenJDK, 那么到底什么是OpenJDK,它与SUN JDK有什么关系和区别呢? 历史上的原因是,Ope...

jason_kiss ⋅ 今天 ⋅ 0

梳理

Redux 是 JavaScript 状态容器,提供可预测化的状态管理。 它是JS的状态容器,是一种解决问题的方式,所以即可以用于 react 也可以用于 vue。 需要理解其思想及实现方式。 应用中所有的 stat...

分秒 ⋅ 今天 ⋅ 0

Java 后台判断是否为ajax请求

/** * 是否是Ajax请求 * @param request * @return */public static boolean isAjax(ServletRequest request){return "XMLHttpRequest".equalsIgnoreCase(((HttpServletReques......

JavaSon712 ⋅ 今天 ⋅ 0

Redis 单线程 为何却需要事务处理并发问题

Redis是单线程处理,也就是命令会顺序执行。那么为什么会存在并发问题呢? 个人理解是,虽然redis是单线程,但是可以同时有多个客户端访问,每个客户端会有 一个线程。客户端访问之间存在竞争...

码代码的小司机 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部