• R/O
  • HTTP
  • SSH
  • HTTPS

Commit

Tags
Keine Tags

Frequently used words (click to add to your profile)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

Commit MetaInfo

Revisiond6f6c0e4c13e15a265702a2c97c61a0ea3ce24eb (tree)
Zeit2014-02-26 13:36:58
AutorHiroaki Nakano <nakano.hiroaki@nttc...>
CommiterHiroaki Nakano

Log Message

Merge branch 'fix_memory_leak' into v3.1.1-devel

Ändern Zusammenfassung

Diff

--- a/l7vsd/include/virtualservice.h
+++ b/l7vsd/include/virtualservice.h
@@ -621,6 +621,8 @@ public:
621621 void run();
622622 void stop();
623623
624+ boost::shared_ptr<boost::thread> vs_thread_ptr;
625+
624626 void connection_active(const boost::asio::ip::tcp::endpoint &);
625627 void connection_inactive(const boost::asio::ip::tcp::endpoint &);
626628 void release_session(const tcp_session *session_ptr);
--- a/l7vsd/src/l7vsd.cpp
+++ b/l7vsd/src/l7vsd.cpp
@@ -249,7 +249,7 @@ void l7vsd::add_virtual_service(const virtualservice_element *in_vselement, e
249249 try {
250250
251251 // create thread and run
252- vs_threads.create_thread(boost::bind(&virtual_service::run, vsptr));
252+ (*vsptr).vs_thread_ptr = boost::shared_ptr<boost::thread>(vs_threads.create_thread(boost::bind(&virtual_service::run, vsptr)));
253253
254254 } catch (...) {
255255 std::stringstream buf;
@@ -348,6 +348,8 @@ void l7vsd::del_virtual_service(const virtualservice_element *in_vselement, e
348348 if (vslist.end() != vsitr) {
349349 // vs stop
350350 (*vsitr)->stop();
351+ (*vsitr)->vs_thread_ptr->join();
352+ vs_threads.remove_thread((*vsitr)->vs_thread_ptr.get());
351353 // vs finalize
352354 (*vsitr)->finalize(err);
353355
@@ -791,14 +793,14 @@ void l7vsd::flush_virtual_service(error_code &err)
791793
792794 // vs stop
793795 (*itr)->stop();
796+ // join virtualservice threads
797+ (*itr)->vs_thread_ptr->join();
798+ vs_threads.remove_thread((*itr)->vs_thread_ptr.get());
794799 // vs finalize
795800 (*itr)->finalize(err);
796801 }
797802 }
798803
799- // join virtualservice threads
800- vs_threads.join_all();
801-
802804 // replication switch to slave
803805 rep->switch_to_slave();
804806 }