Http-сервер Grizzly не выполняет какой-либо запрос - PullRequest
1 голос
/ 09 сентября 2010

Я создал веб-сервер гризли, чтобы запускать мое приложение из джерси из tomcat, чтобы ускорить тестирование.

Я новичок в гризли, но, просматривая сеть, я собрал несколько строк кода, чтобы веб-сервер гризли заработал меньше, чем за рабочий день:)

К сожалению, у моего класса есть некоторые проблемы при параллельном запросе, часто один или несколько сбоев в необъяснимом NullPointerException .

Проблемы обычно возникают, когда я обновляю свою веб-страницу, где гризли должны возвращать около 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);
}
}

Любые предложения приветствуются.

Чао, Давиде.

Ответы [ 2 ]

0 голосов
/ 06 марта 2015

у вас есть

  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");

дважды в вашей конфигурации. К вашему сведению ... не уверен, что это может быть проблемой.

https://java.net/jira/browse/GRIZZLY-819

...если вы регистрируете более одного фильтра, это происходит: «Я предлагаю, по крайней мере, сделать эту переменную потокобезопасной. Проблема показывает, только если зарегистрировано больше, чем фильтр».

0 голосов
/ 04 ноября 2010

Это связано с ошибкой в ​​Grizzly, реализация FilterChainImpl не является поточно-ориентированной. О проблеме сообщали здесь: https://grizzly.dev.java.net/issues/show_bug.cgi?id=819, и исправили пару месяцев назад.

Обновление до последней версии (1.9.21) решило проблему для меня.

...