我正在使用线程模块来同时托管一个web服务器和一个不和谐的机器人。Windows上一切运行良好,但一旦我将它加载到Linux服务器上,就会得到以下错误:
Starting Bot
Exception in thread Bot:
Traceback (most recent call last):
File "/usr/lib/python3.8/asyncio/unix_events.py", line 95, in add_signal_handler
signal.set_wakeup_fd(self._csock.fileno())
ValueError: set_wakeup_fd only works in main thread
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/usr/lib/python3.8/threading.py", line 932, in _bootstrap_inner
self.run()
File "/home/webadmin/discordbot/bot/moduls/m_threadingmaker.py", line 15, in run
self.client.run(self.args[0])
File "/home/webadmin/discordbot/bot/venv/lib/python3.8/site-packages/discord/client.py", line 614, in run
loop.add_signal_handler(signal.SIGINT, lambda: loop.stop())
File "/usr/lib/python3.8/asyncio/unix_events.py", line 97, in add_signal_handler
raise RuntimeError(str(exc))
RuntimeError: set_wakeup_fd only works in main thread
我已经从python3.7升级到python3.8,但是我仍然有相同的错误。
下面是我的代码: main.py (webserver已工作)
dcbot = m_threadingmaker.myThread("Bot", client, secrets.token)
webserver = m_threadingmaker.myThread("Flask", app, 'localhost', '7010')
#webserver.start()
dcbot.start()
M_threadingmaker.py
from threading import Thread
class myThread (Thread):
def __init__(self, name, client, *args):
Thread.__init__(self)
self.name = name
self.client = client
self.args = args
def run(self):
print("Starting " + self.name)
if self.name == "Flask":
self.client.run(host=self.args[0], port=self.args[1])
else:
self.client.run(self.args[0])
print("Exiting " + self.name)
发布于 2020-07-01 11:15:10
我建议您在异步协同器中使用client.start()
,而不是在单独的线程中使用client.run()
。
更详细的示例here
发布于 2020-07-02 15:18:35
webserver.start()
dcbot.run()
好的,现在启动webserver和bot。但是当我试图在机器人启动后做些什么的时候,什么都不会发生。然而,我感兴趣的是为什么会这样。如果有人知道一个好的和广泛的贡献,如书籍的线程,请发送它。
https://stackoverflow.com/questions/62671883
复制相似问题