Changeset 86c12d65


Ignore:
Timestamp:
Jun 6, 2022, 9:04:31 PM (2 years ago)
Author:
Thierry Delisle <tdelisle@…>
Branches:
ADT, ast-experimental, master, pthread-emulation, qualifiedEnum
Children:
b6e0b61
Parents:
ac1aba4b
Message:

Checkpoint of the broken version of reuseport

Location:
benchmark/io/http
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • benchmark/io/http/main.cfa

    rac1aba4b r86c12d65  
    234234        int addrlen = prepaddr(address);
    235235
    236         int server_fd = listener(address, addrlen);
     236        int server_fd;
     237        if(!options.socket.manyreuse) {
     238                server_fd = listener(address, addrlen);
     239        }
    237240
    238241        //===================
     
    271274                                                workers[i].pipe[0] = fds[pipe_off + (i * 2) + 0];
    272275                                                workers[i].pipe[1] = fds[pipe_off + (i * 2) + 1];
    273                                                 workers[i].sockfd  = server_fd;
     276                                                workers[i].sockfd  = options.socket.manyreuse ?  listener(address, addrlen) : server_fd;
    274277                                                workers[i].addr    = (struct sockaddr *)&address;
    275278                                                workers[i].addrlen = (socklen_t*)&addrlen;
     
    311314
    312315                                sout | "Shutting down socket..." | nonl; flush( sout );
    313                                 int ret = shutdown( server_fd, SHUT_RD );
    314                                 if( ret < 0 ) {
    315                                         abort( "shutdown error: (%d) %s\n", (int)errno, strerror(errno) );
     316                                if(options.socket.manyreuse) {
     317                                        for(i; options.clopts.nworkers) {
     318                                                ret = shutdown( workers[i].sockfd, SHUT_RD );
     319                                                if(ret < 0) abort( "close socket %d error: (%d) %s\n", i, (int)errno, strerror(errno) );
     320                                        }
     321                                }
     322                                else {
     323                                        ret = shutdown( server_fd, SHUT_RD );
     324                                        if( ret < 0 ) {
     325                                                abort( "shutdown error: (%d) %s\n", (int)errno, strerror(errno) );
     326                                        }
    316327                                }
    317328                                sout | "done";
     
    320331                                // Close Socket
    321332                                sout | "Closing Socket..." | nonl; flush( sout );
    322                                 ret = close( server_fd );
    323                                 if(ret < 0) {
    324                                         abort( "close socket error: (%d) %s\n", (int)errno, strerror(errno) );
     333                                if(options.socket.manyreuse) {
     334                                        for(i; options.clopts.nworkers) {
     335                                                ret = close(workers[i].sockfd);
     336                                                if(ret < 0) abort( "close socket %d error: (%d) %s\n", i, (int)errno, strerror(errno) );
     337                                        }
     338                                }
     339                                else {
     340                                        ret = close( server_fd );
     341                                        if(ret < 0) {
     342                                                abort( "close socket error: (%d) %s\n", (int)errno, strerror(errno) );
     343                                        }
    325344                                }
    326345                                sout | "done";
  • benchmark/io/http/options.cfa

    rac1aba4b r86c12d65  
    3535
    3636        { // socket
    37                 8080, // port
    38                 10,   // backlog
    39                 1024  // buflen
     37                8080,  // port
     38                10,    // backlog
     39                1024,  // buflen
     40                false, // onereuse
     41                false  // manyreuse
    4042        },
    4143
     
    7072                {'\0', "shell",          "Disable interactive mode", options.interactive, parse_setfalse},
    7173                {'\0', "accept-backlog", "Maximum number of pending accepts", options.socket.backlog},
     74                {'\0', "reuseport-one",  "Create a single listen socket with SO_REUSEPORT", options.socket.onereuse, parse_settrue},
     75                {'\0', "reuseport",      "Use many listen sockets with SO_REUSEPORT", options.socket.manyreuse, parse_settrue},
    7276                {'\0', "request_len",    "Maximum number of bytes in the http request, requests with more data will be answered with Http Code 414", options.socket.buflen},
    7377                {'\0', "seed",           "seed to use for hashing", options.file_cache.hash_seed },
  • benchmark/io/http/options.hfa

    rac1aba4b r86c12d65  
    2727                int backlog;
    2828                int buflen;
     29                bool onereuse;
     30                bool manyreuse;
    2931        } socket;
    3032
  • benchmark/io/http/socket.cfa

    rac1aba4b r86c12d65  
    3131        }
    3232
    33         int value = 1;
    34         if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &value, sizeof(int)) < 0)
    35                 abort( "setsockopt error: (%d) %s\n", (int)errno, strerror(errno) );
     33        if(options.socket.onereuse || options.socket.manyreuse) {
     34                int value = 1;
     35                // if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (const void*)&on, sizeof(on)))
     36                //      abort( "setsockopt SO_REUSEADDR error: (%d) %s\n", (int)errno, strerror(errno) );
     37                if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT, &value, sizeof(int)) < 0)
     38                        abort( "setsockopt SO_REUSEPORT error: (%d) %s\n", (int)errno, strerror(errno) );
     39        }
    3640
    3741        int ret = 0;
  • benchmark/io/http/worker.cfa

    rac1aba4b r86c12d65  
    4343        /* paranoid */ assert( this.pipe[0] != -1 );
    4444        /* paranoid */ assert( this.pipe[1] != -1 );
     45
     46        const bool reuse = options.socket.manyreuse;
    4547
    4648        CONNECTION:
Note: See TracChangeset for help on using the changeset viewer.