正在显示
9 个修改的文件
包含
190 行增加
和
27 行删除
... | ... | @@ -79,12 +79,9 @@ def create_app(): |
79 | 79 | |
80 | 80 | # 日志 |
81 | 81 | logging.basicConfig(level=configure.log_level) |
82 | - log_file = os.path.join(os.path.dirname(os.path.dirname( | |
83 | - os.path.realpath(__file__))), "logs", "log.txt") | |
84 | - handler = logging.FileHandler( | |
85 | - log_file, encoding='UTF-8') # 设置日志字符集和存储路径名字 | |
86 | - logging_format = logging.Formatter( | |
87 | - '[%(levelname)s] %(asctime)s %(message)s') | |
82 | + log_file = os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "logs", "log.txt") | |
83 | + handler = logging.FileHandler(log_file, encoding='UTF-8') # 设置日志字符集和存储路径名字 | |
84 | + logging_format = logging.Formatter('[%(levelname)s] %(asctime)s %(message)s') | |
88 | 85 | handler.setFormatter(logging_format) |
89 | 86 | app.logger.addHandler(handler) |
90 | 87 | |
... | ... | @@ -97,16 +94,13 @@ def create_app(): |
97 | 94 | app.register_blueprint(api.bp) |
98 | 95 | |
99 | 96 | # 入库监测线程 |
100 | - @app.before_first_request | |
101 | - def data_entry_process(): | |
102 | - StructurePrint().print("start listen") | |
103 | - process = threading.Thread(target=data_entry_center) | |
104 | - process.start() | |
97 | + # @app.before_first_request | |
98 | + # def data_entry_process(): | |
99 | + # StructurePrint().print("start listen") | |
100 | + # process = threading.Thread(target=data_entry_center) | |
101 | + # process.start() | |
105 | 102 | |
106 | 103 | # 不检测https |
107 | 104 | os.environ['OAUTHLIB_INSECURE_TRANSPORT'] = '1' |
108 | - | |
109 | - | |
110 | - | |
111 | 105 | return app |
112 | 106 | ... | ... |
... | ... | @@ -19,6 +19,7 @@ from app.util.component.ZipUtil import ZipUtil |
19 | 19 | from app.util.component.StructuredPrint import StructurePrint |
20 | 20 | import multiprocessing |
21 | 21 | import datetime |
22 | +from app.util.component.TaskController import TaskController | |
22 | 23 | |
23 | 24 | class Api(ApiTemplate): |
24 | 25 | |
... | ... | @@ -69,6 +70,9 @@ class Api(ApiTemplate): |
69 | 70 | |
70 | 71 | try: |
71 | 72 | |
73 | + #任务控制,等待执行 | |
74 | + TaskController.wait(task_guid) | |
75 | + | |
72 | 76 | sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) |
73 | 77 | |
74 | 78 | table_names = para.get("table_name").split(",") | ... | ... |
... | ... | @@ -13,8 +13,13 @@ import json |
13 | 13 | import re |
14 | 14 | from app.util.component.ApiTemplate import ApiTemplate |
15 | 15 | from app.util.component.PGUtil import PGUtil |
16 | +from app.util.component.StructuredPrint import StructurePrint | |
17 | +from sqlalchemy.orm import Session | |
18 | +import configure | |
16 | 19 | import datetime |
17 | - | |
20 | +import multiprocessing | |
21 | +from app.util.component.EntryDataVacuate import EntryDataVacuate | |
22 | +from app.util.component.TaskController import TaskController | |
18 | 23 | |
19 | 24 | class Api(ApiTemplate): |
20 | 25 | |
... | ... | @@ -68,7 +73,11 @@ class Api(ApiTemplate): |
68 | 73 | except: |
69 | 74 | print("关闭数据库失败!") |
70 | 75 | return res |
71 | - | |
76 | + | |
77 | + entry_thread = multiprocessing.Process(target=self.entry,args=(self.para.get("task_guid"),)) | |
78 | + entry_thread.start() | |
79 | + | |
80 | + | |
72 | 81 | # 录入数据后台进程,录入主函数为entry |
73 | 82 | # 初始化task |
74 | 83 | task = Task(guid=self.para.get("task_guid"), |
... | ... | @@ -81,10 +90,12 @@ class Api(ApiTemplate): |
81 | 90 | database_guid=self.para.get("database_guid"), |
82 | 91 | catalog_guid=self.para.get("catalog_guid"), |
83 | 92 | process="等待入库", |
84 | - parameter=json.dumps(self.para)) | |
93 | + parameter=json.dumps(self.para), | |
94 | + task_pid=entry_thread.pid) | |
85 | 95 | db.session.add(task) |
86 | 96 | db.session.commit() |
87 | - | |
97 | + | |
98 | + | |
88 | 99 | res["result"] = True |
89 | 100 | res["msg"] = "数据录入提交成功!" |
90 | 101 | res["data"] = self.para["task_guid"] |
... | ... | @@ -92,6 +103,81 @@ class Api(ApiTemplate): |
92 | 103 | raise e |
93 | 104 | return res |
94 | 105 | |
106 | + def entry(self,task_guid): | |
107 | + | |
108 | + sys_session: Session = None | |
109 | + this_task_layer = [] | |
110 | + try: | |
111 | + #任务控制,等待执行 | |
112 | + TaskController.wait(task_guid) | |
113 | + | |
114 | + sys_session: Session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) | |
115 | + | |
116 | + | |
117 | + task:Task = sys_session.query(Task).filter_by(guid=task_guid).one_or_none() | |
118 | + parameter = json.loads(task.parameter) | |
119 | + | |
120 | + task.state = 2 | |
121 | + task.process = "入库中" | |
122 | + sys_session.commit() | |
123 | + | |
124 | + | |
125 | + #处理修改入库信息 | |
126 | + | |
127 | + metas: list = json.loads(parameter.get("meta").__str__()) | |
128 | + parameter["meta"] = metas | |
129 | + | |
130 | + database = sys_session.query(Database).filter_by(guid=task.database_guid).one_or_none() | |
131 | + pg_ds: DataSource = PGUtil.open_pg_data_source(1, DES.decode(database.sqlalchemy_uri)) | |
132 | + | |
133 | + | |
134 | + for meta in metas: | |
135 | + overwrite = parameter.get("overwrite", "no") | |
136 | + | |
137 | + for layer_name_origin, layer_name in meta.get("layer").items(): | |
138 | + origin_name = layer_name | |
139 | + no = 1 | |
140 | + | |
141 | + while (overwrite.__eq__("no") and pg_ds.GetLayerByName(layer_name)) or sys_session.query( | |
142 | + InsertingLayerName).filter_by(name=layer_name).one_or_none(): | |
143 | + layer_name = origin_name + "_{}".format(no) | |
144 | + no += 1 | |
145 | + | |
146 | + # 添加到正在入库的列表中 | |
147 | + iln = InsertingLayerName(guid=uuid.uuid1().__str__(), | |
148 | + task_guid=task.guid, | |
149 | + name=layer_name) | |
150 | + | |
151 | + sys_session.add(iln) | |
152 | + sys_session.commit() | |
153 | + this_task_layer.append(layer_name) | |
154 | + # 修改表名 | |
155 | + meta["layer"][layer_name_origin] = layer_name | |
156 | + pg_ds.Destroy() | |
157 | + | |
158 | + #入库 | |
159 | + EntryDataVacuate().entry(parameter) | |
160 | + | |
161 | + #完成后 | |
162 | + for ln in this_task_layer: | |
163 | + iln = sys_session.query(InsertingLayerName).filter_by(name=ln).one_or_none() | |
164 | + sys_session.delete(iln) | |
165 | + | |
166 | + except Exception as e: | |
167 | + sys_session.query(Task).filter_by(guid=task_guid).update( | |
168 | + {"state": -1, "process": "入库失败"}) | |
169 | + | |
170 | + for ln in this_task_layer: | |
171 | + iln = sys_session.query(InsertingLayerName).filter_by(name=ln).one_or_none() | |
172 | + sys_session.delete(iln) | |
173 | + | |
174 | + sys_session.commit() | |
175 | + StructurePrint().print(e.__str__(), "error") | |
176 | + finally: | |
177 | + sys_session.commit() | |
178 | + if sys_session: | |
179 | + sys_session.close() | |
180 | + | |
95 | 181 | |
96 | 182 | api_doc={ |
97 | 183 | "tags":["IO接口"], | ... | ... |
... | ... | @@ -18,7 +18,7 @@ from app.util.component.PGUtil import PGUtil |
18 | 18 | from app.util.component.StructuredPrint import StructurePrint |
19 | 19 | from app.util.component.ApiTemplate import ApiTemplate |
20 | 20 | from app.util.component.GeometryAdapter import GeometryAdapter |
21 | - | |
21 | +from app.util.component.TaskController import TaskController | |
22 | 22 | import multiprocessing |
23 | 23 | import configure |
24 | 24 | |
... | ... | @@ -72,6 +72,10 @@ class Api(ApiTemplate): |
72 | 72 | db_tuple = PGUtil.get_info_from_sqlachemy_uri(DES.decode(database.sqlalchemy_uri)) |
73 | 73 | |
74 | 74 | try: |
75 | + | |
76 | + #任务控制,等待执行 | |
77 | + TaskController.wait(task_guid) | |
78 | + | |
75 | 79 | sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) |
76 | 80 | sys_ds = PGUtil.open_pg_data_source(0,configure.SQLALCHEMY_DATABASE_URI) |
77 | 81 | ... | ... |
... | ... | @@ -17,7 +17,7 @@ from app.util.component.PGUtil import PGUtil |
17 | 17 | from app.util.component.VacuateConf import VacuateConf |
18 | 18 | from app.util.component.GeometryAdapter import GeometryAdapter |
19 | 19 | |
20 | - | |
20 | +from app.util.component.TaskController import TaskController | |
21 | 21 | from osgeo.ogr import DataSource,Layer,Geometry |
22 | 22 | from osgeo import ogr |
23 | 23 | |
... | ... | @@ -105,15 +105,18 @@ class Api(ApiTemplate): |
105 | 105 | pg_ds = None |
106 | 106 | vacuate_process = None |
107 | 107 | try: |
108 | - sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) | |
109 | 108 | |
110 | - sys_session.query(Table).filter_by(guid=table.guid).update({"is_vacuate": 2, "update_time": datetime.datetime.now()}) | |
109 | + #任务控制,等待执行 | |
110 | + TaskController.wait(task_guid) | |
111 | + | |
111 | 112 | |
113 | + sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) | |
114 | + sys_session.query(Table).filter_by(guid=table.guid).update({"is_vacuate": 2, "update_time": datetime.datetime.now()}) | |
115 | + sys_session.query(Task).filter_by(guid=task_guid).update({"state":2,"process":"精华中"}) | |
112 | 116 | |
113 | 117 | database = sys_session.query(Database).filter_by(guid=table.database_guid).one_or_none() |
114 | 118 | database_sqlalchemy_uri = str(database.sqlalchemy_uri) |
115 | 119 | pg_session = PGUtil.get_db_session(DES.decode(database.sqlalchemy_uri)) |
116 | - | |
117 | 120 | pg_ds :DataSource= PGUtil.open_pg_data_source(0,DES.decode(database.sqlalchemy_uri)) |
118 | 121 | |
119 | 122 | |
... | ... | @@ -126,6 +129,7 @@ class Api(ApiTemplate): |
126 | 129 | #长时间的连接,导致后续的session超时,现在先断开 |
127 | 130 | sys_session.close() |
128 | 131 | |
132 | + | |
129 | 133 | # 创建抽稀过程 |
130 | 134 | options = ["OVERWRITE=yes", "GEOMETRY_NAME={}".format(PGUtil.get_geo_column(table.name,pg_session)), |
131 | 135 | "PRECISION=NO"] | ... | ... |
... | ... | @@ -17,6 +17,7 @@ from osgeo.ogr import DataSource,Layer,Geometry |
17 | 17 | from osgeo import ogr |
18 | 18 | |
19 | 19 | from app.util.component.VacuateConf import VacuateConf |
20 | +from app.util.component.TaskController import TaskController | |
20 | 21 | |
21 | 22 | class Api(ApiTemplate): |
22 | 23 | api_name = "单独抽稀" |
... | ... | @@ -106,16 +107,19 @@ class Api(ApiTemplate): |
106 | 107 | origin_vacuate = table.is_vacuate |
107 | 108 | |
108 | 109 | try: |
110 | + | |
111 | + #任务控制,等待执行 | |
112 | + TaskController.wait(task_guid) | |
113 | + | |
109 | 114 | sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) |
110 | 115 | sys_session.query(Table).filter_by(guid=table.guid).update( |
111 | 116 | {"is_vacuate": 2, "update_time": datetime.datetime.now()}) |
117 | + sys_session.query(Task).filter_by(guid=task_guid).update({"state":2,"process":"精华中"}) | |
112 | 118 | |
113 | - database = sys_session.query(Database).filter_by(guid=table.database_guid).one_or_none() | |
114 | 119 | |
120 | + database = sys_session.query(Database).filter_by(guid=table.database_guid).one_or_none() | |
115 | 121 | database_sqlalchemy_uri = str(database.sqlalchemy_uri) |
116 | - | |
117 | 122 | pg_session = PGUtil.get_db_session(DES.decode(database_sqlalchemy_uri)) |
118 | - | |
119 | 123 | pg_ds :DataSource= PGUtil.open_pg_data_source(1,DES.decode(database_sqlalchemy_uri)) |
120 | 124 | |
121 | 125 | #删除原有数据 | ... | ... |
... | ... | @@ -103,6 +103,10 @@ class Task(db.Model): |
103 | 103 | process = Column(Text) |
104 | 104 | create_time = Column(DateTime) |
105 | 105 | update_time = Column(DateTime) |
106 | + #0等待 | |
107 | + #1完成 | |
108 | + #-1失败 | |
109 | + #2正在进行中 | |
106 | 110 | state = Column(Integer) |
107 | 111 | #数据源外键 |
108 | 112 | database_guid = Column(String(256), ForeignKey('dmap_database.guid')) | ... | ... |
... | ... | @@ -16,10 +16,11 @@ import configure |
16 | 16 | from app.util.component.PGUtil import PGUtil |
17 | 17 | from .util.Cache import Cache |
18 | 18 | import json |
19 | -from osgeo import gdal,osr | |
19 | +from osgeo import gdal | |
20 | 20 | from osgeo.gdal import * |
21 | 21 | import traceback |
22 | 22 | import os |
23 | +from app.util.component.TaskController import TaskController | |
23 | 24 | |
24 | 25 | class Api(ApiTemplate): |
25 | 26 | |
... | ... | @@ -77,6 +78,11 @@ class Api(ApiTemplate): |
77 | 78 | def build_pyramid_task(self,image_guid,task_guid,data_servers,path): |
78 | 79 | sys_session = None |
79 | 80 | try: |
81 | + | |
82 | + | |
83 | + #任务控制,等待执行 | |
84 | + TaskController.wait(task_guid) | |
85 | + | |
80 | 86 | sys_session = PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) |
81 | 87 | #进入创建金字塔的状态 |
82 | 88 | sys_session.query(Image).filter_by(guid=image_guid).update({"has_pyramid": -1}) | ... | ... |
app/util/component/TaskController.py
0 → 100644
1 | +# coding=utf-8 | |
2 | +#author: 4N | |
3 | +#createtime: 2021/12/2 | |
4 | +#email: nheweijun@sina.com | |
5 | + | |
6 | +from app.modules.data.models import Task | |
7 | +from app.util.component.StructuredPrint import StructurePrint | |
8 | +import configure | |
9 | +import time | |
10 | +from app.util.component.PGUtil import PGUtil | |
11 | + | |
12 | +class TaskController: | |
13 | + ''' | |
14 | + 此类是面向切面的类,控制各种任务是否可以进入执行状态 | |
15 | + ''' | |
16 | + | |
17 | + @classmethod | |
18 | + def pass_check(cls,sys_session,task_guid): | |
19 | + | |
20 | + # 任务类型 | |
21 | + # 1:入库任务 | |
22 | + # 2:抽稀任务 | |
23 | + # 3:数据库刷新任务 | |
24 | + # 4:数据下载任务 | |
25 | + # 5:影像金字塔任务 | |
26 | + | |
27 | + task = sys_session.query(Task).filter_by(guid=task_guid).one_or_none() | |
28 | + | |
29 | + check = True | |
30 | + if task.task_type==1: | |
31 | + #控制正在运行的任务数量 | |
32 | + running_count = sys_session.query(Task).filter(Task.state == 2).filter(Task.task_type == 1).count() | |
33 | + first_task = sys_session.query(Task).filter(Task.state == 0).filter(Task.task_type == 1).order_by(Task.create_time).first() | |
34 | + if (running_count > configure.entry_data_thread) or (not first_task.guid.__eq__(task_guid)): | |
35 | + StructurePrint().print("等待入库") | |
36 | + check = False | |
37 | + if task.task_type==2: | |
38 | + running_count = sys_session.query(Task).filter(Task.state == 2).filter(Task.task_type == 2).count() | |
39 | + first_task = sys_session.query(Task).filter(Task.state == 0).filter(Task.task_type == 2).order_by(Task.create_time).first() | |
40 | + if (running_count > configure.entry_data_thread) or (not first_task.guid.__eq__(task_guid)): | |
41 | + StructurePrint().print("等待精化") | |
42 | + check = False | |
43 | + if task.task_type==3: | |
44 | + pass | |
45 | + if task.task_type==4: | |
46 | + pass | |
47 | + if task.task_type==5: | |
48 | + pass | |
49 | + | |
50 | + return check | |
51 | + | |
52 | + @classmethod | |
53 | + def wait(cls,task_guid): | |
54 | + sys_session= PGUtil.get_db_session(configure.SQLALCHEMY_DATABASE_URI) | |
55 | + while not cls.pass_check(sys_session,task_guid): | |
56 | + time.sleep(3) | |
57 | + sys_session.close() | |
\ No newline at end of file | ... | ... |
请
注册
或
登录
后发表评论