青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

   C++ 技術(shù)中心

   :: 首頁(yè) :: 聯(lián)系 ::  :: 管理
  160 Posts :: 0 Stories :: 87 Comments :: 0 Trackbacks

公告

鄭重聲明:本BLOG所發(fā)表的原創(chuàng)文章,作者保留一切權(quán)利。必須經(jīng)過(guò)作者本人同意后方可轉(zhuǎn)載,并注名作者(天空)和出處(CppBlog.com)。作者Email:coder@luckcoder.com

留言簿(27)

搜索

  •  

最新隨筆

最新評(píng)論

評(píng)論排行榜

epoll是linux下高并發(fā)服務(wù)器的完美方案,因?yàn)槭腔谑录|發(fā)的,所以比select快的不只是一個(gè)數(shù)量級(jí)。
單線程epoll,觸發(fā)量可達(dá)到15000,但是加上業(yè)務(wù)后,因?yàn)榇蠖鄶?shù)業(yè)務(wù)都與數(shù)據(jù)庫(kù)打交道,所以就會(huì)存在阻塞的情況,這個(gè)時(shí)候就必須用多線程來(lái)提速。
業(yè)務(wù)在線程池內(nèi),這里要加鎖才行。測(cè)試結(jié)果2300個(gè)/s
測(cè)試工具:stressmark
因?yàn)榧恿诉m用與ab的代碼,所以也可以適用ab進(jìn)行壓力測(cè)試。
char buf[1000] = {0};
sprintf(buf,"HTTP/1.0 200 OK\r\nContent-type: text/plain\r\n\r\n%s","Hello world!\n");
send(socketfd,buf, strlen(buf),0);
#include <iostream>
#include 
<sys/socket.h>
#include 
<sys/epoll.h>
#include 
<netinet/in.h>
#include 
<arpa/inet.h>
#include 
<fcntl.h>
#include 
<unistd.h>
#include 
<stdio.h>
#include 
<pthread.h>

#include 
<errno.h>
 
#define MAXLINE 10
#define OPEN_MAX 100
#define LISTENQ 20
#define SERV_PORT 8006
#define INFTIM 1000
 
//線程池任務(wù)隊(duì)列結(jié)構(gòu)體

struct task{
  
int fd; //需要讀寫(xiě)的文件描述符

  
struct task *next; //下一個(gè)任務(wù)

}
;
 
//用于讀寫(xiě)兩個(gè)的兩個(gè)方面?zhèn)鬟f參數(shù)

struct user_data{
  
int fd;
  unsigned 
int n_size;
  
char line[MAXLINE];
}
;
 
//線程的任務(wù)函數(shù)

void * readtask(void *args);
void * writetask(void *args);
 
 
//聲明epoll_event結(jié)構(gòu)體的變量,ev用于注冊(cè)事件,數(shù)組用于回傳要處理的事件

struct epoll_event ev,events[20];
int epfd;
pthread_mutex_t mutex;
pthread_cond_t cond1;
struct task *readhead=NULL,*readtail=NULL,*writehead=NULL;
 
void setnonblocking(int sock)
{
     
int opts;
     opts
=fcntl(sock,F_GETFL);
     
if(opts<0)
     
{
          perror(
"fcntl(sock,GETFL)");
          exit(
1);
     }

    opts 
= opts|O_NONBLOCK;
     
if(fcntl(sock,F_SETFL,opts)<0)
     
{
          perror(
"fcntl(sock,SETFL,opts)");
          exit(
1);
     }
 
}

 
int main()
{
     
int i, maxi, listenfd, connfd, sockfd,nfds;
     pthread_t tid1,tid2;
    
     
struct task *new_task=NULL;
     
struct user_data *rdata=NULL;
     socklen_t clilen;
    
     pthread_mutex_init(
&mutex,NULL);
     pthread_cond_init(
&cond1,NULL);
     
//初始化用于讀線程池的線程

     pthread_create(
&tid1,NULL,readtask,NULL);
     pthread_create(
&tid2,NULL,readtask,NULL);
    
     
//生成用于處理accept的epoll專(zhuān)用的文件描述符 

     epfd
=epoll_create(256);
 
     
struct sockaddr_in clientaddr;
     
struct sockaddr_in serveraddr;
     listenfd 
= socket(AF_INET, SOCK_STREAM, 0);
     
//把socket設(shè)置為非阻塞方式

     setnonblocking(listenfd);
     
//設(shè)置與要處理的事件相關(guān)的文件描述符

     ev.data.fd
=listenfd;
     
//設(shè)置要處理的事件類(lèi)型

     ev.events
=EPOLLIN|EPOLLET;
     
//注冊(cè)epoll事件

     epoll_ctl(epfd,EPOLL_CTL_ADD,listenfd,
&ev);
    
     bzero(
&serveraddr, sizeof(serveraddr)); 
     serveraddr.sin_family 
= AF_INET; 
     serveraddr.sin_port
=htons(SERV_PORT);
     serveraddr.sin_addr.s_addr 
= INADDR_ANY;
     bind(listenfd,(sockaddr 
*)&serveraddr, sizeof(serveraddr));
     listen(listenfd, LISTENQ);
    
     maxi 
= 0;
     
for ( ; ; ) {
          
//等待epoll事件的發(fā)生

          nfds
=epoll_wait(epfd,events,20,500);
          
//處理所發(fā)生的所有事件 

        
for(i=0;i<nfds;++i)
        
{
               
if(events[i].data.fd==listenfd)
               
{
                   
                    connfd 
= accept(listenfd,(sockaddr *)&clientaddr, &clilen);
                    
if(connfd<0){
                      perror(
"connfd<0");
                      exit(
1);
                   }

                    setnonblocking(connfd);
                   
                    
char *str = inet_ntoa(clientaddr.sin_addr);
                    
//std::cout<<"connec_ from >>"<<str<<std::endl;

                    
//設(shè)置用于讀操作的文件描述符

                    ev.data.fd
=connfd;
                    
//設(shè)置用于注測(cè)的讀操作事件

                 ev.events
=EPOLLIN|EPOLLET;
                    
//注冊(cè)ev

                 epoll_ctl(epfd,EPOLL_CTL_ADD,connfd,
&ev);
               }

            
else if(events[i].events&EPOLLIN)
            
{
                    
//printf("reading!/n"); 

                    
if ( (sockfd = events[i].data.fd) < 0continue;
                    new_task
=new task();
                    new_task
->fd=sockfd;
                    new_task
->next=NULL;
                    
//添加新的讀任務(wù)

                    pthread_mutex_lock(
&mutex);
                    
if(readhead==NULL)
                    
{
                      readhead
=new_task;
                      readtail
=new_task;
                    }
 
                    
else
                    

                     readtail
->next=new_task;
                      readtail
=new_task;
                    }
 
                   
//喚醒所有等待cond1條件的線程

                    pthread_cond_broadcast(
&cond1);
                    pthread_mutex_unlock(
&mutex); 
              }

               
else if(events[i].events&EPOLLOUT)
               

                 
/*
              rdata=(struct user_data *)events[i].data.ptr;
                 sockfd = rdata->fd;
                 write(sockfd, rdata->line, rdata->n_size);
                 delete rdata;
                 //設(shè)置用于讀操作的文件描述符
                 ev.data.fd=sockfd;
                 //設(shè)置用于注測(cè)的讀操作事件
               ev.events=EPOLLIN|EPOLLET;
                 //修改sockfd上要處理的事件為EPOLIN
               epoll_ctl(epfd,EPOLL_CTL_MOD,sockfd,&ev);
             
*/

               }

                             
          }

         
     }

}


static int count111 = 0;
static time_t oldtime = 0, nowtime = 0;
void * readtask(void *args)
{
   
   
int fd=-1;
   unsigned 
int n;
   
//用于把讀出來(lái)的數(shù)據(jù)傳遞出去

   
struct user_data *data = NULL;
   
while(1){
        
        pthread_mutex_lock(
&mutex);
        
//等待到任務(wù)隊(duì)列不為空

        
while(readhead==NULL)
             pthread_cond_wait(
&cond1,&mutex);
        
        fd
=readhead->fd;
        
//從任務(wù)隊(duì)列取出一個(gè)讀任務(wù)

        
struct task *tmp=readhead;
        readhead 
= readhead->next;
        delete tmp;
        pthread_mutex_unlock(
&mutex);
        data 
= new user_data();
        data
->fd=fd;
        

        
char recvBuf[1024= {0}
        
int ret = 999;
        
int rs = 1;

        
while(rs)
        
{
            ret 
= recv(fd,recvBuf,1024,0);// 接受客戶(hù)端消息

            
if(ret < 0)
            
{
                
//由于是非阻塞的模式,所以當(dāng)errno為EAGAIN時(shí),表示當(dāng)前緩沖區(qū)已無(wú)數(shù)據(jù)可//讀在這里就當(dāng)作是該次事件已處理過(guò)。

                
if(errno == EAGAIN)
                
{
                    printf(
"EAGAIN\n");
                    
break;
                }

                
else{
                    printf(
"recv error!\n");
        
                    close(fd);
                    
break;
                }

            }

            
else if(ret == 0)
            
{
                
// 這里表示對(duì)端的socket已正常關(guān)閉. 

                rs 
= 0;
            }

            
if(ret == sizeof(recvBuf))
                rs 
= 1// 需要再次讀取

            
else
                rs 
= 0;
        }

        
if(ret>0){

        
//-------------------------------------------------------------------------------


            data
->n_size=n;


            count111 
++;

            
struct tm *today;
            time_t ltime;
            time( 
&nowtime );

            
if(nowtime != oldtime){
                printf(
"%d\n", count111);
                oldtime 
= nowtime;
                count111 
= 0;
            }


            
char buf[1000= {0};
            sprintf(buf,
"HTTP/1.0 200 OK\r\nContent-type: text/plain\r\n\r\n%s","Hello world!\n");
            send(fd,buf,strlen(buf),
0);
            close(fd);


       }

   }

}



posted on 2013-11-26 15:49 C++技術(shù)中心 閱讀(5789) 評(píng)論(2)  編輯 收藏 引用 所屬分類(lèi): Linux 編程

Feedback

# re: 高并發(fā)的epoll+線程池,業(yè)務(wù)在線程池內(nèi)[未登錄](méi) 2013-11-27 12:05 春秋十二月
這個(gè)例子實(shí)現(xiàn)描述的epoll+theadpool方案不太好
1)fd讀事件用加鎖的queue通知,造成epoll thead和read thread間的同步,及many read threads間的鎖競(jìng)爭(zhēng)
2)fd寫(xiě)事件沒(méi)有處理,后面的send(fd,buf,strlen(buf),0)也沒(méi)處理好  回復(fù)  更多評(píng)論
  

# re: 高并發(fā)的epoll+線程池,業(yè)務(wù)在線程池內(nèi) 2013-11-27 18:34 老爺
大哥, 你可以封裝下啊, 你不覺(jué)得看起來(lái)挺費(fèi)勁嗎? 看起來(lái)費(fèi)勁, 用起來(lái)就更不用說(shuō)了~  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产精品成人综合色在线婷婷| 亚洲精选在线观看| 亚洲欧美另类在线观看| 欧美国产视频在线观看| 久久国产免费| 欧美国产精品日韩| 亚洲激情视频网| 激情婷婷亚洲| 香蕉久久夜色精品| 午夜久久美女| 久久精品国产综合精品| 久久久久成人精品免费播放动漫| 久久精品国产一区二区三区| 久久这里只有| 亚洲精品久久| 亚洲视频碰碰| 久久精品国产亚洲一区二区三区| 美国三级日本三级久久99| 欧美激情第1页| 国产精品尤物福利片在线观看| 国产一区二区三区日韩| 亚洲精品视频在线看| 欧美亚洲视频在线观看| 欧美国产精品中文字幕| 一区二区三区四区国产精品| 久久精品99国产精品日本| 欧美激情第六页| 国产日本欧美在线观看| 亚洲精品亚洲人成人网| 久久精品中文| 一本色道久久99精品综合| 欧美一区1区三区3区公司| 欧美久久久久久久久| 国产在线精品二区| 亚洲在线1234| 亚洲国产精品久久久久秋霞不卡 | 久久久久9999亚洲精品| 欧美成人午夜剧场免费观看| 国产区日韩欧美| 一区二区欧美日韩| 欧美多人爱爱视频网站| 欧美在线亚洲在线| 国产乱理伦片在线观看夜一区| 亚洲精品字幕| 欧美激情精品久久久六区热门| 欧美一级黄色录像| 国产麻豆91精品| 亚洲一区二区在线免费观看| 亚洲激情综合| 欧美fxxxxxx另类| 伊大人香蕉综合8在线视| 久久精品国语| 亚洲午夜女主播在线直播| 欧美人与禽猛交乱配| 亚洲精品影视| 欧美激情亚洲国产| 欧美α欧美αv大片| 亚洲二区在线视频| 一区在线电影| 久久久一本精品99久久精品66| 亚洲精品一区二区三区99| 久久在线视频| **欧美日韩vr在线| 免费在线亚洲| 美女黄毛**国产精品啪啪| 在线视频成人| 亚洲二区精品| 欧美另类高清视频在线| 亚洲精品一级| 亚洲日韩第九十九页| 欧美日韩国产专区| 亚洲综合色噜噜狠狠| 亚洲一级免费视频| 国产自产女人91一区在线观看| 久久久999精品| 久久看片网站| 亚洲美女av在线播放| 9色porny自拍视频一区二区| 欧美视频久久| 久久av一区二区三区漫画| 久久99伊人| 亚洲精选中文字幕| 亚洲一区精品电影| 在线看一区二区| 亚洲美女黄色片| 国产欧美 在线欧美| 欧美成人官网二区| 欧美日韩在线观看一区二区| 欧美一区国产在线| 美女视频一区免费观看| 亚洲午夜激情网页| 久久精品99国产精品| 亚洲精品一区在线观看香蕉| 亚洲在线视频一区| 亚洲激情在线| 亚洲综合精品四区| 亚洲精品国产欧美| 性色av一区二区三区| 亚洲人午夜精品免费| 亚洲欧美在线一区| 亚洲日本成人| 香蕉亚洲视频| 一区二区免费看| 久久久精品久久久久| 亚洲一区成人| 另类激情亚洲| 久久久久久久999精品视频| 欧美精品在线观看播放| 久久久一二三| 国产精品久久久久久久久免费| 欧美a级大片| 国产噜噜噜噜噜久久久久久久久| 亚洲国产你懂的| 悠悠资源网亚洲青| 亚洲综合久久久久| 亚洲一区二区三区777| 免费在线观看日韩欧美| 久久久亚洲国产天美传媒修理工| 国产精品黄视频| 亚洲精品影视| 日韩一级精品| 欧美激情一区二区久久久| 欧美日韩麻豆| 亚洲欧美日本国产专区一区| 国产色爱av资源综合区| 亚洲国产精品激情在线观看| 国产色产综合产在线视频| 中文久久乱码一区二区| 亚洲激情国产| 久久亚洲综合色| 久久视频在线视频| 国产日韩精品久久| 亚洲特级片在线| 亚洲天堂成人在线观看| 免费日韩一区二区| 欧美成黄导航| 一区二区视频免费完整版观看| 性欧美xxxx大乳国产app| 久久se精品一区精品二区| 国产精品欧美激情| 亚洲砖区区免费| 久久国产精品黑丝| 国产一区二区三区直播精品电影| 亚洲欧美日韩一区二区在线| 小黄鸭精品aⅴ导航网站入口| 国产精品日韩在线| 校园春色国产精品| 老司机成人网| 亚洲国产日韩在线| 欧美—级高清免费播放| 亚洲欧洲一区二区三区| 亚洲视频 欧洲视频| 国产精品videosex极品| 亚洲在线一区二区| 久久男女视频| 亚洲韩国精品一区| 欧美日韩不卡合集视频| 亚洲天堂av综合网| 久久精品亚洲热| 亚洲国产日韩在线一区模特| 免费欧美视频| 99这里只有精品| 亚洲欧美一区二区精品久久久| 国产精品久久婷婷六月丁香| 亚洲一区日本| 久久夜色精品国产欧美乱| 亚洲精品久久久久| 国产精品久久久久一区| 欧美在线一级视频| 亚洲国产精品久久久久婷婷老年| 亚洲四色影视在线观看| 国产真实乱偷精品视频免| 模特精品在线| 亚洲一二三四久久| 欧美韩日一区二区| 亚洲影视在线播放| 尤物精品在线| 国产精品久久久久久久久久三级| 久久久国产视频91| 一区二区三区精品视频在线观看| 久久精品72免费观看| 亚洲精品在线一区二区| 国产亚洲人成a一在线v站| 欧美福利一区二区| 欧美伊人影院| 亚洲蜜桃精久久久久久久| 久久久久国产精品一区二区| 99精品免费视频| 国产一区白浆| 欧美午夜宅男影院| 欧美aⅴ99久久黑人专区| 欧美日韩在线第一页| 欧美黄在线观看| 亚洲一区二区在线免费观看视频 | 欧美中文字幕在线观看| 亚洲精品一区二区在线| 美女久久网站| 久久精品国产99国产精品| 亚洲视频在线播放| 亚洲精品在线一区二区|