java 日志

门面模式是什么

门面模式

java 日志讲解

java 日志讲解

SLF4J
  • Java简易日志门面(Simple Logging Facade for Java,缩写SLF4J),是一套包装Logging 框架的界面程式,以外观模式实现。可以在软件部署的时候决定要使用的 Logging 框架,目前主要支援的有Java Logging API、Log4j及logback等框架。以MIT 授权方式发布。
总结
  • 要用SLF4J 和log4j ,lo4j2,LogBack 3个中的其中一个.
SLF4J: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError. 
SLF4J: See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more details.
Exception in thread "main" java.lang.ExceptionInInitializerError
	at org.slf4j.impl.StaticLoggerBinder.<init>(StaticLoggerBinder.java:72)
	at org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:45)
	at org.apache.tmpspark.internal.Logging$.org$apache$tmpspark$internal$Logging$$isLog4j12(Logging.scala:205)
	at org.apache.tmpspark.internal.Logging$class.initializeLogging(Logging.scala:119)
	at org.apache.tmpspark.internal.Logging$class.initializeLogIfNecessary(Logging.scala:108)
	at org.apache.tmpspark.util.Utils$.initializeLogIfNecessary(Utils.scala:22)
	at org.apache.tmpspark.internal.Logging$class.initializeLogIfNecessary(Logging.scala:99)
	at org.apache.tmpspark.util.Utils$.initializeLogIfNecessary(Utils.scala:22)
	at org.apache.tmpspark.internal.Logging$class.log(Logging.scala:46)
	at org.apache.tmpspark.util.Utils$.log(Utils.scala:22)
	at org.apache.tmpspark.internal.Logging$class.logInfo(Logging.scala:54)
	at org.apache.tmpspark.util.Utils$.logInfo(Utils.scala:22)
	at org.apache.tmpspark.util.Utils$$anonfun$startServiceOnPort$1.apply$mcVI$sp(Utils.scala:76)
	at scala.collection.immutable.Range.foreach$mVc$sp(Range.scala:160)
	at org.apache.tmpspark.util.Utils$.startServiceOnPort(Utils.scala:66)
	at org.apache.tmpspark.deploy.yarn.AkkaUtils$.createActorSystem(AkkaUtils.scala:24)
	at org.apache.tmpspark.SparkEnv$.create(SparkEnv.scala:94)
	at org.apache.tmpspark.SparkEnv$.createDriverEnv(SparkEnv.scala:46)
	at org.apache.tmpspark.scheduler.SparkContext.createSparkEnv(SparkContext.scala:65)
	at org.apache.tmpspark.scheduler.SparkContext.<init>(SparkContext.scala:30)
	at org.apache.tmpspark.Test$.main(Test.scala:12)
	at org.apache.tmpspark.Test.main(Test.scala)
Caused by: java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError. See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more details.
	at org.slf4j.impl.Log4jLoggerFactory.<clinit>(Log4jLoggerFactory.java:54)
	... 22 more

原因

  • Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError.
  • log4j-over-slf4j.jar 从log4j到slf4j
  • slf4j-log4j12 从 slf4j到-log4j
  • 造成循环,导致错误,应该去除log4j-over-slf4j.jar,因为我们一般用slf4j,门面.
mvn dependency:tree
  • 用mvn dependency:tree 查看依赖排除后,idea中还是有.
  • 用mvn dependency:tree -Dverbose 太长了,idea显示不下.
  • 用mvn dependency:tree -Dverbose > file.txt
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值