직렬화 함수 작성 끝
This commit is contained in:
77
Server/src/server.cpp
Normal file
77
Server/src/server.cpp
Normal file
@@ -0,0 +1,77 @@
|
||||
#include <chrono>
|
||||
|
||||
#include "socket/iocp.h"
|
||||
#include "socket/tcp_socket.h"
|
||||
#include "socket/udp_socket.h"
|
||||
#include "socket/wsa_manager.h"
|
||||
#include "utils/log.h"
|
||||
#include "utils/snowflake.h"
|
||||
#include "socket/packet.h"
|
||||
|
||||
#define LISTENIP "::"
|
||||
#define LISTENPORT 9010
|
||||
|
||||
void EchoClient(utils::ThreadPool* tp, Network::IOCP* iocp,
|
||||
Network::TCPSocket NewSock, Network::Address NewAddr) {
|
||||
Network::IOCPPASSINDATA* recv_data = new Network::IOCPPASSINDATA(16 * 1024);
|
||||
recv_data->socket = std::make_shared<Network::Socket>(NewSock);
|
||||
recv_data->IOCPInstance = iocp;
|
||||
auto timestamp = std::chrono::system_clock::now();
|
||||
while (!iocp->recv(recv_data)) {
|
||||
if (std::chrono::duration_cast<std::chrono::milliseconds>(
|
||||
std::chrono::system_clock::now() - timestamp)
|
||||
.count() == 1000) {
|
||||
tp->enqueueJob(EchoClient, iocp, NewSock, NewAddr);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<Network::IOCPPASSINDATA*> send_data;
|
||||
recv_data->event = Network::IOCPEVENT::WRITE;
|
||||
send_data.push_back(recv_data);
|
||||
iocp->send(NewSock.sock, &send_data);
|
||||
|
||||
tp->enqueueJob(EchoClient, iocp, NewSock, NewAddr);
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
Network::WSAManager wsamanager;
|
||||
#if !defined(NDEBUG)
|
||||
utils::setDefaultLogger(spdlog::level::level_enum::debug, "log.log", 1024, 2);
|
||||
#endif
|
||||
utils::ThreadPool tp(0);
|
||||
Network::IOCP iocp;
|
||||
iocp.init(&tp, SessionProtocol::TCP);
|
||||
|
||||
Network::Address addr;
|
||||
|
||||
addr.set(AF_INET6, "::", 9010);
|
||||
|
||||
Network::Socket* sock;
|
||||
Network::TCPSocket TCPSock;
|
||||
TCPSock.init(AF_INET6);
|
||||
sock = &TCPSock;
|
||||
if (TCPSock.bind(addr) == INVALID_SOCKET) {
|
||||
spdlog::error("bind()");
|
||||
std::exit(EXIT_FAILURE);
|
||||
}
|
||||
if (TCPSock.listen(SOMAXCONN) == INVALID_SOCKET) {
|
||||
spdlog::error("listen()");
|
||||
std::exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
while (true) {
|
||||
Network::TCPSocket NewSock;
|
||||
Network::Address NewAddr;
|
||||
NewAddr.length = addr.length;
|
||||
spdlog::info("Waiting for connection");
|
||||
TCPSock.accept(NewSock, NewAddr);
|
||||
|
||||
Network::IOCPPASSINDATA* data = new Network::IOCPPASSINDATA(16 * 1024);
|
||||
data->socket = std::make_shared<Network::Socket>(NewSock);
|
||||
data->IOCPInstance = &iocp;
|
||||
iocp.registerTCPSocket(data);
|
||||
|
||||
tp.enqueueJob(EchoClient, &iocp, NewSock, NewAddr);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user