大佬们,都来帮我分析分析这个程序设计

2023-01-13 09:40:55 +08:00
 ccagml

前因

玩具的主要结构

  1. 主函数 main 中有个循环,不断从 队列 msg_queue 中取出数据处理.
  2. msg_queue 的数据来源有:
    • 2.1 控制台输入
      • 2.1.1 创建 一个线程 的线程池 boost::asio::thread_pool _console_thread(1)
      • 2.1.2 通过 boost::asio::post 让 匿名函数 f 在 _console_thread 中工作
      • 2.1.3 匿名函数 f 是 死循环 从 std::cin 读取输入, 放入 msg_queue
    • 2.2 数据库执行结果
      • 2.2.1 使用 mysqlcapi (libmysqlclient.so)
      • 2.2.2 创建 一个线程 的线程池 boost::asio::thread_pool _db_thread(10)
      • 2.2.3 不断从 db_queue 取出 需要执行的内容
        • db_queue 的数据来源是 1.的处理结果
      • 2.2.4 将执行结果放入 msg_queue
    • 2.3 网络通信
      • 2.3.1 创建 一个线程 的线程池 boost::asio::thread_pool _io_worker_thread(1)
      • 2.3.2 通过 boost::asio::post 让 _io_worker_thread 执行 boost::asio::io_context 的 run()
      • 2.3.3 通过 async_read_some 从 socket 读取数据, 如果完整了就放入 msg_queue
      • 2.3.4 每个 socket 上 有一个待发送的队列 wait_queue, 用 boost::asio::async_write 将 wait_queue 按顺序发出去
        • wait_queue 的数据来源是 1.的处理结果

想要请教的问题

  1. 目前这样的结构设计会有什么问题吗? 有什么不足之处?
  2. 在 2.3.2 中 只用 一个线程 执行 io_context.run(), 是不是表示 所有 socket 的 读写 都共用这个线程在处理?处理能力会不足吗?
1010 次点击
所在节点    编程
1 条回复
ccagml
2023-01-13 18:07:46 +08:00
🌝大佬们!什么情况?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/908603

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX