今天在测试聊天室项目时,出现了一个大问题:我的tkinter卡住不动了.
当我点击登录时,它就自动卡死,而且还不报错!
经过一番排查,我发现问题出在Threading上
def __init__(self):
"""初始化客户端"""
# 初始化登录窗口
self.receive_thread = Thread(target=lambda: self.response_handle) # 问题线程
self.window = WindowLogin()
self.window.on_reset_button_cilck(self.clear_inputs)
self.window.on_login_button_cilck(self.send_login_data)
# 创建客户端套接字
self.conn = ClientSocket()
def startup(self):
"""开启窗口"""
self.conn.connect_server()
self.receive_thread.start()# 线程开始
self.window.mainloop()
不让线程开始,那么代码就没问题,所以问题一定出在线程里
顺着这条路,我找到了线程的target方法调用的函数:
def response_handle(self):
"""不断地接收服务器的新消息"""
while True:
recv_data_1 = self.conn.recv_data()
print(recv_data_1)
其中recv_data()为
def recv_data(self):
"""接收数据,并自动转换为字符串返回"""
return self.recv(512).decode('utf-8')
这更奇怪了,完全看不出来有什么错误.
一通logging,发现在按下登录时服务器只收到了登录信息,却没有发送信息,
回到服务器看了一下发现:服务器却报了一个pymysql.err.OperationalError.
于是定位到mysql上,去网上查了一下错误发现这种错误意味着mysql超时后自动关闭了,其中还提到了mysql中叫做wait_timeout的参数,查了一下发现才120!!!!,最后在my.ini中更改wait_timeout->36000,重启sql server和chat_server发现点登录时再也不会报错了!
查了一个晚上,弄得我够呛了