summaryrefslogtreecommitdiff
path: root/src/syncClient.cpp
diff options
context:
space:
mode:
authorOthmar Gsenger <otti@anytun.org>2008-11-24 23:17:47 +0000
committerOthmar Gsenger <otti@anytun.org>2008-11-24 23:17:47 +0000
commita3417dfb7d14e7831fe1fe1577e604ea6fb18b03 (patch)
tree272d13df0e29cb2e620eda5f192c675f4aff3038 /src/syncClient.cpp
parentfixed syncing, config & showtables (diff)
fixed sync reconnects
Diffstat (limited to 'src/syncClient.cpp')
-rw-r--r--src/syncClient.cpp52
1 files changed, 25 insertions, 27 deletions
diff --git a/src/syncClient.cpp b/src/syncClient.cpp
index 8170990..d2c5ce7 100644
--- a/src/syncClient.cpp
+++ b/src/syncClient.cpp
@@ -50,11 +50,12 @@ SyncClient::SyncClient(std::string hostname,std::string port)
void SyncClient::run()
{
- try
- {
- boost::asio::io_service io_service;
- for(;;)
+ bool connected(false);
+ for(;;)
+ {
+ try
{
+ boost::asio::io_service io_service;
boost::asio::ip::tcp::resolver resolver(io_service);
boost::asio::ip::tcp::resolver::query query( hostname_, port_);
boost::asio::ip::tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
@@ -69,35 +70,32 @@ void SyncClient::run()
}
if (error)
throw boost::system::system_error(error);
-
- try
+ if (!connected)
+ cLog.msg(Log::PRIO_NOTICE) << "sync: connected to " << hostname_ <<":"<< port_;
+ connected=true;
+ for (;;)
{
- for (;;)
- {
- boost::array<char, 1> buf;
- boost::system::error_code error;
+ boost::array<char, 1> buf;
+ boost::system::error_code error;
- size_t len = socket.read_some(boost::asio::buffer(buf), error);
+ size_t len = socket.read_some(boost::asio::buffer(buf), error);
- if (error == boost::asio::error::eof)
- break; // Connection closed cleanly by peer.
- else if (error)
- throw boost::system::system_error(error); // Some other error.
+ if (error == boost::asio::error::eof)
+ break; // Connection closed cleanly by peer.
+ else if (error)
+ throw boost::system::system_error(error); // Some other error.
- OnRawData(buf.data(), len);
- }
- }
- catch (std::exception& e)
- {
- cLog.msg(Log::PRIO_NOTICE) << e.what() << std::endl;
+ OnRawData(buf.data(), len);
}
}
- sleep(10);
- }
- catch (std::exception& e)
- {
- cLog.msg(Log::PRIO_NOTICE) << e.what() << std::endl;
- }
+ catch (std::exception& e)
+ {
+ if (connected)
+ cLog.msg(Log::PRIO_NOTICE) << "sync: connection to " << hostname_ <<":"<< port_<< " lost ("<< e.what() << ") retrying every 10sec";
+ connected=false;
+ sleep(10);
+ }
+ }
}
void SyncClient::OnRawData(const char *buf,size_t len)