|  | @@ -4,6 +4,7 @@
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  import time
 | 
	
		
			
				|  |  |  import json
 | 
	
		
			
				|  |  | +import threading
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  import requests
 | 
	
		
			
				|  |  |  import schedule
 | 
	
	
		
			
				|  | @@ -12,6 +13,7 @@ from datetime import datetime
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  from config import accountBaseInfo
 | 
	
		
			
				|  |  |  from applications import PQMySQL, WeixinSpider, Functions
 | 
	
		
			
				|  |  | +from applications.decoratorApi import retryOnTimeout
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  class UpdateMsgDaily(object):
 | 
	
	
		
			
				|  | @@ -37,6 +39,7 @@ class UpdateMsgDaily(object):
 | 
	
		
			
				|  |  |          return gh_id_dict
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @classmethod
 | 
	
		
			
				|  |  | +    @retryOnTimeout()
 | 
	
		
			
				|  |  |      def bot(cls, account_list):
 | 
	
		
			
				|  |  |          """
 | 
	
		
			
				|  |  |          机器人
 | 
	
	
		
			
				|  | @@ -67,7 +70,7 @@ class UpdateMsgDaily(object):
 | 
	
		
			
				|  |  |                  "header": {"title": {"content": "【重点关注】", "tag": "plain_text"}},
 | 
	
		
			
				|  |  |              },
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | -        requests.request("POST", url=url, headers=headers, data=json.dumps(payload))
 | 
	
		
			
				|  |  | +        requests.request("POST", url=url, headers=headers, data=json.dumps(payload), timeout=10)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      @classmethod
 | 
	
		
			
				|  |  |      def findAccountLatestUpdateTime(cls, gh_id):
 | 
	
	
		
			
				|  | @@ -191,7 +194,18 @@ class UpdateMsgDaily(object):
 | 
	
		
			
				|  |  |          输入ghid获取账号的文章list
 | 
	
		
			
				|  |  |          :return:
 | 
	
		
			
				|  |  |          """
 | 
	
		
			
				|  |  | -        response = cls.spider.update_msg_list(ghId=gh_id, index=cursor)
 | 
	
		
			
				|  |  | +        try:
 | 
	
		
			
				|  |  | +            response = cls.spider.update_msg_list(ghId=gh_id, index=cursor)
 | 
	
		
			
				|  |  | +        except Exception as e:
 | 
	
		
			
				|  |  | +            response = {
 | 
	
		
			
				|  |  | +                "error": str(e),
 | 
	
		
			
				|  |  | +                "info": "更新文章接口请求失败",
 | 
	
		
			
				|  |  | +                "gh_id": gh_id,
 | 
	
		
			
				|  |  | +                "time": datetime.now().__str__()
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +            # 之后可以考虑抛出阿里云日志
 | 
	
		
			
				|  |  | +            print(response)
 | 
	
		
			
				|  |  | +            return
 | 
	
		
			
				|  |  |          msg_list = response.get("data", {}).get("data")
 | 
	
		
			
				|  |  |          if msg_list:
 | 
	
		
			
				|  |  |              last_article_in_this_msg = msg_list[-1]
 | 
	
	
		
			
				|  | @@ -200,7 +214,17 @@ class UpdateMsgDaily(object):
 | 
	
		
			
				|  |  |              ]["UpdateTime"]
 | 
	
		
			
				|  |  |              last_url = last_article_in_this_msg["AppMsg"]["DetailInfo"][0]["ContentUrl"]
 | 
	
		
			
				|  |  |              # 校验是否抓到的是同一个账号
 | 
	
		
			
				|  |  | -            resdata = cls.spider.get_account_by_url(last_url)
 | 
	
		
			
				|  |  | +            try:
 | 
	
		
			
				|  |  | +                resdata = cls.spider.get_account_by_url(last_url)
 | 
	
		
			
				|  |  | +            except Exception as e:
 | 
	
		
			
				|  |  | +                resdata = {
 | 
	
		
			
				|  |  | +                    "error": str(e),
 | 
	
		
			
				|  |  | +                    "info": "通过链接获取账号信息失败",
 | 
	
		
			
				|  |  | +                    "gh_id": gh_id,
 | 
	
		
			
				|  |  | +                    "time": datetime.now().__str__()
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                print(resdata)
 | 
	
		
			
				|  |  | +                return
 | 
	
		
			
				|  |  |              check_name = resdata["data"].get("data", {}).get("account_name")
 | 
	
		
			
				|  |  |              check_id = resdata["data"].get("data", {}).get("wx_gh")
 | 
	
		
			
				|  |  |              if check_id == gh_id:
 | 
	
	
		
			
				|  | @@ -294,14 +318,27 @@ class UpdateMsgDaily(object):
 | 
	
		
			
				|  |  |                  name = account_dict[account_id]
 | 
	
		
			
				|  |  |                  error_account_list.append(name)
 | 
	
		
			
				|  |  |          if error_account_list:
 | 
	
		
			
				|  |  | -            cls.bot(error_account_list)
 | 
	
		
			
				|  |  | +            try:
 | 
	
		
			
				|  |  | +                cls.bot(error_account_list)
 | 
	
		
			
				|  |  | +            except Exception as e:
 | 
	
		
			
				|  |  | +                print("Timeout Error: {}".format(e))
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +def job_with_thread(job_func):
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    每个任务放到单个线程中
 | 
	
		
			
				|  |  | +    :param job_func:
 | 
	
		
			
				|  |  | +    :return:
 | 
	
		
			
				|  |  | +    """
 | 
	
		
			
				|  |  | +    job_thread = threading.Thread(target=job_func)
 | 
	
		
			
				|  |  | +    job_thread.start()
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  if __name__ == "__main__":
 | 
	
		
			
				|  |  |      UMD = UpdateMsgDaily()
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    schedule.every().day.at("21:00").do(UMD.updateJob)
 | 
	
		
			
				|  |  | -    schedule.every().day.at("21:30").do(UMD.checkJob)
 | 
	
		
			
				|  |  | +    schedule.every().day.at("21:00").do(job_with_thread, UMD.updateJob)
 | 
	
		
			
				|  |  | +    schedule.every().day.at("21:30").do(job_with_thread, UMD.checkJob)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      while True:
 | 
	
		
			
				|  |  |          schedule.run_pending()
 |