muduo/examples/zeromq/local_lat.cc
2024-03-08 14:03:37 +08:00

65 lines
1.6 KiB
C++

#include "muduo/base/Logging.h"
#include "muduo/net/EventLoop.h"
#include "muduo/net/TcpServer.h"
#include "examples/asio/chat/codec.h"
#include <stdio.h>
#include <unistd.h>
using std::placeholders::_1;
using std::placeholders::_2;
using std::placeholders::_3;
using muduo::get_pointer;
bool g_tcpNoDelay = false;
void onConnection(const muduo::net::TcpConnectionPtr& conn)
{
if (conn->connected())
{
conn->setTcpNoDelay(g_tcpNoDelay);
}
}
void onStringMessage(LengthHeaderCodec* codec,
const muduo::net::TcpConnectionPtr& conn,
const muduo::string& message,
muduo::Timestamp)
{
codec->send(get_pointer(conn), message);
}
int main(int argc, char* argv[])
{
if (argc > 1)
{
uint16_t port = static_cast<uint16_t>(atoi(argv[1]));
g_tcpNoDelay = argc > 2 ? atoi(argv[2]) : false;
int threadCount = argc > 3 ? atoi(argv[3]) : 0;
LOG_INFO << "pid = " << getpid() << ", listen port = " << port;
// muduo::Logger::setLogLevel(muduo::Logger::WARN);
muduo::net::EventLoop loop;
muduo::net::InetAddress listenAddr(port);
muduo::net::TcpServer server(&loop, listenAddr, "PingPong");
LengthHeaderCodec codec(std::bind(onStringMessage, &codec, _1, _2, _3));
server.setConnectionCallback(onConnection);
server.setMessageCallback(
std::bind(&LengthHeaderCodec::onMessage, &codec, _1, _2, _3));
if (threadCount > 1)
{
server.setThreadNum(threadCount);
}
server.start();
loop.loop();
}
else
{
fprintf(stderr, "Usage: %s listen_port [tcp_no_delay [threads]]\n", argv[0]);
}
}