[logback-user] Logback.groovy configuration results in java.lang.VerifyError exception.

rathnadhar.kolar at wipro.com rathnadhar.kolar at wipro.com
Mon Feb 28 09:13:26 CET 2011


Namasthe,

 

I have switched from log4j to logback. For configuration,  I initially
worked with logback.xml  which worked fine. I wanted to get rid of xml
so re-wrote the logback.xml in groovy. 

The logback.groovy is as below:

import ch.qos.logback.classic.PatternLayout

import ch.qos.logback.classic.filter.ThresholdFilter

import ch.qos.logback.classic.net.SMTPAppender

import ch.qos.logback.core.ConsoleAppender

import ch.qos.logback.core.rolling.FixedWindowRollingPolicy

import ch.qos.logback.core.rolling.RollingFileAppender

import ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy

 

import static ch.qos.logback.classic.Level.ERROR

import static ch.qos.logback.classic.Level.INFO

 

appender("RootFileAppender", RollingFileAppender) {

  file = "project"

  append = true

  filter(ThresholdFilter) {

    level = INFO

  }

  rollingPolicy(FixedWindowRollingPolicy) {

    fileNamePattern = "project_log.%i"

    maxIndex = 1

  }

  triggeringPolicy(SizeBasedTriggeringPolicy) {

    maxFileSize = 1000000

  }

  layout(PatternLayout) {

    pattern = "%d{yyyy-MM-dd HH:mm:ss}, %p, %c, %t, %ex, %F, %L, %C{1},
%M %m%n"

  }

}

appender("RootConsoleAppender", ConsoleAppender) {

  filter(ThresholdFilter) {

    level = INFO

  }

  layout(PatternLayout) {

    pattern = "%d{yyyy-MM-dd HH:mm:ss}, %p, %c, %t %m%n"

  }

}

appender("RootEmailAppender", SMTPAppender) {

  filter(ThresholdFilter) {

    level = ERROR

  }

  bufferSize = 10

  SMTPHost = "smtp.hostaddress"

  to = "logback.user at xyz.com"

  from = " logback.user at xyz.com "

  username = "user"

  password = "password"

  subject = "Logback Error"

  layout(PatternLayout) {

    pattern = "%d{yyyy-MM-dd HH:mm:ss}, %p, %c, %t, %ex, %F, %L, %C{1},
%M %m%n"

  }

}

root(INFO, ["RootFileAppender", "RootConsoleAppender",
"RootEmailAppender"])

 (Some values have been masked for security reasons).

I put this file in the classpath. 

After that I started my application, but I got this exception:

Failed to instantiate [ch.qos.logback.classic.LoggerContext]

Reported exception:

java.lang.VerifyError: (class:
groovy/runtime/metaclass/java/lang/StringMetaClass, method:
super$2$invokeMethod signature:
(Ljava/lang/Class;Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object
;ZZ)Ljava/lang/Object;) Illegal use of nonvirtual function call

      at java.lang.Class.forName0(Native Method)

      at java.lang.Class.forName(Class.java:169)

      at
groovy.lang.MetaClassRegistry$MetaClassCreationHandle.createWithCustomLo
okup(MetaClassRegistry.java:127)

      at
groovy.lang.MetaClassRegistry$MetaClassCreationHandle.create(MetaClassRe
gistry.java:122)

      at
org.codehaus.groovy.reflection.ClassInfo.getMetaClassUnderLock(ClassInfo
.java:165)

      at
org.codehaus.groovy.reflection.ClassInfo.getMetaClass(ClassInfo.java:195
)

      at
org.codehaus.groovy.runtime.metaclass.MetaClassRegistryImpl.getMetaClass
(MetaClassRegistryImpl.java:214)

      at
org.codehaus.groovy.runtime.InvokerHelper.getMetaClass(InvokerHelper.jav
a:747)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.createPojoSite(CallSi
teArray.java:107)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.createCallSite(CallSi
teArray.java:148)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteA
rray.java:40)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallS
ite.java:116)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallS
ite.java:124)

      at
ch.qos.logback.classic.gaffer.ConfigurationDelegate.appender(Configurati
onDelegate.groovy:117)

      at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

      at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.jav
a:39)

      at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessor
Impl.java:25)

      at java.lang.reflect.Method.invoke(Method.java:597)

      at
org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:90)

      at
org.codehaus.groovy.runtime.metaclass.MixinInstanceMetaMethod.invoke(Mix
inInstanceMetaMethod.java:53)

      at
org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite$PogoMetaMethodSi
teNoUnwrapNoCoerce.invoke(PogoMetaMethodSite.java:307)

      at
org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite.callCurrent(Pogo
MetaMethodSite.java:51)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(Ca
llSiteArray.java:44)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(Abstra
ctCallSite.java:141)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(Abstra
ctCallSite.java:157)

      at Script1.run(Script1.groovy:24)

      at Script1$run.call(Unknown Source)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteA
rray.java:40)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallS
ite.java:116)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallS
ite.java:120)

      at
ch.qos.logback.classic.gaffer.GafferConfigurator.run(GafferConfigurator.
groovy:59)

      at
ch.qos.logback.classic.gaffer.GafferConfigurator$run.callCurrent(Unknown
Source)

      at
org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(Ca
llSiteArray.java:44)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(Abstra
ctCallSite.java:141)

      at
org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(Abstra
ctCallSite.java:149)

      at
ch.qos.logback.classic.gaffer.GafferConfigurator.run(GafferConfigurator.
groovy:37)

      at
ch.qos.logback.classic.gaffer.GafferUtil.runGafferConfiguratorOn(GafferU
til.java:44)

      at
ch.qos.logback.classic.util.ContextInitializer.configureByResource(Conte
xtInitializer.java:67)

      at
ch.qos.logback.classic.util.ContextInitializer.autoConfig(ContextInitial
izer.java:150)

      at
org.slf4j.impl.StaticLoggerBinder.init(StaticLoggerBinder.java:85)

      at
org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:55)

      at org.slf4j.LoggerFactory.bind(LoggerFactory.java:121)

      at
org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:111)

      at
org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:268)

      at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:241)

      at
src.temporalprocessing.StartProgram.<clinit>(StartProgram.java:37)

 

 

When I switch from logback.groovy to logback.xml, everything works
perfectly (both the configurations are equal in functionality).

 

My google search did not yield useful information. 

 

I am using the following jars:

1.       groovy-all-1.7.8.jar

2.       logback-access-0.9.28.jar

3.       logback-classic-0.9.28.jar

4.       logback-core-0.9.28.jar

5.       slf4j-api-1.6.1.jar

 

Can somebody please help me to resolve the issue.

 

Regards

Rathnadhar.K.V

 

 

 


Please do not print this email unless it is absolutely necessary. 

The information contained in this electronic message and any attachments to this message are intended for the exclusive use of the addressee(s) and may contain proprietary, confidential or privileged information. If you are not the intended recipient, you should not disseminate, distribute or copy this e-mail. Please notify the sender immediately and destroy all copies of this message and any attachments. 

WARNING: Computer viruses can be transmitted via email. The recipient should check this email and any attachments for the presence of viruses. The company accepts no liability for any damage caused by any virus transmitted by this email. 

www.wipro.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://qos.ch/pipermail/logback-user/attachments/20110228/b235fc45/attachment-0001.html>


More information about the Logback-user mailing list