Есть ли другой способ использовать PyDataLog в CherryPy, чем обычный способ использования PyDataLog?
Я получаю ошибку, как это ниже в 500 internal server error
стр.
File "/usr/local/lib/python3.5/dist-packages/pyDatalog/pyParser.py", line 388, in __call__
literal = Literal.make(self._pyD_name, tuple(args), kwargs)
File "/usr/local/lib/python3.5/dist-packages/pyDatalog/pyParser.py", line 510, in make
return precalculations & Query(predicate_name, terms, kwargs, prearity, aggregate)
File "/usr/local/lib/python3.5/dist-packages/pyDatalog/pyParser.py", line 574, in __init__
Literal.__init__(self, predicate_name, terms, kwargs, prearity, aggregate)
File "/usr/local/lib/python3.5/dist-packages/pyDatalog/pyParser.py", line 500, in __init__
self.lua = pyEngine.Literal(self.predicate_name, tbl, self.prearity, aggregate)
File "pyDatalog\pyEngine.py", line 402, in pyDatalog.pyEngine.Literal.__init__ (pyDatalog/pyEngine.c:15254)
File "pyDatalog\pyEngine.py", line 333, in pyDatalog.pyEngine.Pred.__new__ (pyDatalog/pyEngine.c:13917)
File "pyDatalog\pyEngine.py", line 334, in pyDatalog.pyEngine.Pred.__new__ (pyDatalog/pyEngine.c:13431)
AttributeError: '_thread._local' object has no attribute 'logic'
Как получить доступ к переменным PyDataLog
1 ответ
Решение
Я нашел ответ здесь в Thread safety and multi-models
раздел. Если это может помочь кому-либо еще сталкиваться с тем, с чем я столкнулся
Программа Python может запускать несколько потоков. Каждый поток должен иметь эти операторы для инициализации pyDatalog:
from pyDatalog import pyDatalog, Logic
Logic() # initializes the pyDatalog engine