实例一:不支持并发,单服务器---单客户端

/*************************************************************************
> File Name: ser01.c
> Author:
> Mail:
> Created Time: 2015年11月22日 星期日 10时22分17秒
************************************************************************/ #include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h> int main()
{
//int socket(int domain, int type, int protocol);
int sockfd;
sockfd = socket(AF_INET, SOCK_STREAM, 0); struct sockaddr_in seraddr;
seraddr.sin_family = AF_INET;
seraddr.sin_port = htons(8001);
seraddr.sin_addr.s_addr = inet_addr("127.0.0.1"); //int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
bind(sockfd, (struct sockaddr *)&seraddr, sizeof(seraddr)); listen(sockfd, 128); struct sockaddr cliaddr;
socklen_t clilen;
int connfd;
connfd = accept(sockfd, (struct sockaddr *)&cliaddr, &clilen); char recvbuf[2014] = {0};
int recvcount = 0; while(1){
recvcount = read(connfd, recvbuf,1024);
if (recvcount == 0){
printf("read is over.\n");
printf("the client is over.\n");
exit(0);
}
else if (recvcount == -1){
perror("read error.\n");
exit(EXIT_FAILURE);
}
fputs(recvbuf, stdout);
write(connfd, recvbuf, strlen(recvbuf));
memset(recvbuf, 0, 1024);
} exit(0);
}
/*************************************************************************
> File Name: cli01.c
> Author:
> Mail:
> Created Time: 2015年11月22日 星期日 11时56分05秒
************************************************************************/ #include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <string.h> int main()
{ int sockfd, ret;
struct sockaddr_in seraddr;
seraddr.sin_family = AF_INET;
seraddr.sin_port = htons(8001);
seraddr.sin_addr.s_addr = inet_addr("127.0.0.1"); sockfd = socket(AF_INET, SOCK_STREAM, 0); ret = connect(sockfd, (struct sockaddr*)&seraddr, sizeof(seraddr));
if(ret == -1){
perror("bind error.\n");
exit(EXIT_FAILURE);
} char recvbuf[1024] = {0};
char sendbuff[1024] = {0}; while(fgets(sendbuff, 1024, stdin) != NULL){
write(sockfd, sendbuff, strlen(sendbuff));
read(sockfd, recvbuf, 1024);
fputs(recvbuf, stdout);
memset(recvbuf, 0, 1024);
memset(sendbuff, 0, 1024);
} exit(0);
}

server:

client:

实例二:支持多并发,单服务器----多客户端

/*************************************************************************
> File Name: ser02.c
> Author:
> Mail:
> Created Time: 2015年11月22日 星期日 10时22分17秒
************************************************************************/ #include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h> int main()
{
//int socket(int domain, int type, int protocol);
int sockfd;
sockfd = socket(AF_INET, SOCK_STREAM, 0); struct sockaddr_in seraddr;
seraddr.sin_family = AF_INET;
seraddr.sin_port = htons(8001);
seraddr.sin_addr.s_addr = inet_addr("127.0.0.1"); //int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
bind(sockfd, (struct sockaddr *)&seraddr, sizeof(seraddr)); listen(sockfd, 128); struct sockaddr_in cliaddr;
socklen_t clilen; int connfd;
char recvbuf[2014] = {0};
int recvcount = 0; while(1){
connfd = accept(sockfd, (struct sockaddr *)&cliaddr, &clilen);
if(connfd == -1){
perror("accept error.\n");
exit(EXIT_FAILURE);
}
pid_t pid = fork(); if(pid == 0){
while(1){
recvcount = read(connfd, recvbuf,1024);
if (recvcount == 0){
printf("%s:%d is over.\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));
exit(0);
}
else if (recvcount == -1){
perror("read error.\n");
exit(EXIT_FAILURE);
}
printf("%d receive from %s:%d - ", getpid(), inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));
fputs(recvbuf, stdout);
write(connfd, recvbuf, strlen(recvbuf));
memset(recvbuf, 0, 1024);
}
}
else if(pid > 0){ }
else if(pid < 0){
perror("fork error.\n");
exit(EXIT_FAILURE);
}
} exit(0);
}
/*************************************************************************
> File Name: cli02.c
> Author:
> Mail:
> Created Time: 2015年11月22日 星期日 11时56分05秒
************************************************************************/ #include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <string.h> int main()
{ int sockfd, ret;
struct sockaddr_in seraddr;
seraddr.sin_family = AF_INET;
seraddr.sin_port = htons(8001);
seraddr.sin_addr.s_addr = inet_addr("127.0.0.1"); sockfd = socket(AF_INET, SOCK_STREAM, 0); ret = connect(sockfd, (struct sockaddr*)&seraddr, sizeof(seraddr));
if(ret == -1){
perror("bind error.\n");
exit(EXIT_FAILURE);
} char recvbuf[1024] = {0};
char sendbuff[1024] = {0}; while(fgets(sendbuff, 1024, stdin) != NULL){
write(sockfd, sendbuff, strlen(sendbuff));
read(sockfd, recvbuf, 1024);
printf("receive from %s:%d - ", inet_ntoa(seraddr.sin_addr), ntohs(seraddr.sin_port));
fputs(recvbuf, stdout);
memset(recvbuf, 0, 1024);
memset(sendbuff, 0, 1024);
} exit(0);
}

server:

client1:

client2:

client3:

server(此时三个客户端退出):

linux支持并发的服务器回射程序实例的更多相关文章

  1. unp TCP 客户端服务器回射程序中对SIGCHLD信号的处理

    第五章中,有一个例子模拟客户端并发的终止TCP连接,服务器捕捉并处理SIGCHLD信号并调用waitpid函数防止僵死进程的出现.信号处理函数中核心的一句是: , &statloc, WNOH ...

  2. Socket 入门- 客户端回射程序

    结果输出:------------------------------------------------------客户端:xx@xxxxxx:~/Public/C$ ./postBackCli.o ...

  3. TCP简单回射程序

    一.程序功能 (1)客户从标准输入读入一行文本行,并写给服务器: (2)服务器从网络输入读入这行文本,并回射给客户: (3)客户从网络输入读入这行回射文本,并显示在标准输出上 二.服务器程序 #inc ...

  4. 简单回射程序之处理accept返回EINTR错误的服务器程序版本

    #include <stdio.h> #include <stdlib.h> #include <time.h> #include <errno.h> ...

  5. python实现支持并发、断点续传的Ftp程序

    一.要求 1.用户md5认证 2.支持多用户同时登陆(并发) 3.进入用户的命令行模式,支持cd切换目录,ls查看目录子文件 4.执行命令(ipconfig) 5.传输文件: a.支持断点续传 b.传 ...

  6. 第五十六节,python实现支持并发、断点续传的Ftp程序

    一.要求 1.用户md5认证 2.支持多用户同时登陆(并发) 3.进入用户的命令行模式,支持cd切换目录,ls查看目录子文件 4.执行命令(ipconfig) 5.传输文件: a.支持断点续传 b.传 ...

  7. unix域数据报回射程序(不完整)

    一.服务器程序 int main(int argc, char **argv) { int sockfd; struct sockaddr_un servaddr, cliaddr; sockfd = ...

  8. unix域字节流回射程序

    一.服务端程序 #include <stdio.h> #include <errno.h> #include <stdlib.h> #include <uni ...

  9. 第十篇:基于TCP的一对回射客户/服务器程序及其运行过程分析( 上 )

    前言 本文将讲解一对经典的客户/服务器回射程序,感受网络编程的大致框架( 该程序稍作改装即可演变成各种提供其他服务的程序 ):同时,还将对其运行过程加以分析,观察程序背后协议的执行细节,学习调试网络程 ...

随机推荐

  1. [Google Guava] 6-字符串处理:分割,连接,填充

    原文链接 译文链接 译者:沈义扬,校对:丁一 连接器[Joiner] 用分隔符把字符串序列连接起来也可能会遇上不必要的麻烦.如果字符串序列中含有null,那连接操作会更难.Fluent风格的Joine ...

  2. java-十五周作业

    题目1:编写一个应用程序,输入用户名和密码,访问test数据库中t_login表(字段包括id.username.password),验证登录是否成功. 题目2:在上一题基础上,当登录成功后,将t_u ...

  3. 032_备份 MySQL 的 shell 脚本(mysqldump 版本)

    #!/bin/bash#定义变量 user(数据库用户名),passwd(数据库密码),date(备份的时间标签)#dbname(需要备份的数据库名称,根据实际需求需要修改该变量的值,默认备份 mys ...

  4. 修改quartus 配置rom时memory很小的问题。

    我用的是quartus ii 13版本的仿真软件,在做VGA实验时显示用到640*480的图片所以就需要307200*1bit的rom.但是坑爹的megawizard- plug-in-manager ...

  5. Linux下查看文件和文件夹大小 df,du命令

    转自 http://www.cnblogs.com/benio/archive/2010/10/13/1849946.html df可以查看一级文件夹大小.使用比例.档案系统及其挂入点,但对文件却无能 ...

  6. Integer int auto-boxing auto-unboxing ==

    Auto-boxing 自动装箱 Auto-unboxing 自动拆箱 == 相等 1.new出来的对象,除非遇到了拆箱的情况,肯定不相等. 因为new对象之前需要在JVM堆中提供空间,所以new出来 ...

  7. 内存管理3- @property 参数详解

    @property ----------------- Create two classes: Book & Student ------------------- book.m #impor ...

  8. 内存管理1 retain & release

    内存管理法则 1:谁创建谁释放alloc /new/ copy------>release/autorelease.一一对应,不是你创建的就不用你释放. 2:除了alloc /new/ copy ...

  9. Appium Inspector定位Webview/H5页面元素

    目录 操作步骤 Python操作该混合App代码 Appium在操作混合App或Android App的H5页面时, 常常需要定位H5页面中的元素, 传统方式是 翻墙 + 使用Chrome://ins ...

  10. codeforces#1215E. Marbles(状压dp)

    题目链接: http://codeforces.com/contest/1215/problem/E 题意: 至少多少次操作可以使得相同的数都是相邻的 每次操作可以交换两个相邻的数 数据范围: $1\ ...