save updated local RouterInfo in separate thread

This commit is contained in:
orignal 2025-01-28 20:49:36 -05:00
parent 5d7a062f1b
commit daeb177579
2 changed files with 19 additions and 2 deletions

View file

@ -77,7 +77,9 @@ namespace i2p
m_CongestionUpdateTimer->cancel ();
m_Service->Stop ();
CleanUp (); // GarlicDestination
}
}
if (m_SavingRouterInfo.valid ())
m_SavingRouterInfo.wait ();
}
std::shared_ptr<i2p::data::RouterInfo::Buffer> RouterContext::CopyRouterInfoBuffer () const
@ -254,12 +256,25 @@ namespace i2p
void RouterContext::UpdateRouterInfo ()
{
std::shared_ptr<i2p::data::RouterInfo::Buffer> buffer;
{
std::lock_guard<std::mutex> l(m_RouterInfoMutex);
m_RouterInfo.CreateBuffer (m_Keys);
buffer = m_RouterInfo.CopyBuffer ();
}
m_RouterInfo.SaveToFile (i2p::fs::DataDirPath (ROUTER_INFO));
m_LastUpdateTime = i2p::util::GetSecondsSinceEpoch ();
// defer saving buffer to disk
if (m_SavingRouterInfo.valid ())
{
// wait until previous update complete
m_SavingRouterInfo.wait ();
m_SavingRouterInfo.get ();
}
m_SavingRouterInfo = std::async (std::launch::async,
[buffer = std::move(buffer)]()
{
i2p::data::RouterInfo::SaveToFile (i2p::fs::DataDirPath (ROUTER_INFO), buffer);
});
}
void RouterContext::NewNTCP2Keys ()

View file

@ -13,6 +13,7 @@
#include <string>
#include <memory>
#include <random>
#include <future>
#include <unordered_set>
#include <boost/asio.hpp>
#include "Identity.h"
@ -266,6 +267,7 @@ namespace garlic
bool m_IsHiddenMode; // not publish
mutable std::mutex m_RouterInfoMutex;
std::mt19937 m_Rng;
std::future<void> m_SavingRouterInfo;
};
extern RouterContext context;