linux并发服务器(1)

开学闲来无事,研究了下并发服务器,写了个初步的版本,没什么功能,以后会不定期填坑

使用标准的多线程处理来实现并发

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#include<pthread.h>
#define DEFAULT_PORT 8000
#define MAXLINE 65
#define MAXCONNECT 2
struct ADDR//用来传递给新线程的数据
{
int connectfd;
pthread_t tid;
struct sockaddr_in client;
int* p_num;
};
void* event1(void* addr)
{
char buff[MAXLINE];
while(1)
{
if (!recv(((struct ADDR*)addr)->connectfd, buff, MAXLINE-1, 0))
{
printf("Client %s dies out.\n",inet_ntoa(((struct ADDR*)addr)->client.sin_addr));
break;
};
if(send(((struct ADDR*)addr)->connectfd, "Y",1,0) == -1)
{
perror("send error");
break;
}
if(!strcmp((const char *)buff,"exit\n"))
{
printf("Server exit.");
exit(0);
}
printf("%s: %s",inet_ntoa(((struct ADDR*)addr)->client.sin_addr), buff);
memset(buff,0,MAXLINE);
buff[MAXLINE-1]='\0';
}

close(((struct ADDR*)addr)->connectfd);
*((struct ADDR*)addr)->p_num--;
free(addr);
pthread_exit(NULL);
}

int main(int argc, char** argv)

{
int socket_fd,connect_fd,connect_num;
struct sockaddr_in servaddr,client;
/*待用
char buff[64];
*/
int n;
pthread_t tid;
struct ADDR* addr;
//初始化Socket
if( (socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1 ){
printf("Create socket error: %s(errno: %d)\n",strerror(errno),errno);
exit(0);
}
//初始化
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//IP地址设置成INADDR_ANY,让系统自动获取本机的IP地址。
servaddr.sin_port = htons(DEFAULT_PORT);//设置的端口为DEFAULT_PORT
//将本地地址绑定到所创建的套接字上
if( bind(socket_fd, (struct sockaddr*)&servaddr, sizeof(servaddr)) == -1)
{
printf("bind socket error: %s(errno: %d)\n",strerror(errno),errno);
exit(0);
}
//开始监听是否有客户端连接
if( listen(socket_fd, 10) == -1){
printf("listen socket error: %s(errno: %d)\n",strerror(errno),errno);
exit(0);
}
printf("************ waiting ************\n");
while(1)
{
int addrlen=0;
if(!connect_num>=MAXCONNECT)
{
if( (connect_fd = accept(socket_fd, (struct sockaddr*)&client, &addrlen)) == -1)
{
printf("accept socket error: %s(errno: %d)",strerror(errno),errno);
continue;
}
if(!fork())
{
printf("%s is online\n",inet_ntoa(client.sin_addr));
exit(0);
}
connect_num++;
addr=(struct ADDR*)malloc(sizeof(struct ADDR));
addr->connectfd=connect_fd;
memcpy((void*)&addr->client,&client,sizeof(client));
addr->p_num=&connect_num;
if(pthread_create(&tid,NULL,event1,(void*) addr))
{
perror("Pthread error.");
exit(1);
}
}
else
{
sleep(100);
}
}
close(socket_fd);
printf("Program Exit.\n");
exit(0);
}


在此感谢http://blog.csdn.net/hguisu/article/details/7445768/博主的贴子,源码中一部分取自原文章。特此声明

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值