实现并发服务器

该博客介绍了如何修改远程控制服务器代码以实现并发服务,允许服务器同时为多个用户提供服务。实验环境中使用Red Hat 9,并给出了server.c、tcpclient.c、tcpserver.c的代码示例。运行结果显示,通过netstat命令观察到8900端口有三个不同PID的进程,证明并发服务器已成功运行。同时,通过ps命令检查,发现程序能自动清除僵尸进程。
摘要由CSDN通过智能技术生成
实验要求

修改远程控制服务器代码,使得服务器同时能够向多个用户提供服务。消除僵尸进程,收回所有子进程资源。

实验环境

Red Hat 9

代码
server.c
#include<stdio.h>
#include<unistd.h>
#include<sys/socket.h>
#include<string.h>
#include<netdb.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#include<sys/socket.h>
#define PORT 8900
#define BUF_SIZE 2048

int execute(char* command,char* buf);

int main()
{
   
	int sockfd;
	struct sockaddr_in client;
	struct sockaddr_in server;
	char send_buf[BUF_SIZE];
	char recv_buf[BUF_SIZE];
	char cmd[2048];
	int sendnum;
	int recvnum;
	int length;
	int port;
	int connected;	//change

	memset(send_buf,0,2048);
	memset(recv_buf,0,2048);
	memset(cmd,0,2048);  //change
	port = PORT;
	
	if (-1==(sockfd=socket(AF_INET,SOCK_STREAM,0)))  //change
	{
   
		perror("generating socket error\n");
		exit(1);
	}

	memset(&server,0,sizeof(struct sockaddr_in));
	server.sin_family = AF_INET;
	server.sin_addr.s_addr = htonl(INADDR_ANY);
	server.sin_port = htons(port);

	if (-1==bind(sockfd,(struct sockaddr*)&server,sizeof(struct sockaddr)))
	{
   
		perror("binding error\n");
		close(sockfd);
		exit(1);
	}

	if(-1==listen(sockfd,10))
	{
   
		perror("listen socket error\n");
		close(sockfd);
		return -1;
	}
	
	length = sizeof(struct sockaddr_in);

	while(1)
	{
   
		memset(recv_buf,0,2048);
		memset(send_buf,0,2048);
		if(-1==(connected=accept(sockfd,(struct sockaddr*)&client,&length)))
		{
   
			perror("three shakehands error\n");
			close(sockfd);
			return -1;
		}
		//change///
		int pid = fork();
		if((pid=fork())<0)
		{
   
			printf("fork failed\n");
			_exit(1);
		}
		else if(pid == 0)
		{
   
			//close(connected);
			process(connected, client);
		}
		else
		{
   
			close(connected);
			continue;
		}
		close(connected);
	}
	close(sockfd);
	exit(1);
}

int process(int connected, struct sockaddr_in client)
{
   
	char sendbuf[BUF_SIZE];
	char recvbuf[BUF_SIZE];
	int sendnum = 0;
	int recvnum = 0;
	int cnt;
	int n, fd[
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值