memgraph/src/memgraph_bolt.cpp

83 lines
1.8 KiB
C++
Raw Normal View History

#include <iostream>
#include <signal.h>
#include "communication/bolt/v1/server/server.hpp"
#include "communication/bolt/v1/server/worker.hpp"
#include "io/network/socket.hpp"
#include "logging/default.hpp"
#include "logging/streams/stdout.hpp"
#include "utils/terminate_handler.hpp"
static bolt::Server<bolt::Worker>* serverptr;
Logger logger;
void sigint_handler(int s)
{
auto signal = s == SIGINT ? "SIGINT" : "SIGABRT";
logger.info("Recieved signal {}", signal);
logger.info("Shutting down...");
std::exit(EXIT_SUCCESS);
}
static constexpr const char* interface = "0.0.0.0";
static constexpr const char* port = "7687";
int main(void)
{
// TODO figure out what is the relationship between this and signals
// that are configured below
std::set_terminate(&terminate_handler);
2016-08-19 08:28:22 +08:00
// logger init
#ifdef SYNC_LOGGER
logging::init_sync();
2016-08-19 08:28:22 +08:00
#else
logging::init_async();
#endif
logging::log->pipe(std::make_unique<Stdout>());
2016-08-19 08:28:22 +08:00
// get Main logger
logger = logging::log->logger("Main");
2016-08-19 08:28:22 +08:00
logger.info("{}", logging::log->type());
signal(SIGINT, sigint_handler);
signal(SIGABRT, sigint_handler);
io::Socket socket;
try
{
socket = io::Socket::bind(interface, port);
}
catch(io::NetworkError e)
{
logger.error("Cannot bind to socket on {} at {}", interface, port);
logger.error("{}", e.what());
std::exit(EXIT_FAILURE);
}
socket.set_non_blocking();
socket.listen(1024);
logger.info("Listening on {} at {}", interface, port);
bolt::Server<bolt::Worker> server(std::move(socket));
serverptr = &server;
// TODO: N should be configurable
2016-08-19 08:28:22 +08:00
auto N = std::thread::hardware_concurrency();
logger.info("Starting {} workers", N);
server.start(N);
logger.info("Shutting down...");
return EXIT_SUCCESS;
}