网络编程day2.2~day3——TCP并发服务器

笔记脑图

作业:多进程多线程并发服务器实现一遍提交。

多进程

cpp 复制代码
#include <stdio.h>
#include <string.h>
#include <myhead.h>
#define IP "192.168.60.44"
#define PORT 6666
#define BACKLOG 20
void fun(int sss)
{
	if(sss==SIGCHLD)
	{
		while(waitpid(-1,NULL,0)>0);
	}
}
int main(int argc, const char *argv[])
{
	//
	if(signal(SIGCHLD,fun)==SIG_ERR)
	{
		perror("signal");
		return -1;
	}
	//
	int oldfd=socket(AF_INET,SOCK_STREAM,0);
	if(oldfd==-1)
	{
		perror("socket");
		return -1;
	}
	//
	int n=1;
	if(setsockopt(oldfd,SOL_SOCKET,SO_REUSEADDR,&n,sizeof(n))==-1)
	{
		perror("setsockopt");
		return -1;
	}
	printf("端口号快速复用成功\n");
	//
	struct sockaddr_in server={
		.sin_family=AF_INET,
		.sin_port=htons(PORT),
		.sin_addr.s_addr=inet_addr(IP),
	};
	if(bind(oldfd,(struct sockaddr *)&server,sizeof(server))==-1)
	{
		perror("bind");
		return -1;
	}
	//
	if(listen(oldfd,BACKLOG)==-1)
	{
		perror("listen");
		return -1;
	}

	struct sockaddr_in client;
	socklen_t client_len=sizeof(client);
	char buff[1024];
	while(1)
	{
		//
		int newfd=accept(oldfd,(struct sockaddr *)&client,&client_len);
		printf("%s发来连接请求\n",inet_ntoa(client.sin_addr));
		pid_t pid=fork();
		if(pid>0)
		{
			close(newfd);
		}
		else if(pid==0)
		{
			close(oldfd);
			while(1)
			{
				int len=recv(newfd,buff,sizeof(buff),0);
				if(len==0)
				{
					printf("%s客户端退出\n",inet_ntoa(client.sin_addr));
					break;
				}
				printf("客户端%s发来消息:%s\n",inet_ntoa(client.sin_addr),buff);
				strcat(buff,inet_ntoa(client.sin_addr));
				send(newfd,buff,sizeof(buff),0);
			}
			close(newfd);
			exit(0);
		}
		else
		{
			perror("fork");
			return -1;
		}
	}
	return 0;
}

多线程

cpp 复制代码
#include <stdio.h>
#include <string.h>
#include <myhead.h>
#define IP "192.168.60.44"
#define PORT 6666
#define BACKLOG 1024
typedef struct 
{
	struct sockaddr_in client;
	int newfd;
}stu;
void *fun(void *sss)
{
	int newfd=((stu *)sss)->newfd;
	struct sockaddr_in client=((stu *)sss)->client;
	printf("%s发来消息\n",inet_ntoa(client.sin_addr));

	char buff[1024];
	while(1)
	{
		int len=recv(newfd,buff,sizeof(buff),0);
		if(len==0)
		{
			printf("客户端退出\n");
			break;
		}
		printf("收到消息:%s\n",buff);
		strcat(buff,"1973");
		send(newfd,buff,sizeof(buff),0);
	}
	pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
	int oldfd=socket(AF_INET,SOCK_STREAM,0);
	if(oldfd==-1)
	{
		perror("socket");
		return -1;
	}
	//
	struct sockaddr_in server={
		.sin_family=AF_INET,
		.sin_port=htons(PORT),
		.sin_addr.s_addr=inet_addr(IP),
	};
	if(bind(oldfd,(struct sockaddr *)&server,sizeof(server))==-1)
	{
		perror("bind");
		return -1;
	}
	//
	if(listen(oldfd,BACKLOG)==-1)
	{
		perror("listen");
		return -1;
	}
	struct sockaddr_in client;
	socklen_t client_len=sizeof(client);
	while(1)
	{
		int newfd=accept(oldfd,(struct sockaddr *)&client,&client_len);
		
		stu a;
		a.newfd=newfd;
		a.client=client;

		pthread_t tid;
		tid=pthread_create(&tid,NULL,fun,&a);
		if(tid==-1)
		{
			perror("pthread_create");
			return -1;
		}
		pthread_detach(tid);
	}
	return 0;
}
相关推荐
拾光Ծ8 小时前
【Linux】Ext系列文件系统(一):初识文件系统
linux·运维·服务器·硬件架构·ext文件系统
天荒地老笑话么8 小时前
Vim核心快捷键与运维实战指南
运维·vim·excel
IT19958 小时前
Linux笔记-使用systemd管理进程
linux·运维·笔记
Web极客码8 小时前
WordPress 在哪里存储网站上的图片?
运维·服务器·wordpress
想逃离铁厂的老铁8 小时前
Day60 >> 94、城市间货物运输1️⃣ + 95、城市间货物运输 2️⃣ + 96、城市间货物运输 3️⃣
java·服务器·前端
杜子不疼.8 小时前
用Claude Code构建AI内容创作工作流:从灵感到发布的自动化实践
运维·人工智能·自动化
草莓熊Lotso8 小时前
从零手搓实现 Linux 简易 Shell:内建命令 + 环境变量 + 程序替换全解析
linux·运维·服务器·数据库·c++·人工智能
人工智能训练16 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
微露清风17 小时前
系统性学习Linux-第二讲-基础开发工具
linux·运维·学习
阳光九叶草LXGZXJ18 小时前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习