我正在从事实时3d Web应用程序项目。 它基于Bottle和Gevent构建(使用bottle-websocket插件)。
使用Nuitka进行编译后,我们的开发服务器工作正常,但有一个例外:在Ctrl + C退出时引发错误。错误输出如下所示
$ ./__main__.bin server
Bottle v0.12.18 server starting up (using GeventWebSocketServer())...
Listening on http://0.0.0.0:8080/
Hit Ctrl-C to quit.
^CKeyboardInterrupt
2019-12-20T17:05:28Z
/usr/lib/python3/dist-packages/apport/report.py:13: DeprecationWarning: the imp module is deprecated in favour of importlib; see the module's documentation for alternative uses
import fnmatch, glob, traceback, errno, sys, atexit, locale, imp
Traceback (most recent call last):
File "/usr/local/lib/python3.6/dist-packages/gevent/baseserver.py", line 369, in serve_forever
self._stop_event.wait()
File "src/gevent/event.py", line 127, in gevent._event.Event.wait
File "src/gevent/_abstract_linkable.py", line 192, in gevent.__abstract_linkable.AbstractLinkable._wait
File "src/gevent/_abstract_linkable.py", line 165, in gevent.__abstract_linkable.AbstractLinkable._wait_core
File "src/gevent/_abstract_linkable.py", line 169, in gevent.__abstract_linkable.AbstractLinkable._wait_core
File "src/gevent/_greenlet_primitives.py", line 60, in gevent.__greenlet_primitives.SwitchOutGreenletWithLoop.switch
File "src/gevent/_greenlet_primitives.py", line 60, in gevent.__greenlet_primitives.SwitchOutGreenletWithLoop.switch
File "src/gevent/_greenlet_primitives.py", line 64, in gevent.__greenlet_primitives.SwitchOutGreenletWithLoop.switch
File "src/gevent/__greenlet_primitives.pxd", line 35, in gevent.__greenlet_primitives._greenlet_switch
KeyboardInterrupt
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/home/yunbo/Workspace/jk/backend/__main__.py", line 80, in <module>
File "/home/yunbo/Workspace/jk/backend/__main__.py", line 56, in main
File "/home/yunbo/Workspace/jk/backend/jobkey/system/server/server.py", line 41, in run
run(
File "/usr/local/lib/python3.6/dist-packages/bottle.py", line 3137, in run
server.run(app)
File "/usr/local/lib/python3.6/dist-packages/bottle_websocket/server.py", line 17, in run
server.serve_forever()
File "/usr/local/lib/python3.6/dist-packages/gevent/baseserver.py", line 371, in serve_forever
Greenlet.spawn(self.stop, timeout=stop_timeout).join()
File "src/gevent/greenlet.py", line 588, in gevent._greenlet.Greenlet.spawn
File "src/gevent/greenlet.py", line 258, in gevent._greenlet.Greenlet.__init__
File "src/gevent/greenlet.py", line 150, in gevent._greenlet._extract_stack
TypeError: Cannot convert compiled_frame to frame
为什么会这样?