socket 并发服务器 代码案例 (多进程模式)
来源:互联网 发布:淘宝网安踏春秋长裤 编辑:程序博客网 时间:2024/06/02 02:36
用Socket技术,完成一个简单的并发服务器,要求用fork()创建子进程来并发处理实现多进程并发,在接收到请求时,fork个进程,对父进程则关闭连接Socket,而子进程则关闭监听socket,每一个新的accept请求都由子进程来执行,而由父进程继续listen。
server.c 端
#include<stdio.h>
#include<stdlib.h>#include<strings.h>
#include<string.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#define PORT 1234
#define BACKLOG 2 //numbers of allowed connections
#define MAXDATASIZE 1000
void process_cli(int connectfd,struct sockaddr_in client);
void main()
{
int listenfd,connectfd;
pid_t pid;
struct sockaddr_in server;
struct sockaddr_in client;
int sin_size;
//创建socket关键字
listenfd = socket(AF_INET,SOCK_STREAM,0);
if(listenfd == -1)
{
perror("creating socket failed");
exit(1);
}
int opt = SO_REUSEADDR;
setsockopt(listenfd,SOL_SOCKET,SO_REUSEADDR,&opt,sizeof(opt));
bzero(&server,sizeof(server));
server.sin_family = AF_INET;
server.sin_port = htons(PORT);
server.sin_addr.s_addr = htonl(INADDR_ANY);
//绑定端口和IP地址
if((bind(listenfd,(struct sockaddr *)&server,sizeof(struct sockaddr)))== -1)
{
perror("bind error\n");
exit(1);
}
//监听客户端
if(listen(listenfd,BACKLOG)==-1)
{
perror("listen error\n");
exit(1);
}
sin_size = sizeof(struct sockaddr_in);
while(1)
{
//等待接收来自客户端的信息
if((connectfd=accept(listenfd,(struct sockaddr*)&client,&sin_size))==-1)
{
perror("accept failed\n");
exit(1);
}
//创建进程
if((pid=fork())>0)
{
close(connectfd);
continue;
}
else if(pid ==0)
{
close(listenfd);
process_cli(connectfd,client);
exit(1);
}
else
{
printf("fork error\n");
exit(0);
}
}
close(listenfd);
}
void process_cli(int connectfd,struct sockaddr_in client)
{
int num;
char recvbuf[MAXDATASIZE],sendbuf[MAXDATASIZE],cli_name[MAXDATASIZE];
printf("you got a connectfd from %s\n.",inet_ntoa(client.sin_addr));
send(connectfd,"welcome to my server.\n",22,0);
num=recv(connectfd,cli_name,MAXDATASIZE,0);
if(num == 0)
{
close(connectfd);
printf("client connects failed\n");
return ;
}
cli_name[num-1]='\0';
printf("client'name is %s\n",cli_name);
while(num = recv(connectfd,recvbuf,MAXDATASIZE,0))
{
int i=0;
recvbuf[num]='\0';
printf("recevied client(%s)message:%s\n",cli_name,recvbuf);
for(i=0;i<num;i++)
{
sendbuf[i] = recvbuf[num-i-2];
}
sendbuf[num-1]='\0';
send(connectfd,sendbuf,strlen(sendbuf),0);
}
close(connectfd);
}
client.c 端
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<netdb.h>
#define PORT 1234
#define MAXDATASIZE 1000
int main(int argc,char *argv[])
{
int fd,numbytes;
char buf[MAXDATASIZE];
struct hostent *he;
struct sockaddr_in server;
int i=1;
if((he=gethostbyname(argv[1]))==NULL)
{
perror("gethostbyname error");
exit(1);
}
if((fd=socket(AF_INET,SOCK_STREAM,0))==-1)
{
perror("socket failed");
exit(1);
}
bzero(&server,sizeof(server));
server.sin_family =AF_INET;
server.sin_port =htons(PORT);
server.sin_addr =*((struct in_addr*)he->h_addr);
if(connect(fd,(struct sockaddr*)&server,sizeof(struct sockaddr))==-1)
{
perror("bind error");
exit(1);
}
if((numbytes=recv(fd,buf,MAXDATASIZE,0))==-1)
{
perror("recv error");
exit(1);
}
buf[numbytes]='\0';
printf("%s\n",buf);
printf("input your name:");
scanf("%s",buf);
if((numbytes=send(fd,buf,strlen(buf),0))==-1)
{
perror("send failed");
exit(1);
}
while(i)
{
printf("input me message(max char:%d):",MAXDATASIZE);
scanf("%s",buf);
if(strlen(buf)<1)
{
i=0;
}
if((numbytes=send(fd,buf,strlen(buf),0))==-1)
{
perror("send failed");
exit(1);
}
if((numbytes=recv(fd,buf,MAXDATASIZE,0))==-1)
{
perror("recv error");
exit(1);
}
buf[numbytes]='\0';
printf("server message:%s\n",buf);
printf("\n");
}
close(fd);
return 0;
}
运行结果可以多客户端对应一个服务器端。
- socket 并发服务器 代码案例 (多进程模式)
- linux socket多进程并发服务器
- 多进程、多线程并发服务器代码
- socket 并发服务器 多线程模式
- C-socket编程-多进程版并发服务器
- 多进程并发项目案例
- 多进程并发服务器
- 并发服务器---多进程
- 高性能高并发服务器架构浅析--多进程模式
- 35-并发服务器(多进程)
- socket并发服务器(frok)
- 37-多进程并发服务器(并发测试)
- unix环境IPC通信之socket(三),tcp采用并发服务器编程实例,多进程方式
- linux局域网通讯源码(服务器多路复用和客户端多进程模式)(socket)服务器端
- linux局域网通讯源码(服务器多路复用和客户端多进程模式)(socket)客户端
- 多进程并发服务器编程
- 多进程并发服务器编程
- tcp多进程并发服务器
- 关于listview中是用多个布局 并使用holderView 缓存机制的问题
- 针对json的查询--alibaba的开源项目jsonq
- Spring源码分析的几篇博客
- 解决NPM使用下载慢或者无法下载的问题error
- Tablayout的使用
- socket 并发服务器 代码案例 (多进程模式)
- spring boot学习(六)---表单验证
- 进程通信之无名pipe
- 第78讲 面向对象编程综合练习
- 基于nginx的中间件架构(1)环境准备
- __bridge 显式转换 id和void *
- bzoj 5047 空间传送装置 最短路
- 在Mac中配置tomcat服务器教程(超详细配图)以及其配置简单原理
- Codeforces 873B Balanced Substring(利用前缀和找和为0的子串)