C++ linux epoll并发服务器模型初探

简介: socket通讯流程图 最简单的可以通讯的C++服务器端代码:#include #include #include #include #include #include #define SERV_PORT 8000int main(vo...

socket通讯流程图
这里写图片描述
最简单的可以通讯的C++服务器端代码:

#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>

#define SERV_PORT  8000

int main(void)
{
    int lfd, cfd;
    struct sockaddr_in serv_addr, clin_addr;
    socklen_t clin_len;
    char buf[1024];
    int len;
    //AF_INET ipv4   SOCK_STREAM:tcp
    lfd = socket(AF_INET, SOCK_STREAM, 0);

    serv_addr.sin_family = AF_INET;
    serv_addr.sin_addr.s_addr = htonl(INADDR_ANY); //ip
    serv_addr.sin_port = htons(SERV_PORT); // host to 网络序 大端序
    //IP+PORT 泛型指针  void *
    bind(lfd, (struct sockaddr *)&serv_addr, sizeof(serv_addr));

    listen(lfd, 128);

    clin_len = sizeof(clin_addr);
    cfd = accept(lfd, (struct sockaddr *)&clin_addr, &clin_len);
    len = read(cfd, buf, sizeof(buf));

    write(STDOUT_FILENO, buf, len);
    close(lfd);
    close(cfd);
}

操作步骤:
1. 通过vim server.c创建一个c文件按下i键->写完上面的代码之后->esc->wq保存
2. 编写简单的makefile用于编译代码文件
gcc server.c -o server
3. 在控制台输入make,会自动生成一个server.c的可运行文件server
4. 在控制台输入./server,启动服务器
这里写图片描述
5. 客户端模拟测试
这里写图片描述
或者nc 192.168.1.126 8000 nc是netcat的


epoll模型
原理图
这里写图片描述
三个核心函数:
epoll_create(1024) 参数是节点大小,但现在linux已经废弃这个参数了,能插入多少个节点,取决于服务器内存大小
epoll_ctl() 添加/修改/删除监控文件的描述符
epoll_wait() 监控阻塞

文件拷贝命令: scp 文件 webdev@123.57.211.212:/home/webdev
查看端口信息: sudo netstat -apn | grep :8000

基于epoll模型的开源框架
libevent
libev
nginx
木铎(C++)

epoll代码待续

相关文章
|
3天前
|
Java
Java Socket编程与多线程:提升客户端-服务器通信的并发性能
【6月更文挑战第21天】Java网络编程中,Socket结合多线程提升并发性能,服务器对每个客户端连接启动新线程处理,如示例所示,实现每个客户端的独立操作。多线程利用多核处理器能力,避免串行等待,提升响应速度。防止死锁需减少共享资源,统一锁定顺序,使用超时和重试策略。使用synchronized、ReentrantLock等维持数据一致性。多线程带来性能提升的同时,也伴随复杂性和挑战。
|
2天前
|
Linux vr&ar C语言
Linux怎样更新Centos下Gcc版本支持C17?Centos7快速安装gcc8.3.1 可支持C++17(附gcc相关链接整理)
Linux怎样更新Centos下Gcc版本支持C17?Centos7快速安装gcc8.3.1 可支持C++17(附gcc相关链接整理)
13 2
|
8天前
|
存储 网络协议 编译器
【干货总结】Linux C/C++面试知识点
Linux C/C++基础与进阶知识点,不仅用于面试,平时开发也用得上!
233 8
|
5天前
|
Linux C++
c++高级篇(三) ——Linux下IO多路复用之poll模型
c++高级篇(三) ——Linux下IO多路复用之poll模型
|
5天前
|
缓存 监控 网络协议
c++高级篇(二) ——Linux下IO多路复用之select模型
c++高级篇(二) ——Linux下IO多路复用之select模型
|
6天前
|
存储 监控 Linux
性能监控之Telegraf+InfluxDB+Grafana linux服务器实时监控
【6月更文挑战11天】标题性能监控之 Java Metrics 度量包性能监控之Telegraf+InfluxDB+Grafana linux服务器实时监控
21 2
|
7天前
|
Linux 网络安全
|
3天前
|
数据可视化 网络协议 Linux
Linux 怎样通过win 远程桌面连接链接Linux后台服务器的可视化图形界面
Linux 怎样通过win 远程桌面连接链接Linux后台服务器的可视化图形界面
8 0
|
5天前
|
算法 Linux Shell
c++高级篇(一) —— 初识Linux下的进程控制
c++高级篇(一) —— 初识Linux下的进程控制
|
5天前
|
网络协议
UDP服务器的并发方案
UDP服务器的并发方案
10 0