Core/Threading: Create ThreadPool class

This commit is contained in:
Shauren
2022-10-08 20:08:29 +02:00
parent 0174e6ba80
commit d82b2b1a67
2 changed files with 54 additions and 10 deletions

View File

@@ -0,0 +1,48 @@
/*
* This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at your
* option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef TRINITY_THREAD_POOL_H
#define TRINITY_THREAD_POOL_H
#include <boost/asio/post.hpp>
#include <boost/asio/thread_pool.hpp>
#include <thread>
namespace Trinity
{
class ThreadPool
{
public:
explicit ThreadPool(std::size_t numThreads = std::thread::hardware_concurrency()) : _impl(numThreads) { }
template<typename T>
decltype(auto) PostWork(T&& work)
{
return boost::asio::post(_impl, std::forward<T>(work));
}
void Join()
{
_impl.join();
}
private:
boost::asio::thread_pool _impl;
};
}
#endif // TRINITY_THREAD_POOL_H

View File

@@ -49,6 +49,7 @@
#include "SecretMgr.h"
#include "SharedDefines.h"
#include "TCSoap.h"
#include "ThreadPool.h"
#include "World.h"
#include "WorldSocket.h"
#include "WorldSocketMgr.h"
@@ -241,20 +242,13 @@ extern int main(int argc, char** argv)
// Start the Boost based thread pool
int numThreads = sConfigMgr->GetIntDefault("ThreadPool", 1);
std::shared_ptr<std::vector<std::thread>> threadPool(new std::vector<std::thread>(), [ioContext](std::vector<std::thread>* del)
{
ioContext->stop();
for (std::thread& thr : *del)
thr.join();
delete del;
});
if (numThreads < 1)
numThreads = 1;
std::shared_ptr<Trinity::ThreadPool> threadPool = std::make_shared<Trinity::ThreadPool>(numThreads);
for (int i = 0; i < numThreads; ++i)
threadPool->push_back(std::thread([ioContext]() { ioContext->run(); }));
threadPool->PostWork([ioContext]() { ioContext->run(); });
// Set process priority according to configuration settings
SetProcessPriority("server.worldserver", sConfigMgr->GetIntDefault(CONFIG_PROCESSOR_AFFINITY, 0), sConfigMgr->GetBoolDefault(CONFIG_HIGH_PRIORITY, false));
@@ -390,6 +384,8 @@ extern int main(int argc, char** argv)
WorldUpdateLoop();
// Shutdown starts here
ioContext->stop();
threadPool.reset();
sLog->SetSynchronous();