提升异步TCP服务器写入错误

问题描述:

我有一个问题,我有一个客户端和服务器之间的TCP连接,当客户端初始化时,他发送一条消息到服务器和服务器回答一个欢迎消息。提升异步TCP服务器写入错误

所有这一切都在本地网络上正常工作。

所以我的问题是,我使用async_write和async_read(因为我需要我的服务器是异步的) 我的客户端发送消息到服务器,服务器看到它并回答,但我的客户端从来没有得到欢迎消息。

否则,当我关闭我的服务器时,客户端收到欢迎消息。

这里是我的服务器代码:

的main.cpp

int main() 
{ 
    try 
    { 
    boost::asio::io_service io_service; 

    tcp_server server(io_service, 7171); 
    io_service.run(); 
} 
catch (std::exception& e) 
{ 
    std::cerr << e.what() << std::endl; 
} 

return 0; 
} 

tcp_server

class tcp_server 
{ 
    public: 
tcp_server(boost::asio::io_service& io_service, int port) // (1)                                            
    : m_acceptor(io_service, tcp::endpoint(tcp::v4(), port)) 
    { 
     std::cout << "Port : " << port << std::endl; 
     start_accept(); 
    } 

private: 

    void start_accept() 
    { 
    tcp_connection::pointer new_connection = tcp_connection::create(m_acceptor.io_service()); 

    m_acceptor.async_accept(new_connection->socket(), 
          boost::bind(&tcp_server::handle_accept, this, new_connection, 
        boost::asio::placeholders::error)); 
    } 

    void handle_accept(tcp_connection::pointer new_connection, const boost::system::error_code& error) // (4)                                 
    { 
    if (!error) 
     { 
     std::cout << "Get one client!" << std::endl; 
     new_connection->start(); 
     start_accept(); // (5)                                                    
     } 
    } 


    tcp::acceptor m_acceptor; 
}; 

tcp_connection

class tcp_connection : public boost::enable_shared_from_this<tcp_connection> 
{ 
public: 
    typedef boost::shared_ptr<tcp_connection> pointer; 

    static pointer create(boost::asio::io_service& ios) 
    { 
    pointer new_connection(new tcp_connection(ios)); 
    return new_connection; 
    } 

    tcp::socket& socket() 
    { 
     return m_socket; 
    } 

    void do_read() // (1)                                                      
    { 
    boost::asio::async_read(m_socket, boost::asio::buffer(m_buffer), // (3)                                         
          boost::bind(&tcp_connection::handle_read, shared_from_this(), 
             boost::asio::placeholders::error) 
          ); 
    } 


    void start() 
    { 
    m_message = "Welcome on the server \n"; 

    boost::asio::async_write(m_socket, boost::asio::buffer(m_message), 
          boost::bind(&tcp_connection::handle_write, shared_from_this(), 
             boost::asio::placeholders::error) 
          ); 
    } 
private: 
tcp_connection(boost::asio::io_service& io_service) 
    : m_socket(io_service) 
     { } 

    void handle_write(const boost::system::error_code& error) 
    { 
    std::cout << "handle_write : "<< m_message << std::endl; 
    if (!error) 
     do_read(); // (2)                                                      
    else 
     std::cout << error.message() << std::endl; 
    } 

    void handle_read(const boost::system::error_code& error) // (6)                                            
    { 
    std::cout << "handle read" << m_buffer.data() <<std::endl; 
    if (!error) 
     do_read(); 
    else 
     close(); 
    } 

void close() // (7)                                                       
    { 
    m_socket.close(); 
    } 

    tcp::socket m_socket; 
    std::string m_message; 
    boost::array<char, 128> m_buffer; 
}; 

我不明白为什么? 我该如何避免这种情况?

+0

有多少线程运行你的io队列(io_service :: run())?也许所有这些线程都会阻塞,直到您关闭服务器。 – 2012-07-16 12:41:37

+0

我只用一次调用io_service.run()在我的主,我只使用异步方法后。 – kavaliero 2012-07-16 12:44:51

+0

将调试器附加到您的服务器进程并查看调用io_service.run()的线程阻塞的内容。 – 2012-07-16 12:47:38

请的async_read该手册:

此功能用于从流读异步一定数量的数据的字节 的。函数调用总是立即返回。 异步操作将继续,直到出现以下 条件之一为真:

  • 所提供的缓冲器满了。也就是说,传输的字节数等于缓冲区大小的总和。
  • An error occurred。

在你的情况下,两个条件都不满足,直到对方关闭套接字为止。

您应该使用async_read_some代替(或async_read_until,但它可能会更复杂一点)。

+0

这个错误是一个更基本的错误的后果 - 你从来没有设计或实现一个协议。一方如何知道它何时收到整个消息?什么是信息格式? – 2012-07-16 19:53:48