xtn-tools-pro 1.0.0.2.7__tar.gz → 1.0.0.2.9__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (30) hide show
  1. {xtn-tools-pro-1.0.0.2.7/xtn_tools_pro.egg-info → xtn-tools-pro-1.0.0.2.9}/PKG-INFO +1 -1
  2. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/setup.py +1 -1
  3. xtn-tools-pro-1.0.0.2.9/xtn_tools_pro/task_pro/go_fun.py +229 -0
  4. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9/xtn_tools_pro.egg-info}/PKG-INFO +1 -1
  5. xtn-tools-pro-1.0.0.2.7/xtn_tools_pro/task_pro/go_fun.py +0 -54
  6. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/LICENSE +0 -0
  7. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/README.md +0 -0
  8. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/setup.cfg +0 -0
  9. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/__init__.py +0 -0
  10. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/db/MongoDB.py +0 -0
  11. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/db/MysqlDB.py +0 -0
  12. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/db/RedisDB.py +0 -0
  13. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/db/__init__.py +0 -0
  14. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/proxy/XiaoXiangProxy.py +0 -0
  15. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/proxy/__init__.py +0 -0
  16. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/proxy/proxy.py +0 -0
  17. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/task_pro/__init__.py +0 -0
  18. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/tools.py +0 -0
  19. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/__init__.py +0 -0
  20. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/crypto.py +0 -0
  21. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/file_utils.py +0 -0
  22. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/helpers.py +0 -0
  23. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/log.py +0 -0
  24. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/retry.py +0 -0
  25. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/sql.py +0 -0
  26. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro/utils/time_utils.py +0 -0
  27. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro.egg-info/SOURCES.txt +0 -0
  28. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro.egg-info/dependency_links.txt +0 -0
  29. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro.egg-info/requires.txt +0 -0
  30. {xtn-tools-pro-1.0.0.2.7 → xtn-tools-pro-1.0.0.2.9}/xtn_tools_pro.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: xtn-tools-pro
3
- Version: 1.0.0.2.7
3
+ Version: 1.0.0.2.9
4
4
  Summary: xtn 开发工具
5
5
  Author: xtn
6
6
  Author-email: czw011122@gmail.com
@@ -15,7 +15,7 @@ with open("README.md", "r") as f:
15
15
 
16
16
  setuptools.setup(
17
17
  name="xtn-tools-pro", # 模块名称
18
- version="1.0.0.2.7", # 版本
18
+ version="1.0.0.2.9", # 版本
19
19
  author="xtn", # 作者
20
20
  author_email="czw011122@gmail.com", # 作者邮箱
21
21
  description="xtn 开发工具", # 模块简介
@@ -0,0 +1,229 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+
4
+ # 说明:
5
+ # 程序说明xxxxxxxxxxxxxxxxxxx
6
+ # History:
7
+ # Date Author Version Modification
8
+ # --------------------------------------------------------------------------------------------------
9
+ # 2025/1/14 xiatn V00.01.000 新建
10
+ # --------------------------------------------------------------------------------------------------
11
+ import time
12
+ import inspect
13
+ import requests
14
+ import threading
15
+ import multiprocessing
16
+ import concurrent.futures
17
+ from multiprocessing import Process
18
+
19
+
20
+ class GoFun:
21
+ def __init__(self, ini_dict, logger, go_task_function=None):
22
+ # 读取配置信息
23
+ host = ini_dict.get('host', '')
24
+ port = ini_dict.get('port', 0)
25
+ task = ini_dict.get('task', '')
26
+ auto = ini_dict.get('auto', '')
27
+ processes_num = ini_dict.get('processes_num', 0)
28
+ thread_num = ini_dict.get('thread_num', 0)
29
+ restart_time = ini_dict.get('restart_time', 0)
30
+
31
+ self.__ini_info = {
32
+ "host": host,
33
+ "port": port,
34
+ "task": task,
35
+ "auto": auto,
36
+ "processes_num": processes_num,
37
+ "thread_num": thread_num,
38
+ "restart_time": restart_time,
39
+ }
40
+
41
+ for server_k, server_v in self.__ini_info.items():
42
+ if not server_v and server_k not in ["port", "processes_num", "thread_num", "restart_time"]:
43
+ raise Exception(f"ini_dict 配置 {server_k} 不存在")
44
+
45
+ if port:
46
+ task_host = f"http://{host}:{port}"
47
+ else:
48
+ task_host = f"http://{host}"
49
+
50
+ download_url = task_host + "/filter_server/phone/get"
51
+ upload_url = task_host + "/filter_server/phone/update"
52
+ external_ip = self.__get_external_ip()
53
+
54
+ self.__ini_info["download_url"] = download_url
55
+ self.__ini_info["upload_url"] = upload_url
56
+ self.__ini_info["external_ip"] = external_ip
57
+
58
+ self.logger = logger
59
+
60
+ if not go_task_function:
61
+ return
62
+
63
+ # 共享任务队列
64
+ download_queue = multiprocessing.Queue()
65
+ upload_queue = multiprocessing.Queue()
66
+ download_task_process = multiprocessing.Process(target=self._download_and_upload_task,
67
+ args=(download_queue, upload_queue, self.__ini_info, logger))
68
+ download_task_process.start()
69
+
70
+ # 根据配置启动任务
71
+ if go_task_function:
72
+ go_task_fun_process = multiprocessing.Process(target=self._go_task_fun_task,
73
+ args=(download_queue, upload_queue, self.__ini_info,
74
+ go_task_function, logger))
75
+ go_task_fun_process.start()
76
+
77
+ def __get_external_ip(self):
78
+ """
79
+ 获取当前网络ip
80
+ :return:
81
+ """
82
+ while True:
83
+ try:
84
+ rp = requests.get('https://httpbin.org/ip')
85
+ rp_json = rp.json()
86
+ print(f"当前网络ip --> {rp_json}")
87
+ return rp_json['origin']
88
+ except Exception as e:
89
+ pass
90
+
91
+ def _download_and_upload_task(self, download_queue, upload_queue, ini_info, logger):
92
+ """
93
+ 使用两个线程 打开 获取任务、回写任务
94
+ :param queue:
95
+ :return:
96
+ """
97
+ caller = inspect.stack()[1] # 获取调用者的调用栈信息
98
+ caller_name = caller.function # 获取调用者的函数名
99
+ caller_class = caller.frame.f_locals.get('self', None) # 获取调用者的类实例
100
+ if caller_name != "run" or caller_class is None:
101
+ raise Exception("错误调用")
102
+ thread_download_task = threading.Thread(target=self.__download_task, args=(download_queue, ini_info, logger))
103
+ thread_download_task.start()
104
+ thread_upload_task = threading.Thread(target=self.__upload_task, args=(upload_queue, ini_info, logger))
105
+ thread_upload_task.start()
106
+
107
+ def __download_task(self, download_queue, ini_info, logger):
108
+ """
109
+ 获取任务
110
+ :param queue:
111
+ :return:
112
+ """
113
+ download_url = ini_info["download_url"]
114
+ external_ip = ini_info["external_ip"]
115
+ auto = ini_info["auto"]
116
+ task = ini_info["task"]
117
+ headers = {"Authorization": auto}
118
+ params = {"taskType": task}
119
+ while True:
120
+ qsize = download_queue.qsize()
121
+ logger.info(f"获取任务,当前队列任务数:{qsize}")
122
+ if download_queue.qsize() >= 10:
123
+ time.sleep(2)
124
+ continue
125
+ resp = requests.get(download_url, headers=headers, params=params, timeout=5)
126
+ json_data = resp.json()
127
+ result_list = json_data.get("result", [])
128
+ for task_item in result_list:
129
+ download_queue.put(task_item)
130
+ logger.info(f"成功获取任务个数:{len(result_list)}")
131
+
132
+ def __upload_task(self, queue, ini_info, logger):
133
+ """
134
+ 回写任务
135
+ :return:
136
+ """
137
+ upload_url = ini_info["upload_url"]
138
+ external_ip = ini_info["external_ip"]
139
+ auto = ini_info["auto"]
140
+ task = ini_info["task"]
141
+ headers = {"Authorization": auto}
142
+ params = {"taskType": task}
143
+ while True:
144
+ # 判断队列是否有值
145
+ empty = queue.empty()
146
+ if empty:
147
+ time.sleep(2)
148
+ continue
149
+
150
+ # 循环全部获取队列的任务
151
+ result_list = []
152
+ try:
153
+ while True:
154
+ result_list.append(queue.get_nowait())
155
+ except Exception as e:
156
+ pass
157
+
158
+ # 回写任务
159
+ data = {"result": result_list, "remoteAddr": external_ip}
160
+ while True:
161
+ try:
162
+ resp = requests.post(upload_url, json=data, headers=headers, params=params, timeout=5)
163
+ json_data = resp.json()
164
+ logger.info(f"成功回写任务个数:{len(result_list)},{json_data}")
165
+ break
166
+ except Exception as e:
167
+ logger.critical(f"回写异常:{e}")
168
+
169
+ def _go_task_fun_task(self, download_queue, upload_queue, ini_info, go_task_function, logger):
170
+ """
171
+ 单函数,根据配置启动程序
172
+ :param queue:
173
+ :return:
174
+ """
175
+ caller = inspect.stack()[1] # 获取调用者的调用栈信息
176
+ caller_name = caller.function # 获取调用者的函数名
177
+ caller_class = caller.frame.f_locals.get('self', None) # 获取调用者的类实例
178
+ if caller_name != "run" or caller_class is None:
179
+ raise Exception("错误调用")
180
+
181
+ processes_num = ini_info["processes_num"]
182
+ thread_num = ini_info["thread_num"]
183
+ restart_time = ini_info["restart_time"]
184
+
185
+ processes_num = 1 if processes_num <= 0 else processes_num
186
+ thread_num = 1 if thread_num <= 0 else thread_num
187
+
188
+ go_task_fun_cnt = 0
189
+ processes_start_list = []
190
+ while True:
191
+ try:
192
+ if not processes_start_list:
193
+ go_task_fun_cnt += 1
194
+ logger.info(
195
+ f"第{go_task_fun_cnt}次,进程数:{processes_num},线程数:{thread_num},等待{restart_time}秒强制下一次")
196
+ for i in range(processes_num):
197
+ p = Process(target=self._run_with_timeout,
198
+ args=(download_queue, upload_queue, thread_num, go_task_function))
199
+ processes_start_list.append(p)
200
+ p.start()
201
+
202
+ if not restart_time:
203
+ # 一直执行 不退出
204
+ continue
205
+
206
+ time.sleep(restart_time)
207
+ # 关闭所有进程
208
+ for p in processes_start_list:
209
+ p.terminate()
210
+ p.join() # 等待进程确实结束
211
+ processes_start_list = []
212
+
213
+ except Exception as e:
214
+ pass
215
+
216
+ def _run_with_timeout(self, download_queue, upload_queue, thread_num, go_task_function):
217
+ caller = inspect.stack()[1] # 获取调用者的调用栈信息
218
+ caller_name = caller.function # 获取调用者的函数名
219
+ caller_class = caller.frame.f_locals.get('self', None) # 获取调用者的类实例
220
+ if caller_name != "run" or caller_class is None:
221
+ raise Exception("错误调用")
222
+
223
+ with concurrent.futures.ThreadPoolExecutor(max_workers=thread_num) as executor:
224
+ # 提交10个函数到线程池中执行
225
+ futures = [executor.submit(go_task_function, download_queue, upload_queue) for _ in range(thread_num)]
226
+
227
+ # 等待所有线程完成
228
+ for future in concurrent.futures.as_completed(futures):
229
+ future.result()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: xtn-tools-pro
3
- Version: 1.0.0.2.7
3
+ Version: 1.0.0.2.9
4
4
  Summary: xtn 开发工具
5
5
  Author: xtn
6
6
  Author-email: czw011122@gmail.com
@@ -1,54 +0,0 @@
1
- #!/usr/bin/env python
2
- # -*- coding: utf-8 -*-
3
-
4
- # 说明:
5
- # 程序说明xxxxxxxxxxxxxxxxxxx
6
- # History:
7
- # Date Author Version Modification
8
- # --------------------------------------------------------------------------------------------------
9
- # 2025/1/14 xiatn V00.01.000 新建
10
- # --------------------------------------------------------------------------------------------------
11
- import os
12
- import configparser
13
- from xtn_tools_pro.utils.file_utils import check_file_exists
14
-
15
-
16
- class GoFun:
17
- def __init__(self, ini_dict):
18
- # 读取配置信息
19
- host = ini_dict.get('host', '')
20
- port = ini_dict.get('port', 0)
21
- task = ini_dict.get('task', '')
22
- auto = ini_dict.get('auto', '')
23
- is_processes = ini_dict.get('is_processes', False)
24
- processes_num = ini_dict.get('processes_num', 0)
25
- is_thread = ini_dict.get('is_thread', False)
26
- thread_num = ini_dict.get('thread_num', 0)
27
-
28
- self.__ini_info = {
29
- "host": host,
30
- "port": port,
31
- "task": task,
32
- "auto": auto,
33
- "is_processes": is_processes,
34
- "processes_num": processes_num,
35
- "is_thread": is_thread,
36
- "thread_num": thread_num,
37
- }
38
-
39
- for server_k, server_v in self.__ini_info.items():
40
- if not server_v and server_k not in ["port", "is_processes", "processes_num", "is_thread", "thread_num"]:
41
- raise Exception(f"ini_dict 配置 {server_k} 不存在")
42
-
43
- if port:
44
- task_host = f"http://{host}:{port}"
45
- else:
46
- task_host = f"http://{host}"
47
-
48
- download_url = task_host + "/filter_server/phone/get"
49
- upload_url = task_host + "/filter_server/phone/update"
50
-
51
- self.__ini_info["download_url"] = download_url
52
- self.__ini_info["upload_url"] = upload_url
53
-
54
- print(self.__ini_info)