> 文档中心 > 2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现

2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现

推荐一个 零声学院 免费公开课程,个人觉得老师讲得不错,分享给大家:[Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,立即学习]
后台服务器:https://course.0voice.com/v1/course/intro?courseId=5&agentId=0
────────────────────────────────────
请求第三方资源的有哪些?
http请求,人脸识别,定位天气。
2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现
发送请求等待响应,这是一个非常耗时的操作。如果做成不等待结果,该怎么做?如果多开线程,和线程池也就是同一个原理。

我们如果做成并行的呢?

只能不等待结果继续干别的事,统一用别的线程去处理结果。
2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现

我们该如何实现?

接收结果线程如何拿到send的fd呢?把fd添加到epoll中。

  • commit
  • thread_callback
  • init
  • destory
    2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现
    King 式四元组。
    2022年5月28日记:Linux服务器开发,King老师,异步请求池的实现
    长时间运行时候,创建线程也会创建失败,创建完再创建也是错误。
struct epoll_arg * aparg=(struct epoll_arg *)calloc(1,ziseof(struct epoll_arg));if(eparg ==NULL) return -1;eparg->fd=sockfd;eparg->cb=cb;struct epoll_event ev;ev.data.ptr=eparg;ev.events=EPOLLIN;epoll_ctl(ctx->epfd,EPOLL_CTL_ADD,sockfd,&ev);

总结

麻麻咧咧的感觉,多余的话我就不说了。