예제 #1
0
class ReplayLoadBalancer(object):

  def __init__(self):
    self.sampler_proxy = None
    self.collector_proxy = None

    self.collector_frontend_port = os.environ['SYMPH_COLLECTOR_FRONTEND_PORT']
    self.collector_backend_port = os.environ['SYMPH_COLLECTOR_BACKEND_PORT']
    self.sampler_frontend_port = os.environ['SYMPH_SAMPLER_FRONTEND_PORT']
    self.sampler_backend_port = os.environ['SYMPH_SAMPLER_BACKEND_PORT']

    self.collector_frontend_add = "tcp://*:{}".format(
        self.collector_frontend_port)
    self.collector_backend_add = "tcp://*:{}".format(
        self.collector_backend_port)
    self.sampler_frontend_add = "tcp://*:{}".format(self.sampler_frontend_port)
    self.sampler_backend_add = "tcp://*:{}".format(self.sampler_backend_port)

  def launch(self):
    self.collector_proxy = ZmqProxyThread(in_add=self.collector_frontend_add,
                                          out_add=self.collector_backend_add,
                                          pattern='router-dealer')
    self.sampler_proxy = ZmqProxyThread(in_add=self.sampler_frontend_add,
                                        out_add=self.sampler_backend_add,
                                        pattern='router-dealer')

    self.collector_proxy.setDaemon(False)
    self.collector_proxy.start()
    self.sampler_proxy.setDaemon(False)
    self.sampler_proxy.start()

  def join(self):
    self.collector_proxy.join()
    self.sampler_proxy.join()
예제 #2
0
class ShardedReplay(object):
    def __init__(self,
                 replay_class,
                 learner_config,
                 env_config,
                 session_config,):
        """
        Args:
            *_config: passed on to replay
        """
        self.sampler_proxy = None
        self.collector_proxy = None
        self.processes = []

        self.learner_config = learner_config
        self.env_config = env_config
        self.session_config = session_config

        self.replay_class = replay_class

        self.shards = self.learner_config.replay.replay_shards

        self.collector_frontend_port = os.environ['SYMPH_COLLECTOR_FRONTEND_PORT']
        self.collector_backend_port = os.environ['SYMPH_COLLECTOR_BACKEND_PORT']
        self.sampler_frontend_port = os.environ['SYMPH_SAMPLER_FRONTEND_PORT']
        self.sampler_backend_port = os.environ['SYMPH_SAMPLER_BACKEND_PORT']

        self.collector_frontend_add = "tcp://*:{}".format(self.collector_frontend_port)
        self.collector_backend_add = "tcp://*:{}".format(self.collector_backend_port)
        self.sampler_frontend_add = "tcp://*:{}".format(self.sampler_frontend_port)
        self.sampler_backend_add = "tcp://*:{}".format(self.sampler_backend_port)

    def launch(self):

        self.processes = []

        print('Starting {} replay shards'.format(self.shards))
        for i in range(self.shards):
            print('Replay {} starting'.format(i))
            p = Process(target=self.start_replay, args=[i])
            p.start()
            self.processes.append(p)

        self.collector_proxy = ZmqProxyThread(
            in_add=self.collector_frontend_add,
            out_add=self.collector_backend_add,
            pattern='router-dealer')
        self.sampler_proxy = ZmqProxyThread(
            in_add=self.sampler_frontend_add,
            out_add=self.sampler_backend_add,
            pattern='router-dealer')

        self.collector_proxy.start()
        self.sampler_proxy.start()

    def start_replay(self, index):
        replay = self.replay_class(self.learner_config,
                                   self.env_config,
                                   self.session_config,
                                   index=index)
        replay.start_threads()
        replay.join()

    def join(self):
        for i, p in enumerate(self.processes):
            p.join()
            U.report_exitcode(p.exitcode, 'replay-{}'.format(i))
        self.collector_proxy.join()
        self.sampler_proxy.join()