Apache AJP1.3 Connector Tomcat 調整 packet size 方法

栏目: Java · 发布时间: 6年前

内容简介:今天公司某個站台報修出現異常狀況,查了之後反而找到另一個 catalina.out 跑出來的錯誤訊息:遇到這個問題通常就是踩到 limit 了,拿去查狗發現是在 AJP1.3 Connector 的預設 packet size 限制預設為 8192,通常每個 packet 不會超過這個大小,有可能是工程師開發時誤把 Body 的資料丟到 GET 造成 packet 過大。根解其實要去了解為何造成 packet 過大,但 Workaround 可以透過設定 packet size 暫時解套。

今天公司某個站台報修出現異常狀況,查了之後反而找到另一個 catalina.out 跑出來的錯誤訊息:

2019/5/28 12:10:16 org.apache.jk.common.MsgAjp cpBytes: Buffer overflow: buffer.len=8192 pos=8111 data=84 …
2019/5/28 12:10:16 org.apache.catalina.core.StandardWrapperValve invoke: Servlet.service() for servlet CfmServlet threw exception  java.lang.ArrayIndexOutOfBoundsException: 8192

遇到這個問題通常就是踩到 limit 了,拿去查狗發現是在 AJP1.3 Connector 的預設 packet size 限制預設為 8192,通常每個 packet 不會超過這個大小,有可能是工程師開發時誤把 Body 的資料丟到 GET 造成 packet 過大。

根解其實要去了解為何造成 packet 過大,但 Workaround 可以透過設定 packet size 暫時解套。

這邊遇到 AJP1.3 協定是 Apache + Mod_jk + Tomcat 時產生的問題,如果要調整 packet size 必須要 Connector 搭配 Tomcat 一起調整,詳細在官方文件都有提到:

If you change it from the default, you must also change the packetSize attribute of your AJP connector on the Tomcat side! 

切記兩邊一定要一起作業,而且數值要相同!

如果兩邊的 packet size 不一致,就會在 mod_jk.log 看到錯誤訊息說 Tomcat Network 有問題:

[Tue May 28 13:35:36.053 2019] [11772:3086083840] [error] ajp_connection_tcp_get_message::jk_ajp_common.c (1283): wrong message size 8196 8192 from 127.0.0.1:8180  [Tue May 28 13:35:36.053 2019] [11772:3086083840] [error] ajp_get_reply::jk_ajp_common.c (2088): (tutor) Tomcat is down or network problems. Part of the response has already been sent to the client  [Tue May 28 13:35:36.053 2019] [11772:3086083840] [error] ajp_service::jk_ajp_common.c (2536): (tutor) sending request to tomcat failed (unrecoverable), because of protocol error (attempt=1)

Apache AJP1.3 (mod_jk) 設定

mod_jk 的設定在 workers.properties 加上 max_packet_size

worker.list=server
 
worker.server.port=8080
worker.server.host=127.0.0.1
worker.server.type=ajp13
worker.server.max_packet_size=65536

Tomcat Connector 設定

在 server.xml 的 AJP1.3 Connector 加上 packetSize

<Connector port="8080" maxHttpHeaderSize="8192" packetSize="65536"
           maxThreads="500" minSpareThreads="50" maxSpareThreads="100"
           connectionTimeout="120000" backlog="1000"
           enableLookups="false" redirectPort="8443"
           protocol="AJP/1.3"/>

Apache 和 Tomcat 都重啟後就搞定了!


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

超级用户

超级用户

[美] 艾迪•尹 / 王喆,余宁 / 中信出版集团 / 2017-9 / 49.00

《超级用户》是一本可以让你和你的公司实现超常规增长的神奇的书。 多数人只有一个订书机,但有一天,全球著名市场调研公司尼尔森的高管艾迪•尹在和办公用品供应商的合作中发现,订书机的“死忠粉”们,平均每人有8个订书机。令人意想不到的是,相比那些需要更换订书机或遗失订书机的“普通”用户,他们的需求更强,购买第九个订书机的可能性更大。 有些人无肉不欢,有些人爱做手工,有些人痴迷于美国女孩玩偶。这......一起来看看 《超级用户》 这本书的介绍吧!

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具