From e0ce4528c5ffd43f651f88821723311541e9e461 Mon Sep 17 00:00:00 2001 From: Shauren Date: Tue, 9 Sep 2014 19:19:25 +0200 Subject: Core/NetworkIO: Use reactor style sending on linux to reduce locking overhead --- src/server/authserver/Main.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'src/server/authserver/Main.cpp') diff --git a/src/server/authserver/Main.cpp b/src/server/authserver/Main.cpp index f26c0342654..01dbaa6aa9a 100644 --- a/src/server/authserver/Main.cpp +++ b/src/server/authserver/Main.cpp @@ -118,7 +118,8 @@ int main(int argc, char** argv) } std::string bindIp = sConfigMgr->GetStringDefault("BindIP", "0.0.0.0"); - AsyncAcceptor authServer(_ioService, bindIp, port); + AsyncAcceptor authServer(_ioService, bindIp, port); + authServer.AsyncAccept(); // Set signal handlers boost::asio::signal_set signals(_ioService, SIGINT, SIGTERM); -- cgit v1.2.3 From 946e2d0ca679cca7e491c2e494c1c417ac27eceb Mon Sep 17 00:00:00 2001 From: Shauren Date: Wed, 10 Sep 2014 21:17:55 +0200 Subject: Core/Authserver: Added missing auth socket manager Closes #13085 --- src/server/authserver/CMakeLists.txt | 1 + src/server/authserver/Main.cpp | 24 +++++------ src/server/authserver/Server/AuthSocketMgr.h | 61 ++++++++++++++++++++++++++++ 3 files changed, 73 insertions(+), 13 deletions(-) create mode 100644 src/server/authserver/Server/AuthSocketMgr.h (limited to 'src/server/authserver/Main.cpp') diff --git a/src/server/authserver/CMakeLists.txt b/src/server/authserver/CMakeLists.txt index d6f0515a8e1..d7f1eb4fa30 100644 --- a/src/server/authserver/CMakeLists.txt +++ b/src/server/authserver/CMakeLists.txt @@ -44,6 +44,7 @@ endif() include_directories( ${CMAKE_BINARY_DIR} ${CMAKE_SOURCE_DIR}/src/server/shared + ${CMAKE_SOURCE_DIR}/src/server/shared/Configuration ${CMAKE_SOURCE_DIR}/src/server/shared/Database ${CMAKE_SOURCE_DIR}/src/server/shared/Debugging ${CMAKE_SOURCE_DIR}/src/server/shared/Packets diff --git a/src/server/authserver/Main.cpp b/src/server/authserver/Main.cpp index 01dbaa6aa9a..5f08ebe3127 100644 --- a/src/server/authserver/Main.cpp +++ b/src/server/authserver/Main.cpp @@ -24,23 +24,21 @@ * authentication server */ -#include -#include -#include -#include -#include -#include - -#include "AsyncAcceptor.h" -#include "AuthSession.h" +#include "AuthSocketMgr.h" #include "Common.h" -#include "Configuration/Config.h" -#include "Database/DatabaseEnv.h" +#include "Config.h" +#include "DatabaseEnv.h" #include "Log.h" #include "ProcessPriority.h" #include "RealmList.h" #include "SystemConfig.h" #include "Util.h" +#include +#include +#include +#include +#include +#include using boost::asio::ip::tcp; using namespace boost::program_options; @@ -118,8 +116,8 @@ int main(int argc, char** argv) } std::string bindIp = sConfigMgr->GetStringDefault("BindIP", "0.0.0.0"); - AsyncAcceptor authServer(_ioService, bindIp, port); - authServer.AsyncAccept(); + + sAuthSocketMgr.StartNetwork(_ioService, bindIp, port); // Set signal handlers boost::asio::signal_set signals(_ioService, SIGINT, SIGTERM); diff --git a/src/server/authserver/Server/AuthSocketMgr.h b/src/server/authserver/Server/AuthSocketMgr.h new file mode 100644 index 00000000000..a14ee26ed56 --- /dev/null +++ b/src/server/authserver/Server/AuthSocketMgr.h @@ -0,0 +1,61 @@ +/* + * Copyright (C) 2008-2014 TrinityCore + * + * 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 . + */ + +#ifndef AuthSocketMgr_h__ +#define AuthSocketMgr_h__ + +#include "SocketMgr.h" +#include "AuthSession.h" + +void OnSocketAccept(tcp::socket&& sock); + +class AuthSocketMgr : public SocketMgr +{ + typedef SocketMgr BaseSocketMgr; + +public: + static AuthSocketMgr& Instance() + { + static AuthSocketMgr instance; + return instance; + } + + bool StartNetwork(boost::asio::io_service& service, std::string const& bindIp, uint16 port) override + { + if (!BaseSocketMgr::StartNetwork(service, bindIp, port)) + return false; + + _acceptor->AsyncAcceptManaged(&OnSocketAccept); + return true; + } + +protected: + NetworkThread* CreateThreads() const override + { + return new NetworkThread[1]; + } +}; + +#define sAuthSocketMgr AuthSocketMgr::Instance() + +void OnSocketAccept(tcp::socket&& sock) +{ + sAuthSocketMgr.OnSocketOpen(std::forward(sock)); +} + + +#endif // AuthSocketMgr_h__ -- cgit v1.2.3