.stop()

时间:2015-12-05 12:00:03

标签: python webserver tornado python-multithreading

我在龙卷风上建立了网络服务器。以下是主WebServer类的一些部分:

import tornado.ioloop as tio
...

class WebServer(object):

    def __init__(.....):
        ...
        self.IOloop = tio.IOLoop.instance()
        ...

    def __call__(self):
        self.logger('info', 'Web server', 'Starting web server on port %s, waiting for connection...' % (self.port))
        if self.verbose:
            print 'Starting web server on port %s, waiting for connection...' % (self.port)
        try:
            self.application.listen(self.port)
            self.IOloop.start()
        except Exception as error:
            self.logger('error', 'Web server', str(error), exc_info = True)
        self.stop()
        if self.verbose:
            print 'Web server shut down'
        self.logger('info', 'Web server', 'Stopped')

    def stop(self):
        if self.up:
            self.logger('info', 'Web server', 'Shutting down...')
            ioloop = tio.IOLoop.current()
            ioloop.stop()
            ioloop.close()
            self.ws_controller.stop()
            self.ws_thread.join()
            self.up = False

服务器实例是运行的各种后端对象之一。我在单独的线程中启动服务器实例以及其他后端对象:

def assign_component(self, name, config_name, class_):
    self.components[name] = class_(bus = self.bus, logger = self.logger, config = self.config[config_name], verbose = self.verbose)
    setattr(self, name, self.components[name])
    self.threads[name] = thr.Thread(target = self.components[name])
    self.threads[name].start()

在这种情况下,class_是WebServer。 它的工作没有问题。但是当我想要停止整个应用程序时,我会遇到以下错误:

ERROR:tornado.application:Exception in callback None
  Traceback (most recent call last):
    File "/root/anaconda2/lib/python2.7/site-packages/tornado/ioloop.py", line 865, in start
      fd_obj, handler_func = self._handlers[fd]
KeyError: 29

我阅读了很多文章,他们讲了一些关于线程不安全和add_callback的内容,但我不明白为什么我需要一些回调如果我只想启动和停止IOloop的主要实例?在了解龙卷风IOloop时我缺少什么?

1 个答案:

答案 0 :(得分:3)

IOLoop中唯一的线程安全方法是add_callback。你可以用它来阻止IOLoop。但是,未经测试,它将类似于:

...
def stop(self):
    if self.up:
        self.logger('info', 'Web server', 'Shutting down...')
        self.IOLoop.add_callback(lambda x: x.stop(), self.IOLoop)
        self.ws_controller.stop()
        self.ws_thread.join()
        self.up = False

一些相关问题:How do I stop Tornado web server?

P.S。提供minimum working example是好习惯。