摘要:迭代服务器最近在学习下开发,最简单的就是迭代服务器在网络程序里面,通常都是一个服务器处理多个客户机,为了出个多个客户机的请求,服务器端的程序有不同的处理方式。样例代码是服务端向客户端输出日期时间的功能。
Linux迭代服务器
最近在学习linux下Socket开发,最简单的就是迭代服务器
在网络程序里面,通常都是一个服务器处理多个客户机,为了出个多个客户机的请求,服务器端的程序有不同的处理方式。本节开始介绍Linux下套接字编程的服务器模型选择,主要包括循环服务器模型、并发服务器模型、IO复用服务器模型等,这也是我们常见的几种网络服务器模型。其中基本可以分为两大类,
迭代服务器:循环服务器在同一时刻只能响应一个客户端的请求,是比较简单的一种模型;
并发服务器:并发服务器在同一时刻可以响应多个客户端的请求,这里面又有很多分类,接下来会逐步介绍;
迭代服务器是指对于客户端的请求和连接,服务器逐个进行处理,处理完一个连接后再处理下一个连接,属于串行处理方式,结构比较简单。样例代码是服务端向客户端输出日期时间的功能。
以下是服务端代码:
server.c
#include#include #include #include #include #include #include #include #define BUFFLEN 1024 #define SERVER_PORT 12346 #define BACKLOG 5 int main(int argc, char *argv[]) { printf("等待客户端连接: "); int s_s, s_c; /*服务器套接字文件描述符*/ struct sockaddr_in local, from; /*本地地址*/ time_t now; char buff[BUFFLEN]; int n = 0; int len = sizeof(from); /*建立TCP套接字*/ s_s = socket(AF_INET, SOCK_STREAM, 0); /*初始化地址*/ memset(&local, 0, sizeof(local)); local.sin_family = AF_INET;/*AF_INET协议族*/ local.sin_addr.s_addr = htonl(INADDR_ANY);/*任意本地地址*/ local.sin_port = htons(SERVER_PORT);/*服务器端口*/ /*将套接字文件描述符绑定到本地地址和端口*/ int err = bind(s_s, (struct sockaddr*)&local, sizeof(local)); err = listen(s_s, BACKLOG);/*侦听*/ /*主处理过程*/ while(1) { /*接收客户端连接*/ s_c = accept(s_s, (struct sockaddr*)&from, &len); memset(buff, 0, BUFFLEN); n = recv(s_c, buff, BUFFLEN,0);/*接收发送方数据*/ if(n > 0 && !strncmp(buff, "TIME", 4))/*判断是否合法接收数据*/ {printf("have one "); memset(buff, 0, BUFFLEN); now = time(NULL); sprintf(buff, "%12s ",ctime(&now)); send(s_c, buff, strlen(buff),0);/*发送数据*/ sleep(10);//此处沉睡10秒 } close(s_c); } close(s_s); return 0; }
以下是客户端代码:
client.c #include#include #include #include #include #define BUFFLEN 1024 #define SERVER_PORT 12346 int main(int argc, char *argv[]) { int s; /*服务器套接字文件描述符*/ struct sockaddr_in server; /*本地地址*/ char buff[BUFFLEN]; int n = 0; /*建立TCP套接字*/ s = socket(AF_INET, SOCK_STREAM, 0); /*初始化地址*/ memset(&server, 0, sizeof(server)); server.sin_family = AF_INET;/*AF_INET协议族*/ server.sin_addr.s_addr = htonl(INADDR_ANY);/*任意本地地址*/ server.sin_port = htons(SERVER_PORT);/*服务器端口*/ /*连接服务器*/ int err = connect(s, (struct sockaddr*)&server,sizeof(server)); memset(buff, 0, BUFFLEN); strcpy(buff, "TIME"); /*发送数据*/ send(s, buff, strlen(buff), 0); memset(buff, 0, BUFFLEN); /*接收数据*/ n = recv(s, buff, BUFFLEN, 0); if(n >0){ printf("TIME:%s",buff); } close(s); return 0; }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/10898.html
摘要:在实践中,我们开发并上线了网关和负载均衡网关。而负载均衡网关则支持无缝替换传统交换机实现网关集群,支持一致性,并支持根据任意字段,内存和端口来计算哈希,支持协议。网络作为信息时代的重要载体,在云服务的快速发展下形成了独具特色的虚拟网络服务架构和模式。12月19日,2020中国云网络峰会于北京顺利召开,会上UCloud虚拟网络VPC负责人陈煌栋给大家带来了演讲《UCloud VPC技术演进之路...
摘要:今天主要讲解的是本文力求简单讲清每个知识点,希望大家看完能有所收获一和回顾线程安全的和我们知道是用于替代的,是线程安全的容器。使用迭代器遍历时不需要显示加锁,看看与方法的实现可能就有点眉目了。 前言 只有光头才能变强 showImg(https://segmentfault.com/img/remote/1460000016931828?w=1120&h=640); 前一阵子写过一篇C...
摘要:对此,黄启功表示,容器技术是虚拟化技术的演进结果,这也是企业架构变化的诉求。目前整个业界也在探索容器技术的标准问题,因为只有标准化之后才能被广泛接受,并大规模在企业中推广应用。 以Docker为代表的容器技术正在席卷整个IT业界,容器技术赋予了企业开发运维更多的敏捷性。而在以Docker为代表的容器虚拟化技术市场,初创公司纷纷开始瞄准这个领域进行创新开发,其中TenxCloud时速云就...
摘要:作者本文原载于,不允许转载关于命令的正则表达式使用的是不同标准的正则表达式,而且与中的正则表达式标准还不一样,真的蛋疼,详见正则表达式派别综述。 作者:LogM 本文原载于 https://segmentfault.com/u/logm/articles ,不允许转载~ 0. 关于 Linux 命令的正则表达式 awk、sed、grep 使用的是不同标准的正则表达式,而且与 C++、P...
摘要:请解释开源如何帮助。开源允许你有效快速地适应这些变化和影响。这可以追溯到生态系统,它类似于我们在的合作伙伴计划,是填补空白的胶水,完善给电信公司设想的网络解决方案。 作者:Pam Baker showImg(https://segmentfault.com/img/bVbqsgx?w=800&h=415);迎接即将举行的ONS(开放网络峰会),我们与Red Hat的NFV技术总监Tho...
阅读 1257·2023-04-25 16:31
阅读 1857·2021-11-24 10:33
阅读 1938·2021-10-08 10:04
阅读 3918·2021-10-08 10:04
阅读 2601·2021-09-23 11:33
阅读 2317·2021-09-23 11:31
阅读 2649·2021-09-08 09:45
阅读 2151·2021-09-06 15:02