gpt4 book ai didi

java - Grizzly http 服务器失败了一些请求

转载 作者:行者123 更新时间:2023-12-01 05:53:59 25 4
gpt4 key购买 nike

我创建了一个 grizzly Web 服务器,从 tomcat 运行我的 Jersey 应用程序,以加快测试速度。

我是一个 grizzly 初学者,但是通过网络我将一些代码行放在一起,以便在不到一个工作日的时间内启动并运行 grizzly Web 服务器:)

不幸的是,我的类在并发请求上遇到了一些麻烦,经常会出现一个或多个失败,导致莫名其妙的NullPointerException

问题通常出现在我刷新网页时,grizzly 必须返回大约 25 个非缓存文件。这是注册的异常:

9-set-2010 10.45.21 com.sun.grizzly.http.servlet.ServletAdapter doService
GRAVE: service exception:
java.lang.NullPointerException
at com.sun.grizzly.http.servlet.FilterChainImpl.doFilter(FilterChainImpl.java:178)
at com.sun.grizzly.http.servlet.FilterChainImpl.invokeFilterChain(FilterChainImpl.java:139)
at com.sun.grizzly.http.servlet.ServletAdapter.doService(ServletAdapter.java:376)
at com.sun.grizzly.http.servlet.ServletAdapter.service(ServletAdapter.java:324)
.....

静态文件由我的一个类提供,但日志告诉我一切正常,当我在 tomcat 下使用应用程序时,一切正常。我真的不知道如何解决这个问题..

这是我从互联网创建/复制到启动项目的代码:

public class LaunchApp {

/** Find in internet, used to use argument port as default, only if there is no JERSEY_HTTP_PORT env port enabled*/
private static int getPort(int defaultPort) {
String port = System.getenv("JERSEY_HTTP_PORT");
if (null != port) {
try {
return Integer.parseInt(port);
} catch (NumberFormatException e) {
}
}
return defaultPort;
}

private static URI getBaseURI() {
return UriBuilder.fromUri("http://localhost/").port(getPort(8080)).build();
}

public static final URI BASE_URI = getBaseURI();

protected static GrizzlyWebServer startServer() throws IOException {
final String rootFolder = "/Users/davide/dev/my-project/src/main/webapp";
GrizzlyWebServer ws = new GrizzlyWebServer("/Users/davide/dev/my-project/src/main/webapp");
try{
ServletAdapter adapter = new ServletAdapter();
adapter.addContextParameter( "contextConfigLocation","classpath:applicationContext.xml" );
adapter.addServletListener("org.springframework.web.context.ContextLoaderListener");
adapter.addServletListener("org.springframework.web.context.request.RequestContextListener");
adapter.addInitParameter( "com.sun.jersey.config.property.packages", "it.treis.zero.web.rest");
adapter.addInitParameter( "com.sun.jersey.spi.container.ContainerRequestFilters","com.sun.jersey.api.container.filter.LoggingFilter");
adapter.addInitParameter( "com.sun.jersey.spi.container.ContainerResponseFilters","com.sun.jersey.api.container.filter.LoggingFilter");
adapter.setProperty( "load-on-startup", 1 );
adapter.setServletInstance( new SpringServlet() );
adapter.setRootFolder(rootFolder);

// Add Open Session In View Hibernate Filter.
adapter.addFilter(new org.springframework.orm.hibernate3.support.OpenSessionInViewFilter(), "openSessionInViewFilter", null);

ws.addGrizzlyAdapter(adapter);

ws.start();
} catch(IOException ex){
ex.printStackTrace();
}
return ws;
}

public static void main(String[] args) throws IOException {
System.out.println("Starting Jersey");
GrizzlyWebServer ws = startServer();
System.out.println("Jersey rightly started, press any key to shutdown");
System.in.read();
ws.stop();
System.exit(0);
}
}

如有任何建议,我们将不胜感激。

再见,达维德。

最佳答案

这是由于 Grizzly 中的一个 bug,FilterChainImpl 的实现不是线程安全的。该问题已在此处报告:https://grizzly.dev.java.net/issues/show_bug.cgi?id=819 ,并在几个月前得到修复。

更新到最新版本(1.9.21)解决了我的问题。

关于java - Grizzly http 服务器失败了一些请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3675133/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com