ajp_read_header: ajp_ilink_receive failed

2009/05/10

java linux tomcat web ネットワーク 開発 管理者

t f B! P L
記事内に広告が含まれています。

CentOS 5.2(32bit)で、Tomcat5.5をSun版JDK1.5で動かし、Apache Httpd Serverとmod_proxy_ajpで連携している環境。

たまにTomcat上のアプリの反応がなくなるので、調べたところ、ajp_read_header: ajp_ilink_receive failed というエラーがApacheのエラーログにあった。
ググっても解決方法がよくわからないが、そもそもうまく再現できていないような様子。

再現のポイントは1つ。アプリの処理時間が長いものを相手にすること。
処理時間の長いものに対してどんどんリクエストしていくと、Tomcat側のthreadが上限に達するので、再現できるのではないかと。
port 8009のTCP接続数を見ていくと、エラーが出た時点で頭打ちになっているのではないか。netstat -nat|grep 8009|wc -lとやって、数を見てみると良い。

推測だけど、Tomcat側でthreadが生成できない(リクエストを処理できない)というエラーを返しても、mod_proxy_ajpが知らないメッセージだ!とエラーにしているのかな?ただ、処理できなくなったthreadがいつまでも残っているようにも見えるのだが…。

ちなみに、最後の手段としてはAJPを使うのではなく、httpを使う(tomcatのhttp serverと連携する)ようだ。

人気の投稿

ブログ アーカイブ

自己紹介

ストックオプションを半分しか行使していなかったけど、パワハラをなぁなぁで済まそうとする会社から転職。アーリーリタイアを目指し、自分で稼ぐ術を模索中。

改正電気通信事業法に関する表記

・掲載内容

当サイトでは成果報酬型広告/クリック型広告の効果測定のため、利用者の方のアクセス情報を外部事業者に送信しております。
当該の情報は個人を特定する情報ではございません。また当該の情報が目的外利用される事は一切御座いません。

1.送信される情報の内容
  • 広告の表示日時
  • 広告のクリック日時
  • 広告の計測に必要なクッキー情報
  • 広告表示時及び広告クリック時のIPアドレス
  • 広告表示時及び広告クリック時に使用されたインターネット端末およびインターネットブラウザの種類
2.送信先となる事業者の氏名又は名称
  • グーグル合同会社
  • 楽天グループ株式会社
  • アマゾンジャパン合同会社
  • ヤフー株式会社
  • 株式会社ファンコミュニケーションズ
  • 株式会社もしも
3.利用目的

成果報酬型広告/クリック型広告の効果測定および不正防止のため

QooQ