如何更改传入的CometD短信的最大大小

时间:2016-09-23 17:12:37

标签: jetty-9 cometd bayeux

我正在尝试向Jetty 9下运行的CometD服务器发送一条大消息(> 130k)。当服务器收到此大消息时,它会生成以下异常:

org.eclipse.jetty.websocket.api.MessageTooLargeException: Text message size [130353] exceeds maximum size [65536]
at org.eclipse.jetty.websocket.api.WebSocketPolicy.assertValidTextMessageSize(WebSocketPolicy.java:140)
at org.eclipse.jetty.websocket.common.Parser.assertSanePayloadLength(Parser.java:127)
at org.eclipse.jetty.websocket.common.Parser.parseFrame(Parser.java:482)
at org.eclipse.jetty.websocket.common.Parser.parse(Parser.java:254)
at org.eclipse.jetty.websocket.common.io.AbstractWebSocketConnection.readParse(AbstractWebSocketConnection.java:632)
at org.eclipse.jetty.websocket.common.io.AbstractWebSocketConnection.onFillable(AbstractWebSocketConnection.java:480)
at org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:544)
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635)
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555)
at java.lang.Thread.run(Thread.java:745)
[qtp83954662-20] INFO org.cometd.websocket.server.WebSocketTransport$WebSocketScheduler$1 - WebSocket Error, Address: null
... 
(the rest removed for brevity)  

我理解问题所在,并查看了CometD文档。根据文档,您可以使用初始化参数更改缓冲区大小和最大消息大小:ws.bufferSize和ws.maxMessageSize。我在我的web.xml文件中设置了这些参数并重新启动了Jetty,但参数设置似乎没有任何效果。我仍然得到完全相同的异常,因为缓冲区大小保持不变。

web.xml文件的设置如下:

<servlet>
    <servlet-name>cometd</servlet-name>
    <servlet-class>org.cometd.server.CometDServlet</servlet-class>
    <init-param>
       <param-name>ws.bufferSize</param-name>
       <param-value>400000</param-value>
    </init-param>
    <init-param>
       <param-name>ws.maxMessageSize</param-name>
       <param-value>400000</param-value>
    </init-param>
     <async-supported>true</async-supported>
</servlet>
<servlet-mapping>
    <servlet-name>cometd</servlet-name>
    <url-pattern>/cometd/*</url-pattern>
</servlet-mapping>

我错过了什么吗?如何在CometD服务器中设置最大邮件大小并让服务器实际使用该邮件大小?

1 个答案:

答案 0 :(得分:1)

您的SELECT t.derived, t.c / t.derived AS new1, SUM(t.derived + t.d) AS new2 FROM ( SELECT CASE WHEN a + b IS NULL THEN a ELSE b END AS derived, c, d FROM mytable ) t 是正确的,这是解决问题的正确方法。

CometD测试套件中有测试验证web.xml参数是否正常工作。

我只是尝试修改CometD演示,添加ws.maxMessageSize然后从测试客户端发送一条大消息,它完美地运行了。

也许您在参数名称中有拼写错误或其他将参数重置为其默认值的内容?