#include "head.h"
#define ERR_MSG(msg) do{fprintf(stderr,"line:%d",__LINE__);perror(msg);}while(0)
#define IP "192.168.250.100"
#define PORT 6666
int deal_cli_msg(int newfd,struct sockaddr_in cin);
//回收僵尸进程
void handler(int sig)
{
while(waitpid(-1,NULL,WNOHANG)>0);
}
int main(int argc,const char * argv[])
{
//捕获17号 SIGCHLD信号,回收僵尸进程
__sighandler_t s=signal(17,handler);
if(SIG_ERR==s)
{
ERR_MSG("signal");
return -1;
}
//创建流式套接字
int sfd=socket(AF_INET,SOCK_STREAM,0);
if(sfd<0)
{
ERR_MSG("socket");
return -1;
}
printf("sfd=%d\n",sfd);
//允许端口快速重用
int reuse=1;
if(setsockopt(sfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))<0)
{
ERR_MSG("setsockopt");
return -1;
}
printf("允许端口快速重用成功\n");
//填充地址信息结构体
struct sockaddr_in sin;
sin.sin_family =AF_INET;
sin.sin_port =htons(PORT);
sin.sin_addr.s_addr=inet_addr(IP);
//将ip和端口绑定到套接字上
if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0)
{
ERR_MSG("bind");
return -1;
}
printf("ip绑定套接字成功__%d__\n",__LINE__);
//将套接字设置为可监听状态
if(listen(sfd,128)<0)
{
ERR_MSG("listen");
return -1;
}
printf("将套接字设置为可监听状态成功__%d__\n",__LINE__);
//存储连接成功的客户端地址信息
struct sockaddr_in cin;
socklen_t addrlen =sizeof(cin);
int newfd=-1;
//用epoll来接收和发送
int epfd, i, fd, ret;
struct epoll_event event;
struct epoll_event revents[10];
char buf[128] = {0};
// 1.创建epoll
if ((epfd = epoll_create(10)) == -1)
PRINT_ERR("epoll create error");
for (i = 1; i < argc; i++)
{
if ((fd = open(argv[i], O_RDWR)) == -1)
PRINT_ERR("open file error");
event.events = EPOLLIN;
event.data.fd = fd;
// 2.向epoll中添加想要监听的事件
if (epoll_ctl(epfd, EPOLL_CTL_ADD, fd, &event))
PRINT_ERR("epoll ctl error");
}
while (1)
{
// 3.阻塞等待事件准备好
ret = epoll_wait(epfd, revents, 10, -1);
if (ret == -1)
{
PRINT_ERR("epoll wait error");
}
for (i = 0; i < ret; i++)
{
if (revents[i].events & EPOLLIN)
{
read(revents[i].data.fd, buf, sizeof(buf));
printf("fd = %d,buf = %s\n", revents[i].data.fd, buf);
}
}
}
//关闭进程的所有的文件描述符
for(i=0;i<getdtablesize();i++){
close(i);
}
return 0;
return 0;
}
epoll的tcp并发服务器
最新推荐文章于 2023-12-26 22:27:37 发布