记录WAMP工作人员跟踪返回错误

时间:2015-01-17 12:57:33

标签: python debugging autobahn crossbar

我一直在尝试为基于python组件的WAMP(Web应用程序消息传递协议)调试远程过程调用。例如:

前端(浏览器)

session.call('math.add2', [2, 'two']);

后端(python)

@wamp.register("math.add2")
def add2(self, x, y):
    return x + y

它给出了一些关于错误的想法。 Error

对于这样一个简单的例子,它对于拥有大量文件和模块的大型应用程序来说并不重要,我不太确定找出错误的最佳方法,以便输出完整的错误跟踪文件名,行号和描述。

作为解决方案,我稍微修改了 wamp.py (添加了 traceback.print_exc()行,如下所示)以在控制台日志中输出错误:

# autobahn/asyncio/wamp.py
...
import traceback
...

class FutureMixin:
  ...
  @staticmethod
  def _as_future(fun, *args, **kwargs):
     try:
        res = fun(*args, **kwargs)
     except Exception as e:
        traceback.print_exc() # Added this line
        ...

这是处理它的标准方法吗?

1 个答案:

答案 0 :(得分:2)

AutobahnPython允许您打开WAMP错误消息中的回溯:

class MyComponent(ApplicationSession):
   def __init__(self, config = None):
      ApplicationSession.__init__(self, config)
      self.traceback_app = True