mirror of
https://github.com/PurpleI2P/i2pd
synced 2024-11-10 00:00:29 +03:00
NTP sync in separate thread
This commit is contained in:
parent
d7081c5f23
commit
8a549b83a2
@ -42,6 +42,7 @@ namespace i2p
|
|||||||
std::unique_ptr<i2p::http::HTTPServer> httpServer;
|
std::unique_ptr<i2p::http::HTTPServer> httpServer;
|
||||||
std::unique_ptr<i2p::client::I2PControlService> m_I2PControlService;
|
std::unique_ptr<i2p::client::I2PControlService> m_I2PControlService;
|
||||||
std::unique_ptr<i2p::transport::UPnP> UPnP;
|
std::unique_ptr<i2p::transport::UPnP> UPnP;
|
||||||
|
std::unique_ptr<i2p::util::NTPTimeSync> m_NTPSync;
|
||||||
#ifdef WITH_EVENTS
|
#ifdef WITH_EVENTS
|
||||||
std::unique_ptr<i2p::event::WebsocketServer> m_WebsocketServer;
|
std::unique_ptr<i2p::event::WebsocketServer> m_WebsocketServer;
|
||||||
#endif
|
#endif
|
||||||
@ -284,7 +285,11 @@ namespace i2p
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool nettime; i2p::config::GetOption("nettime.enabled", nettime);
|
bool nettime; i2p::config::GetOption("nettime.enabled", nettime);
|
||||||
if (nettime) i2p::util::RequestNTPTimeSync ();
|
if (nettime)
|
||||||
|
{
|
||||||
|
d.m_NTPSync = std::unique_ptr<i2p::util::NTPTimeSync>(new i2p::util::NTPTimeSync);
|
||||||
|
d.m_NTPSync->Start ();
|
||||||
|
}
|
||||||
|
|
||||||
bool ntcp; i2p::config::GetOption("ntcp", ntcp);
|
bool ntcp; i2p::config::GetOption("ntcp", ntcp);
|
||||||
bool ssu; i2p::config::GetOption("ssu", ssu);
|
bool ssu; i2p::config::GetOption("ssu", ssu);
|
||||||
@ -355,11 +360,18 @@ namespace i2p
|
|||||||
LogPrint(eLogInfo, "Daemon: stopping Tunnels");
|
LogPrint(eLogInfo, "Daemon: stopping Tunnels");
|
||||||
i2p::tunnel::tunnels.Stop();
|
i2p::tunnel::tunnels.Stop();
|
||||||
|
|
||||||
if (d.UPnP) {
|
if (d.UPnP)
|
||||||
|
{
|
||||||
d.UPnP->Stop ();
|
d.UPnP->Stop ();
|
||||||
d.UPnP = nullptr;
|
d.UPnP = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (d.m_NTPSync)
|
||||||
|
{
|
||||||
|
d.m_NTPSync->Stop ();
|
||||||
|
d.m_NTPSync = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
LogPrint(eLogInfo, "Daemon: stopping Transports");
|
LogPrint(eLogInfo, "Daemon: stopping Transports");
|
||||||
i2p::transport::transports.Stop();
|
i2p::transport::transports.Stop();
|
||||||
LogPrint(eLogInfo, "Daemon: stopping NetDB");
|
LogPrint(eLogInfo, "Daemon: stopping NetDB");
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
#include <future>
|
#include <future>
|
||||||
#include <boost/asio.hpp>
|
#include <boost/asio.hpp>
|
||||||
@ -92,15 +90,77 @@ namespace util
|
|||||||
LogPrint (eLogError, "Timestamp: Couldn't resove address ", address);
|
LogPrint (eLogError, "Timestamp: Couldn't resove address ", address);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RequestNTPTimeSync ()
|
NTPTimeSync::NTPTimeSync (): m_IsRunning (false), m_Timer (m_Service)
|
||||||
{
|
{
|
||||||
|
i2p::config::GetOption("nettime.ntpsyncinterval", m_SyncInterval);
|
||||||
std::string ntpservers; i2p::config::GetOption("nettime.ntpservers", ntpservers);
|
std::string ntpservers; i2p::config::GetOption("nettime.ntpservers", ntpservers);
|
||||||
if (ntpservers.length () > 0)
|
boost::split (m_NTPServersList, ntpservers, boost::is_any_of(","), boost::token_compress_on);
|
||||||
|
}
|
||||||
|
|
||||||
|
NTPTimeSync::~NTPTimeSync ()
|
||||||
{
|
{
|
||||||
std::vector<std::string> ntpList;
|
Stop ();
|
||||||
boost::split (ntpList, ntpservers, boost::is_any_of(","), boost::token_compress_on);
|
}
|
||||||
if (ntpList.size () > 0)
|
|
||||||
std::async (std::launch::async, SyncTimeWithNTP, ntpList[rand () % ntpList.size ()]);
|
void NTPTimeSync::Start()
|
||||||
|
{
|
||||||
|
if (m_NTPServersList.size () > 0)
|
||||||
|
{
|
||||||
|
m_IsRunning = true;
|
||||||
|
LogPrint(eLogInfo, "Timestamp: NTP time sync starting");
|
||||||
|
m_Service.post (std::bind (&NTPTimeSync::Sync, this));
|
||||||
|
m_Thread.reset (new std::thread (std::bind (&NTPTimeSync::Run, this)));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
LogPrint (eLogWarning, "Timestamp: No NTP server found");
|
||||||
|
}
|
||||||
|
|
||||||
|
void NTPTimeSync::Stop ()
|
||||||
|
{
|
||||||
|
if (m_IsRunning)
|
||||||
|
{
|
||||||
|
LogPrint(eLogInfo, "Timestamp: NTP time sync stopping");
|
||||||
|
m_IsRunning = false;
|
||||||
|
m_Timer.cancel ();
|
||||||
|
m_Service.stop ();
|
||||||
|
if (m_Thread)
|
||||||
|
{
|
||||||
|
m_Thread->join ();
|
||||||
|
m_Thread.reset (nullptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void NTPTimeSync::Run ()
|
||||||
|
{
|
||||||
|
while (m_IsRunning)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
m_Service.run ();
|
||||||
|
}
|
||||||
|
catch (std::exception& ex)
|
||||||
|
{
|
||||||
|
LogPrint (eLogError, "Timestamp: NTP time sync exception: ", ex.what ());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void NTPTimeSync::Sync ()
|
||||||
|
{
|
||||||
|
if (m_NTPServersList.size () > 0)
|
||||||
|
SyncTimeWithNTP (m_NTPServersList[rand () % m_NTPServersList.size ()]);
|
||||||
|
else
|
||||||
|
m_IsRunning = false;
|
||||||
|
|
||||||
|
if (m_IsRunning)
|
||||||
|
{
|
||||||
|
m_Timer.expires_from_now (boost::posix_time::hours (m_SyncInterval));
|
||||||
|
m_Timer.async_wait ([this](const boost::system::error_code& ecode)
|
||||||
|
{
|
||||||
|
if (ecode != boost::asio::error::operation_aborted)
|
||||||
|
Sync ();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,6 +2,10 @@
|
|||||||
#define TIMESTAMP_H__
|
#define TIMESTAMP_H__
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
#include <thread>
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <boost/asio.hpp>
|
||||||
|
|
||||||
namespace i2p
|
namespace i2p
|
||||||
{
|
{
|
||||||
@ -11,7 +15,30 @@ namespace util
|
|||||||
uint32_t GetHoursSinceEpoch ();
|
uint32_t GetHoursSinceEpoch ();
|
||||||
uint64_t GetSecondsSinceEpoch ();
|
uint64_t GetSecondsSinceEpoch ();
|
||||||
|
|
||||||
void RequestNTPTimeSync ();
|
class NTPTimeSync
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
NTPTimeSync ();
|
||||||
|
~NTPTimeSync ();
|
||||||
|
|
||||||
|
void Start ();
|
||||||
|
void Stop ();
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
void Run ();
|
||||||
|
void Sync ();
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
bool m_IsRunning;
|
||||||
|
std::unique_ptr<std::thread> m_Thread;
|
||||||
|
boost::asio::io_service m_Service;
|
||||||
|
boost::asio::deadline_timer m_Timer;
|
||||||
|
int m_SyncInterval;
|
||||||
|
std::vector<std::string> m_NTPServersList;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user