threadsafe port picker for remote bazel

pull/16489/head
Jan Tattermusch 6 years ago
parent 9e735f40e5
commit 577c2e4090
  1. 21
      test/core/util/port_isolated_runtime_environment.cc

@ -20,6 +20,8 @@
* runs in a separate container) the framework takes a round-robin pick of a * runs in a separate container) the framework takes a round-robin pick of a
* port within certain range. There is no need to recycle ports. * port within certain range. There is no need to recycle ports.
*/ */
#include <grpc/support/atm.h>
#include <grpc/support/log.h>
#include <grpc/support/time.h> #include <grpc/support/time.h>
#include <stdlib.h> #include <stdlib.h>
#include "src/core/lib/iomgr/port.h" #include "src/core/lib/iomgr/port.h"
@ -31,23 +33,22 @@
#define MIN_PORT 49152 #define MIN_PORT 49152
#define MAX_PORT 65535 #define MAX_PORT 65535
int get_random_starting_port() { static int get_random_port_offset() {
srand(gpr_now(GPR_CLOCK_REALTIME).tv_nsec); srand(gpr_now(GPR_CLOCK_REALTIME).tv_nsec);
double rnd = static_cast<double>(rand()) / double rnd = static_cast<double>(rand()) /
(static_cast<double>(RAND_MAX) + 1.0); // values from [0,1) (static_cast<double>(RAND_MAX) + 1.0); // values from [0,1)
return static_cast<int>(rnd * (MAX_PORT - MIN_PORT + 1)) + MIN_PORT; return static_cast<int>(rnd * (MAX_PORT - MIN_PORT + 1));
} }
static int s_allocated_port = get_random_starting_port(); static int s_initial_offset = get_random_port_offset();
static gpr_atm s_pick_counter = 0;
int grpc_pick_unused_port_or_die(void) { int grpc_pick_unused_port_or_die(void) {
// TODO(jtattermusch): protect by mutex int orig_counter_val =
int allocated_port = s_allocated_port++; static_cast<int>(gpr_atm_full_fetch_add(&s_pick_counter, 1));
if (s_allocated_port == MAX_PORT + 1) { GPR_ASSERT(orig_counter_val < (MAX_PORT - MIN_PORT + 1));
s_allocated_port = MIN_PORT; return MIN_PORT +
} (s_initial_offset + orig_counter_val) % (MAX_PORT - MIN_PORT + 1);
return allocated_port;
} }
void grpc_recycle_unused_port(int port) { (void)port; } void grpc_recycle_unused_port(int port) { (void)port; }

Loading…
Cancel
Save