Unverified Commit 1a3cb1e7 authored by Ge Jun's avatar Ge Jun Committed by GitHub

Merge pull request #391 from yjhjstz/feature-reuse-port

support for SO_REUSEPORT socket option
parents 80e90599 45ba11af
...@@ -23,12 +23,19 @@ ...@@ -23,12 +23,19 @@
#include <string.h> // strcpy #include <string.h> // strcpy
#include <stdio.h> // snprintf #include <stdio.h> // snprintf
#include <stdlib.h> // strtol #include <stdlib.h> // strtol
#include <gflags/gflags.h>
#include "butil/fd_guard.h" // fd_guard #include "butil/fd_guard.h" // fd_guard
#include "butil/endpoint.h" // ip_t #include "butil/endpoint.h" // ip_t
#include "butil/logging.h" #include "butil/logging.h"
#include "butil/memory/singleton_on_pthread_once.h" #include "butil/memory/singleton_on_pthread_once.h"
#include "butil/strings/string_piece.h" #include "butil/strings/string_piece.h"
#ifndef SO_REUSEPORT
#define SO_REUSEPORT 15
#endif
//This option is supported since Linux 3.9.
DEFINE_bool(reuse_port, false, "turn on support for SO_REUSEPORT socket option.");
__BEGIN_DECLS __BEGIN_DECLS
int BAIDU_WEAK bthread_connect( int BAIDU_WEAK bthread_connect(
int sockfd, const struct sockaddr *serv_addr, socklen_t addrlen) { int sockfd, const struct sockaddr *serv_addr, socklen_t addrlen) {
...@@ -313,6 +320,15 @@ int tcp_listen(EndPoint point, bool reuse_addr) { ...@@ -313,6 +320,15 @@ int tcp_listen(EndPoint point, bool reuse_addr) {
return -1; return -1;
} }
} }
if (FLAGS_reuse_port) {
const int on = 1;
if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEPORT,
&on, sizeof(on)) != 0) {
LOG(WARNING) << "Fail to setsockopt SO_REUSEPORT of sockfd=" << sockfd;
}
}
struct sockaddr_in serv_addr; struct sockaddr_in serv_addr;
bzero((char*)&serv_addr, sizeof(serv_addr)); bzero((char*)&serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET; serv_addr.sin_family = AF_INET;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment