待辦事項 #29144

SSL clear_socketエラー対処

啟用日期: 2012-07-30 11:08 最後更新: 2012-09-04 13:51

回報者:
負責人:
類型:
狀態:
關閉
里程碑:
(無)
優先權:
5 - 中
嚴重程度:
5 - 中
處理結果:
修正
檔案:
2

細節

クライアント数12000のTPCWによるhttps通信負荷を30分かける試験をすると、 50回に1回の割合でcoreを吐く。

対処として、sslのときsocket.clear_socket()をio_serviceの workerスレッドに登録して処理するようにし、それによって clear_socket()の処理をシリアライズ化する。

Ticket History (3/10 Histories)

2012-07-30 11:08 Updated by: hiroakinakano
  • New Ticket "SSL clear_socketエラー対処" created
2012-07-30 11:10 Updated by: hiroakinakano
  • 狀態 Update from 開啟 to 關閉
  • 處理結果 Update from to 修正
  • Ticket Close date is changed to 2012-07-30 11:10
2012-07-30 14:27 Updated by: hiroakinakano
評語

patchは#29143を当てた後のコードとの差分

2012-08-24 11:18 Updated by: hiroakinakano
  • 狀態 Update from 關閉 to 開啟
評語

デバッグ用にエラーメッセージをinfoからerrorにしていた箇所がそのまま残っていた。

2012-08-28 10:27 Updated by: hiroakinakano
評語

tcp_session.cpp L908にて、メッセージ処理をすべきところをnext_call_functionを呼んでいた。 メッセージを実行するように処理を変更する。

2012-09-04 13:47 Updated by: hiroakinakano
評語

メッセージ実行ループの最初にtimed_waitを入れているので、すでにmsgに値が入っていても無駄にwaitするようになっていたのを改善

2012-09-04 13:50 Updated by: hiroakinakano
評語

close処理メッセージのところでは、close処理以外のメッセージを処理することを想定していない。したがって、message_queueに溜まっているclose以外の処理は、直前にすべて廃棄する必要がある。その処理を追加。

2012-09-04 13:51 Updated by: hiroakinakano
  • Ticket Close date is changed to 2012-09-04 13:51
  • 狀態 Update from 開啟 to 關閉
評語

v3.0.4-2にここまでの修正が取り込まれたので、完了とする。

Attachment File List

編輯

You are not logged in. I you are not logged in, your comment will be treated as an anonymous post. » 登入