首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Cometd,Jetty : Cometd不会启动,抽象错误:javax.servlet.ServletOutputStream.setWriteListener

Cometd,Jetty : Cometd不会启动,抽象错误:javax.servlet.ServletOutputStream.setWriteListener
EN

Stack Overflow用户
提问于 2017-09-29 07:25:07
回答 1查看 158关注 0票数 0

我正在尝试运行我们的Spring应用程序,它在Jetty9.2上有Cometd(3.0.9)。目前,它正在与Tomcat7完美地工作,但我们正在将Jetty作为另一个应用程序容器,以满足其他一些需求。但是,Cometd不会启动,并抛出一个500。下面是我们在后端一次又一次地遇到的唯一错误:

代码语言:javascript
复制
2017-09-29 12:48:17.137:WARN:oejs.HttpInput:qtp717356484-66: java.lang.AbstractMethodError: javax.servlet.ServletOutputStream.setWriteListener(Ljavax/servlet/WriteListener;)V

web.xml:

代码语言:javascript
复制
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
         http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
 <servlet>
        <servlet-name>cometd</servlet-name>
        <servlet-class>org.cometd.server.CometDServlet</servlet-class>
        <init-param>
            <param-name>maxSessionsPerBrowser</param-name>
            <param-value>10</param-value>
        </init-param>
        <init-param>
            <param-name>allowMultiSessionsNoBrowser</param-name>
            <param-value>true</param-value>
        </init-param>
        <init-param>
            <param-name>timeout</param-name>
            <param-value>60000</param-value>
        </init-param>
        <init-param>
            <param-name>long-polling.jsonp.timeout</param-name>
            <param-value>30000</param-value>
        </init-param>
        <init-param>
            <param-name>long-polling.timeout</param-name>
            <param-value>40000</param-value>
        </init-param>
        <init-param>
            <param-name>interval</param-name>
            <param-value>0</param-value>
        </init-param>
        <init-param>
            <param-name>maxInterval</param-name>
            <param-value>300000</param-value>
        </init-param>
        <init-param>
            <param-name>long-polling.multiSessionInterval</param-name>
            <param-value>2000</param-value>
        </init-param>
        <init-param>
            <param-name>multiFrameInterval</param-name>
            <param-value>1000</param-value>
        </init-param>
        <init-param>
            <param-name>logLevel</param-name>
            <param-value>3</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
        <async-supported>true</async-supported>
    </servlet>


    <servlet-mapping>
        <servlet-name>cometd</servlet-name>
        <url-pattern>/cometd/*</url-pattern>
    </servlet-mapping>


    <filter>
        <filter-name>cross-origin</filter-name>
        <filter-class>org.eclipse.jetty.servlets.CrossOriginFilter</filter-class>
        <async-supported>true</async-supported>

    </filter>
    <filter-mapping>
        <filter-name>cross-origin</filter-name>
        <url-pattern>/cometd/*</url-pattern>
    </filter-mapping>

控制台错误:

代码语言:javascript
复制
POST /cometd/handshake HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Content-Length: 201
Accept: */*
Origin: http://localhost:8080
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/61.0.3163.79 Chrome/61.0.3163.79 Safari/537.36
Content-Type: application/json;charset=UTF-8
DNT: 1
Referer: http://localhost:8080/canvaslisting
Accept-Encoding: gzip, deflate, br
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6
Cookie: BAYEUX_BROWSER=1ul0bye0whhe511o; language=de; express_sid=s%3APCZq7dlCE8SlD6Iz86erUOv9tzSY3ByZ.4I%2BjSqnjONlhbuZOW90xM%2BeVjDnGQv0h0faztPBGan8; token=t.acvNouIKHegdIIFTjUjV; io=UiTHlpSm-T0vFYL1AAAA; JSESSIONID=1xktmtvfdgw5qtfqsf4et10g; _gat=1; sessionID=s.0dd75393a703ba234388cc605b84b790%2Cs.6fd7622c942a1808476c55355c46c8e4%2Cs.0dd75393a703ba234388cc605b84b790%2Cs.6fd7622c942a1808476c55355c46c8e4; _ga=GA1.1.1967903258.1505904823; _gid=GA1.1.1406412351.1506495950

HTTP/1.1 500 Server Error
Access-Control-Allow-Origin: http://localhost:8080
Access-Control-Allow-Credentials: true
Access-Control-Expose-Headers: 
Content-Type: application/json;charset=UTF-8
Content-Length: 0
Server: Jetty(9.2.22.v20170606)

Cometd依赖关系:

代码语言:javascript
复制
<!-- Cometd dependencies -->
        <dependency>
            <groupId>org.cometd.java</groupId>
            <artifactId>bayeux-api</artifactId>
            <version>${cometd-version}</version>
        </dependency>
        <dependency>
            <groupId>org.cometd.javascript</groupId>
            <artifactId>cometd-javascript-jquery</artifactId>
            <version>${cometd-version}</version>
            <type>war</type>
        </dependency>
        <dependency>
            <groupId>org.cometd.java</groupId>
            <artifactId>cometd-java-server</artifactId>
            <version>${cometd-version}</version>
        </dependency>

        <dependency>
            <groupId>org.eclipse.jetty</groupId>
            <artifactId>jetty-client</artifactId>
            <version>9.2.9.v20150224</version>
        </dependency>

        <dependency>
            <groupId>org.cometd.java</groupId>
            <artifactId>cometd-java-client</artifactId>
            <version>${cometd-version}</version>
        </dependency>

        <dependency>
            <groupId>org.cometd.java</groupId>
            <artifactId>cometd-java-annotations</artifactId>
            <version>${cometd-version}</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.eclipse.jetty/jetty-servlets -->
        <dependency>
            <groupId>org.eclipse.jetty</groupId>
            <artifactId>jetty-servlets</artifactId>
        </dependency>

BayeuxInitializer:

代码语言:javascript
复制
@Component
public class BayeuxInitializer implements DestructionAwareBeanPostProcessor, ServletContextAware {
    private BayeuxServer bayeuxServer;
    private ServerAnnotationProcessor processor;

    @Inject
    private void setBayeuxServer(BayeuxServer bayeuxServer) {
        this.bayeuxServer = bayeuxServer;
    }

    @PostConstruct
    private void init(){

        this.processor = new ServerAnnotationProcessor(bayeuxServer);
    }

    @PreDestroy
    private void destroy() {
    }

    public Object postProcessBeforeInitialization(Object bean, String name) throws BeansException {
        processor.processDependencies(bean);
        processor.processConfigurations(bean);
        processor.processCallbacks(bean);

        return bean;
    }

    public Object postProcessAfterInitialization(Object bean, String name) throws BeansException {
        return bean;
    }

    public void postProcessBeforeDestruction(Object bean, String name) throws BeansException {
        processor.deprocessCallbacks(bean);
    }

    @Bean(initMethod = "start", destroyMethod = "stop")
    public BayeuxServer bayeuxServer() {

        return new BayeuxServerImpl();
    }

    public void setServletContext(ServletContext servletContext) {
        servletContext.setAttribute(BayeuxServer.ATTRIBUTE, bayeuxServer);
    }
}



 @Listener(value = "/service/online")
    public void OnlineNotifications(ServerSession remote, ServerMessage.Mutable message) {
        Person person = this.personService.getCurrentlyAuthenticatedUser();

// This person is always null in Jetty, but not on Apache tomcat.
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-02 13:37:20

web.xml将web应用程序声明为Servlet3.1。

ServletOutputStream.setWriteListener(WriteListener)是一个添加到Servlet3.1中的方法。

你所犯的错误:

代码语言:javascript
复制
java.lang.AbstractMethodError: javax.servlet.ServletOutputStream.setWriteListener(Ljavax/servlet/WriteListener;)V

说您已经根据Servlet3.1JAR编译了您的应用程序,但是您在一个不提供这种jar的环境中运行它,可能只是一个Servlet3.0JAR。

Jetty9.2.x不带任何限制,支持Servlet3.1。

我怀疑您在引用导致错误的旧jars时有一个糟糕的类路径,所以我会先检查一遍。

如果要在独立的Jetty9.2.x服务器中部署web应用程序,请确保web应用程序的WEB-INF/lib中的jars是正确的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46483804

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档