- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图了解什么是错误。当我将mongoDB放入另一个实例时,它开始发生。
该错误有一个大提示,但它什么也没说,并且没有已知的动作触发该错误。
世界标准时间2016年1月12日星期二19:34:31
通过:[java.lang.Thread.getStackTrace(Thread.java:1552),com.sun.enterprise.loader.ASURLClassLoader.done(ASURLClassLoader.java:216),com.sun.enterprise.loader.ASURLClassLoader.preDestroy(ASURLClassLoader .java:184),org.glassfish.javaee.full.deployment.EarClassLoader.preDestroy(EarClassLoader.java:114),org.jvnet.hk2.internal.ServiceLocatorImpl.preDestroy(ServiceLocatorImpl.java:956),org.jvnet。 hk2.internal.ServiceLocatorImpl.preDestroy(ServiceLocatorImpl.java:940),org.glassfish.internal.data.ApplicationInfo.clean(ApplicationInfo.java:451),com.sun.enterprise.v3.server.ApplicationLifecycle.unload(ApplicationLifecycle。 java:1071),com.sun.enterprise.v3.server.ApplicationLifecycle.undeploy(ApplicationLifecycle.java:1099),org.glassfish.deployment.admin.UndeployCommand.execute(UndeployCommand.java:412),com.sun.enterprise .v3.admin.CommandRunnerImpl $ 2 $ 1.run(CommandRunnerImpl.java:539),com.sun.enterprise.v3.admin.CommandRunnerImpl $ 2 $ 1.run(CommandRunnerImpl.java:535),java.security.AccessContr oller.doPrivileged(本机方法),javax.security.auth.Subject.doAs(Subject.java:360),com.sun.enterprise.v3.admin.CommandRunnerImpl $ 2.execute(CommandRunnerImpl.java:534),com.sun .enterprise.v3.admin.CommandRunnerImpl $ 3.run(CommandRunnerImpl.java:565),com.sun.enterprise.v3.admin.CommandRunnerImpl $ 3.run(CommandRunnerImpl.java:557),java.security.AccessController.doPrivileged(Native方法),javax.security.auth.Subject.doAs(Subject.java:360),com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:556),com.sun.enterprise.v3.admin .CommandRunnerImpl.doCommand(CommandRunnerImpl.java:1464),com.sun.enterprise.v3.admin.CommandRunnerImpl.access $ 1300(CommandRunnerImpl.java:109),com.sun.enterprise.v3.admin.CommandRunnerImpl $ ExecutionContext.execute( CommandRunnerImpl.java:1846)、com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1722)、org.glassfish.admin.rest.resources.admin.CommandResource.executeCommand(CommandResource.java: 4 04),org.glassfish.admin.rest.resources.admin.CommandResource.execCommandSimpInMultOut(CommandResource.java:234),sun.reflect.GeneratedMethodAccessor419.invoke(未知来源),sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java: 43),java.lang.reflect.Method.invoke(Method.java:497),org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory $ 1.invoke(ResourceMethodInvocationHandlerFactory.java:81),org.glassfish.jersey。 server.model.internal.AbstractJavaResourceMethodDispatcher $ 1.run(AbstractJavaResourceMethodDispatcher.java:151),org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:171),org.glassfish.jersey.server.model .internal.JavaResourceMethodDispatcherProvider $ ResponseOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:152),org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDisp atcher.java:104)、org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:387)、org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:331)、org .glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:103),org.glassfish.jersey.server.ServerRuntime $ 1.run(ServerRuntime.java:271),org.glassfish.jersey.internal.Errors $ 1 .call(Errors.java:271),org.glassfish.jersey.internal.Errors $ 1.call(Errors.java:267),org.glassfish.jersey.internal.Errors.process(Errors.java:315),org .glassfish.jersey.internal.Errors.process(Errors.java:297),org.glassfish.jersey.internal.Errors.process(Errors.java:267),org.glassfish.jersey.process.internal.RequestScope.runInScope (RequestScope.java:297)、org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:254)、org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1028)、org.glassfish。 jersey.grizzly2.httpserver.GrizzlyHttpContainer.se rvice(GrizzlyHttpContainer.java:365),org.glassfish.admin.rest.adapter.JerseyContainerCommandService $ 3.service(JerseyContainerCommandService.java:173),org.glassfish.admin.rest.adapter.RestAdapter.service(RestAdapter.java:179) ),com.sun.enterprise.v3.services.impl.ContainerMapper $ HttpHandlerCallable.call(ContainerMapper.java:459),com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167), org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:201),org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:175),org.glassfish.grizzly.http。 server.HttpServerFilter.handleRead(HttpServerFilter.java:235),org.glassfish.grizzly.filterchain.ExecutorResolver $ 9.execute(ExecutorResolver.java:119),org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:284) ),org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:201),org.glassfish.grizzly.filterchain.DefaultFilter Chain.execute(DefaultFilterChain.java:133),org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:112),org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77),org.glassfish .grizzly.portunif.PUFilter.handleRead(PUFilter.java:231),org.glassfish.grizzly.filterchain.ExecutorResolver $ 9.execute(ExecutorResolver.java:119),org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain。 java:284),org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:201),org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:133),org.glassfish.grizzly.filterchain .DefaultFilterChain.process(DefaultFilterChain.java:112),org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77),org.glassfish.grizzly.portunif.PUFilter.handleRead(PUFilter.java:231),组织。 glassfish.grizzly.filterchain.ExecutorResolver $ 9.execute(ExecutorResolver.java:119),org.glassfish。 grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:284),org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:201),org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java: 133),org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:112),org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77),org.glassfish.grizzly.nio.transport.TCPNIOTransport .fireIOEvent(TCPNIOTransport.java:561),org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112),org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117),组织。 glassfish.grizzly.strategies.WorkerThreadIOStrategy.access $ 100(WorkerThreadIOStrategy.java:56),org.glassfish.grizzly.strategies.WorkerThreadIOStrategy $ WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137),org.glassfish.grizzly.Threadpool.AbstractpoolPool .doWor k(AbstractThreadPool.java:565),org.glassfish.grizzly.threadpool.AbstractThreadPool $ Worker.run(AbstractThreadPool.java:545),java.lang.Thread.run(Thread.java:745)]父->组织。 glassfish.internal.api.DelegatingClassLoader@7cbe8ac6
从以下堆栈跟踪中调用完成后,被要求查找类org.bson.codecs.EncoderContext $ 1
java.lang.Throwable
在com.sun.enterprise.loader.ASURLClassLoader.findClassData(ASURLClassLoader.java:825)
在com.sun.enterprise.loader.ASURLClassLoader.findClass(ASURLClassLoader.java:742)
在java.lang.ClassLoader.loadClass(ClassLoader.java:424)
在java.lang.ClassLoader.loadClass(ClassLoader.java:357)
在org.bson.codecs.EncoderContext。(EncoderContext.java:27)
在org.bson.codecs.EncoderContext $ Builder.build(EncoderContext.java:67)
在com.mongodb.connection.RequestMessage.addDocument(RequestMessage.java:168)
在com.mongodb.connection.CommandMessage.encodeMessageBody(CommandMessage.java:69)
在com.mongodb.connection.RequestMessage.encode(RequestMessage.java:132)
在com.mongodb.connection.CommandHelper.sendMessage(CommandHelper.java:88)
在com.mongodb.connection.CommandHelper.executeCommand(CommandHelper.java:32)
在com.mongodb.connection.DefaultServerMonitor $ ServerMonitorRunnable.lookupServerDescription(DefaultServerMonitor.java:186)处
在com.mongodb.connection.DefaultServerMonitor $ ServerMonitorRunnable.run(DefaultServerMonitor.java:134)
在java.lang.Thread.run(Thread.java:745)
]]
错误消息图像:
编辑:
来自Payara Server github issue的人员帮助我找到了问题。我已经使用ServletContextListener在部署之前杀死mongo连接。现在,我将等待一段时间以查看问题是否已解决。代码如下:
@Log
@WebListener
public class AppServletContextListener implements ServletContextListener {
@Inject
MongoClientProvider mongo;
@Override
public void contextDestroyed(ServletContextEvent arg) {
log.info("ServletContextListener destroyed");
DbUtils.closeMongoConnections(mongo);
}
@Override
public void contextInitialized(ServletContextEvent arg) {
log.info("ServletContextListener started");
}
}
public class DbUtils {
public static void closeMongoConnections(MongoClientProvider mongo) {
mongo.getDeletedGroups().getManager().close();
mongo.getMessages().getManager().close();
mongo.getGameficationInfos().getManager().close();
mongo.getDgsa().getManager().close();
mongo.getRisa().getManager().close();
mongo.getExpiredEmailLinks().getManager().close();
}
}
最佳答案
您已从错误中删除了有用的内容,但它已显示在屏幕快照中。在AT Tue Jan 12 19:34:31 UTC 2016
部分之前也会有一点,它会告诉您错误是由于ASURLClassLoader
引起的,它告诉您有关类加载器状态的信息。
关键部分是图像的最后一行:
...
was requested to find class org.bson.codecs.EncoderContext$1 after done was invoked from the following stack trace
done()
方法是一种清理方法,当类加载器准备好进行垃圾回收时会调用该方法。因此,此时,
EncoderContext
类正在尝试加载一个类,但是到达的
ASURLClassLoader
处于标记为清除但尚未清除之间的这种不确定状态。
ASURLClassLoader
堆栈(大屏幕截图),看起来是由于取消部署而调用
done()
。因此,很可能是从未部署的应用程序中调用了MongoDB,而MongoDB却没有被同时处置。
关于java - mongodb套接字中的java.lang.Throwable错误是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34765816/
我正在尝试弄清楚如何将 Throwable\/List[Throwable\/A] 干净利落地排列成 Throwable\/List[A] ,可能使用 List 的 Traverse 实例,但我似乎无
在不创建新 Throwable 的情况下添加一种通用方法来向 Throwable 添加信息是否有益? 我经常看到这样的代码: try { foo(); } catch (Exception e
当发生异常并且我得到 Throwable 时,我想将它转换为 MyThrowable 并重新抛出它。 我正在实现实例创建的方法 obs1 = obs1.map(new Func1() {
我有一个带 @Aspect 注释的类正在调用 ProceedingJoinPoint#proceed() 。此方法抛出 Throwable,因此该类看起来像这样: @Aspect @Component
我知道网络上充斥着不要捕获 Throwable 的建议,但是它适用于使用 CompleteableFuture 吗?例如,在 ExecutorService es = Executors.ne
这个问题在这里已经有了答案: No Exception while type casting with a null in java (10 个答案) 关闭 7 年前。 这个问题只是让我理解这个概念
假设我有几种方法可以返回 \/[Throwable, String]。右边的值 Int 是我想要的,左边的值累积错误。 import scalaz._ import Scalaz._ type Err
今天我去部署一个我创建的 Java 应用程序到 Google App Engine,但我遇到了一些非常无用的错误消息。 Invocation of init method failed; nested
我正在实现一个 AOP 拦截器,它处理 RetryTemplate 中的逻辑。问题是 ProceedingJoinPoint#execute 被声明为抛出 Throwable,但 RetryTempl
首先我必须说我阅读了以下内容:http://docs.oracle.com/javase/tutorial/essential/exceptions/index.html ! 尝试编译时出现的错误如下
我正在编辑别人的代码,并且一个方法有“Throws Throwable”。我把它去掉了,所以 Eclipse 会让我只添加它需要抛出的异常类型...但是,我在调用父类(super class)(我当前
当我开发 android 应用程序时,我想制作一个 CrashReport 类,然后使用它向我的服务器发送报告。 我做了一个名为CrashHandler的类,它实现了UncaughtException
我在java中得到了这段代码: public static void main(String[] args) { try{ Class tryLoadi
我正在使用 JDK8 在 macOS 上工作。 在 catch 中,我必须给出异常的完整名称,例如在这种情况下 (ArithmeticException e) 而不是 (Exception e)运行代
我有一个执行 I/O 的类(我们称之为 ABC)。像 FileOutputStream.close 这样的东西会让你在它们周围使用 try catch block 。此外,我创建了自己的可抛出对象,帮
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Why doesn’t Java allow generic subclasses of Throwable
我在这里看到了很多关于 Exception 和 Throwable 之间区别的一般性问题。我知道其中的区别,而且我有一个更具体的问题。 我正在编写一个库,用于绑定(bind)并运行多个用户提供的代码片
我已经捕获了任何未捕获的异常 Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
我有一些外部提供的回调要运行。因为它们可以包含任何东西,所以我更愿意冒险在它们上捕获 Throwable 并因此从任何可恢复的错误中恢复。 回调执行的某些阶段允许抛出错误,除非错误连续重复两次。在这种
在java语言中,错误类的基类是java.lang.Error,异常类的基类是java.lang.Exception。 1)相同点:java.lang.Error和java.lang.Excepti
我是一名优秀的程序员,十分优秀!