前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >tomcat报错org.apache.coyote.ajp.AjpMessage processHeader

tomcat报错org.apache.coyote.ajp.AjpMessage processHeader

作者头像
悟空宇
发布2024-03-11 15:59:11
1500
发布2024-03-11 15:59:11
举报
文章被收录于专栏:干JAVA的日常干JAVA的日常
问题点:

Tomcat 7使用AJP协议导致AJP对应端口被暴露给外网

环境:

Linux(CentOS7) + Tomcat7

Step1:问题表现
Step2:问题分析

一般情况下AJP协议不会发生非常频繁的通信协议错误问题, 当尝试从外网连接Tomcat的Ajp端口8009,telnet连接成功,说明端口被暴露给了外网 根据The AJP Connector中的介绍说明(address部分):如果没有指定IP地址,默认是绑定任意地址,这样就导致外网可以通过8009端口访问主机。出于安全考虑,需要增加这个address的设置(如下图),并且绑定到127.0.0.1。最终结果如下:

修改后重启即可

<补充>

关于tomcat的优化

1.Executor配置

项目

Value

maxThreads

线程池中最大并发线程数, 默认值为200, 一般建议设置400~ 800 , 要根据服务器配置和业务需求而定.

minSpareThreads

最小活跃线程数, 也就是核心线程数, 不会被销毁, 会一直存在.

maxIdleTime

线程最大空闲时间, 超过该时间后, 空闲线程会被销毁, 默认值为6000, 单位为毫秒.

2.Connector配置

项目

Value

connectionTimeout

网络连接超时时间, 默认值为20000ms, 设置为0表示永不超时 —— 存在隐患. 通常可设置为30000ms.

acceptCount

当tomcat启动的线程数达到最大时,接受排队的请求个数,默认值为100

maxThreads

最大线程数,即同时处理的任务个数,默认值为200

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-03-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题点:
  • 环境:
  • Step1:问题表现
  • Step2:问题分析
  • <补充>
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档