使用boost::asio库实现多个子进程监听同一个端口

class session_http {
public:
	session_http(boost::asio::io_context &io) : socket_(io) {};
	void run(boost::asio::yield_context yield) {
	boost::system::error_code ec;
	boost::beast::flat_buffer buffer;
	while (true) {
		// Read a request
		boost::beast::http::async_read(socket_, buffer, req_, yield[ec]);
		if(ec) {
			BOOST_LOG_TRIVIAL(error) << "Read fail: " << ec.message();
			break;
		}
		BOOST_LOG_TRIVIAL(debug) << "Read: " << req_;
		BOOST_LOG_TRIVIAL(info) << "Read: " << req_.method_string() << " " << req_.target();

		send_response(yield, "success");
		if(req_.need_eof())	{// ture means Connection: close
			// This means we should close the connection, usually because
			// the response indicated the "Connection: close" semantic.
			break;
		}
		req_.body().clear();
	}
    // Send a TCP shutdown
    socket_.shutdown(boost::asio::ip::tcp:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值