2021-08-17 17:00:34 +08:00
|
|
|
|
#!/usr/bin/env python
|
|
|
|
|
from datetime import datetime
|
|
|
|
|
import json
|
|
|
|
|
from myapp import app, appbuilder, db, security_manager
|
|
|
|
|
from myapp.models.model_team import Project,Project_User
|
2021-10-14 17:36:14 +08:00
|
|
|
|
from myapp.models.model_job import Repository,Images,Job_Template,Pipeline,Task
|
2022-08-02 16:03:09 +08:00
|
|
|
|
from myapp.models.model_dataset import Dataset
|
2022-05-22 22:05:10 +08:00
|
|
|
|
from myapp.models.model_serving import Service,InferenceService
|
2022-08-02 16:03:09 +08:00
|
|
|
|
from myapp.models.model_train_model import Training_Model
|
|
|
|
|
import uuid
|
2021-08-17 17:00:34 +08:00
|
|
|
|
conf = app.config
|
|
|
|
|
|
|
|
|
|
def create_app(script_info=None):
|
|
|
|
|
return app
|
|
|
|
|
|
|
|
|
|
@app.shell_context_processor
|
|
|
|
|
def make_shell_context():
|
|
|
|
|
return dict(app=app, db=db)
|
|
|
|
|
|
|
|
|
|
# https://dormousehole.readthedocs.io/en/latest/cli.html
|
|
|
|
|
@app.cli.command('init')
|
2022-06-04 17:38:31 +08:00
|
|
|
|
# @pysnooper.snoop()
|
2021-08-17 17:00:34 +08:00
|
|
|
|
def init():
|
2021-10-14 17:36:14 +08:00
|
|
|
|
|
|
|
|
|
# 初始化创建项目组
|
2021-08-17 17:00:34 +08:00
|
|
|
|
try:
|
|
|
|
|
"""Inits the Myapp application"""
|
|
|
|
|
appbuilder.add_permissions(update_perms=True) # update_perms为true才会检测新权限
|
|
|
|
|
security_manager.sync_role_definitions()
|
2021-11-25 18:04:34 +08:00
|
|
|
|
def add_project(project_type,name,describe,expand={}):
|
|
|
|
|
project = db.session.query(Project).filter_by(name=name).filter_by(type=project_type).first()
|
2021-08-17 17:00:34 +08:00
|
|
|
|
if project is None:
|
|
|
|
|
try:
|
|
|
|
|
project = Project()
|
2021-11-25 18:04:34 +08:00
|
|
|
|
project.type=project_type
|
2021-08-17 17:00:34 +08:00
|
|
|
|
project.name = name
|
|
|
|
|
project.describe=describe
|
|
|
|
|
project.expand=json.dumps(expand,ensure_ascii=False,indent=4)
|
|
|
|
|
db.session.add(project)
|
|
|
|
|
db.session.commit()
|
|
|
|
|
|
|
|
|
|
project_user = Project_User()
|
|
|
|
|
project_user.project=project
|
|
|
|
|
project_user.role = 'creator'
|
|
|
|
|
project_user.user_id=1
|
|
|
|
|
db.session.add(project_user)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add project %s'%name)
|
2021-08-17 17:00:34 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2021-08-17 17:00:34 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 添加一些默认的记录
|
|
|
|
|
add_project('org','推荐中心','推荐项目组')
|
|
|
|
|
add_project('org', '多媒体中心', '多媒体项目组')
|
|
|
|
|
add_project('org', '搜索中心', '搜索项目组')
|
|
|
|
|
add_project('org', '广告中心', '广告项目组')
|
|
|
|
|
add_project('org', 'public', '公共项目组')
|
|
|
|
|
|
|
|
|
|
add_project('job-template', '基础命令', 'python/bash等直接在服务器命令行中执行命令的模板',{"index":1})
|
|
|
|
|
add_project('job-template', '数据导入导出', '集群与用户机器或其他集群之间的数据迁移',{"index":2})
|
2022-08-16 11:10:24 +08:00
|
|
|
|
add_project('job-template', '数据处理', '数据的单机或分布式处理任务,ray/spark/hadoop/volcanojob',{"index":3})
|
2022-05-17 14:57:21 +08:00
|
|
|
|
add_project('job-template', '机器学习', '传统机器学习,lr/决策树/gbdt/xgb/fm等', {"index": 4})
|
2022-08-16 11:10:24 +08:00
|
|
|
|
add_project('job-template', '深度学习', '深度框架训练,tf/pytorch/mxnet/mpi/horovod/kaldi等', {"index": 5})
|
|
|
|
|
add_project('job-template', 'tf分布式', 'tf相关的训练,模型校验,离线预测等功能', {"index": 6})
|
|
|
|
|
add_project('job-template', 'pytorch分布式', 'pytorch相关的训练,模型校验,离线预测等功能', {"index": 7})
|
|
|
|
|
add_project('job-template', 'xgb分布式', 'xgb相关的训练,模型校验,离线预测等功能', {"index": 8})
|
|
|
|
|
add_project('job-template', '模型服务化', '模型服务化部署相关的组件模板', {"index": 9})
|
|
|
|
|
add_project('job-template', '推荐类模板', '推荐领域常用的任务模板', {"index": 10})
|
|
|
|
|
add_project('job-template', '多媒体类模板', '音视频图片文本常用的任务模板', {"index": 11})
|
|
|
|
|
add_project('job-template', '搜索类模板', '向量搜索常用的任务模板', {"index": 12})
|
|
|
|
|
|
2021-08-17 17:00:34 +08:00
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
2021-10-14 17:36:14 +08:00
|
|
|
|
|
2022-08-16 11:10:24 +08:00
|
|
|
|
def create_template(repository_id,project_name,image_name,image_describe,job_template_name,job_template_old_names=[],job_template_describe='',job_template_command='',job_template_args=None,job_template_volume='',job_template_account='',job_template_expand=None,job_template_env='',gitpath=''):
|
2022-02-26 22:36:57 +08:00
|
|
|
|
if not repository_id:
|
|
|
|
|
return
|
|
|
|
|
images = db.session.query(Images).filter_by(name=image_name).first()
|
|
|
|
|
project = db.session.query(Project).filter_by(name=project_name).filter_by(type='job-template').first()
|
2021-10-14 17:36:14 +08:00
|
|
|
|
if images is None and project:
|
|
|
|
|
try:
|
|
|
|
|
images = Images()
|
2022-02-26 22:36:57 +08:00
|
|
|
|
images.name = image_name
|
|
|
|
|
images.describe=image_describe
|
2021-10-14 17:36:14 +08:00
|
|
|
|
images.created_by_fk=1
|
|
|
|
|
images.changed_by_fk=1
|
|
|
|
|
images.project_id=project.id
|
2022-02-26 22:36:57 +08:00
|
|
|
|
images.repository_id=repository_id
|
2022-08-02 16:03:09 +08:00
|
|
|
|
images.gitpath = gitpath
|
2021-10-14 17:36:14 +08:00
|
|
|
|
db.session.add(images)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add images %s' % image_name)
|
2021-10-14 17:36:14 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2021-10-14 17:36:14 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
2022-02-26 22:36:57 +08:00
|
|
|
|
job_template = db.session.query(Job_Template).filter_by(name=job_template_name).first()
|
2022-08-16 11:10:24 +08:00
|
|
|
|
if not job_template:
|
|
|
|
|
for old_name in job_template_old_names:
|
|
|
|
|
job_template = db.session.query(Job_Template).filter_by(name=old_name).first()
|
|
|
|
|
if job_template:
|
|
|
|
|
break
|
|
|
|
|
|
2022-02-26 22:36:57 +08:00
|
|
|
|
project = db.session.query(Project).filter_by(name=project_name).filter_by(type='job-template').first()
|
2022-05-31 14:16:55 +08:00
|
|
|
|
if project and images.id:
|
|
|
|
|
if job_template is None:
|
|
|
|
|
try:
|
|
|
|
|
job_template = Job_Template()
|
2022-06-04 17:38:31 +08:00
|
|
|
|
job_template.name = job_template_name.replace('_','-')
|
2022-05-31 14:16:55 +08:00
|
|
|
|
job_template.describe=job_template_describe
|
2022-08-02 16:03:09 +08:00
|
|
|
|
job_template.entrypoint=job_template_command
|
|
|
|
|
job_template.volume_mount=job_template_volume
|
|
|
|
|
job_template.accounts=job_template_account
|
2022-08-16 11:10:24 +08:00
|
|
|
|
job_template_expand['source']="github"
|
2022-05-31 14:16:55 +08:00
|
|
|
|
job_template.expand = json.dumps(job_template_expand,indent=4,ensure_ascii=False) if job_template_expand else '{}'
|
|
|
|
|
job_template.created_by_fk=1
|
|
|
|
|
job_template.changed_by_fk=1
|
|
|
|
|
job_template.project_id=project.id
|
|
|
|
|
job_template.images_id=images.id
|
|
|
|
|
job_template.version='Release'
|
|
|
|
|
job_template.env=job_template_env
|
|
|
|
|
job_template.args=json.dumps(job_template_args,indent=4,ensure_ascii=False) if job_template_args else '{}'
|
|
|
|
|
db.session.add(job_template)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add job_template %s' % job_template_name.replace('_','-'))
|
2022-05-31 14:16:55 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2022-05-31 14:16:55 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
else:
|
|
|
|
|
try:
|
2022-08-18 16:15:01 +08:00
|
|
|
|
job_template.name = job_template_name.replace('_','-')
|
2022-05-31 14:16:55 +08:00
|
|
|
|
job_template.describe = job_template_describe
|
2022-08-02 16:03:09 +08:00
|
|
|
|
job_template.entrypoint = job_template_command
|
|
|
|
|
job_template.volume_mount = job_template_volume
|
|
|
|
|
job_template.accounts = job_template_account
|
2022-08-16 11:10:24 +08:00
|
|
|
|
job_template_expand['source'] = "github"
|
2022-05-31 14:16:55 +08:00
|
|
|
|
job_template.expand = json.dumps(job_template_expand, indent=4,ensure_ascii=False) if job_template_expand else '{}'
|
|
|
|
|
job_template.created_by_fk = 1
|
|
|
|
|
job_template.changed_by_fk = 1
|
|
|
|
|
job_template.project_id = project.id
|
|
|
|
|
job_template.images_id = images.id
|
|
|
|
|
job_template.version = 'Release'
|
|
|
|
|
job_template.env = job_template_env
|
2022-06-04 17:38:31 +08:00
|
|
|
|
job_template.args = json.dumps(job_template_args, indent=4,ensure_ascii=False) if job_template_args else '{}'
|
2022-05-31 14:16:55 +08:00
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('update job_template %s' % job_template_name.replace('_', '-'))
|
2022-05-31 14:16:55 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2022-05-31 14:16:55 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
2021-10-14 17:36:14 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-02-26 22:36:57 +08:00
|
|
|
|
# 初始化创建仓库镜像模板任务流
|
|
|
|
|
try:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print('begin init repository')
|
2022-02-26 22:36:57 +08:00
|
|
|
|
repository = db.session.query(Repository).filter_by(name='hubsecret').first()
|
|
|
|
|
if repository is None:
|
|
|
|
|
try:
|
|
|
|
|
repository = Repository()
|
|
|
|
|
repository.name = 'hubsecret'
|
|
|
|
|
repository.server='registry.docker-cn.com'
|
|
|
|
|
repository.user = 'yourname'
|
|
|
|
|
repository.password = 'yourpassword'
|
|
|
|
|
repository.hubsecret = 'hubsecret'
|
|
|
|
|
repository.created_by_fk=1
|
|
|
|
|
repository.changed_by_fk=1
|
|
|
|
|
db.session.add(repository)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add repository hubsecret')
|
2022-02-26 22:36:57 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2022-02-26 22:36:57 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print('begin init job_templates')
|
2022-06-04 17:38:31 +08:00
|
|
|
|
job_templates = json.load(open('myapp/init-job-template.json',mode='r'))
|
|
|
|
|
for job_template_name in job_templates:
|
|
|
|
|
job_template = job_templates[job_template_name]
|
|
|
|
|
job_template['repository_id']=repository.id
|
|
|
|
|
create_template(**job_template)
|
2022-05-17 14:57:21 +08:00
|
|
|
|
|
2022-05-22 22:05:10 +08:00
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
2022-05-17 14:57:21 +08:00
|
|
|
|
|
|
|
|
|
|
2022-05-25 17:22:11 +08:00
|
|
|
|
# 创建demo pipeline
|
2022-08-22 13:29:21 +08:00
|
|
|
|
# @pysnooper.snoop()
|
2022-05-25 17:22:11 +08:00
|
|
|
|
def create_pipeline(tasks,pipeline):
|
2022-06-04 17:38:31 +08:00
|
|
|
|
# 如果项目组或者task的模板不存在就丢失
|
|
|
|
|
org_project = db.session.query(Project).filter_by(name=pipeline['project']).filter_by(type='org').first()
|
|
|
|
|
if not org_project:
|
|
|
|
|
return
|
|
|
|
|
for task in tasks:
|
|
|
|
|
job_template = db.session.query(Job_Template).filter_by(name=task['job_templete']).first()
|
|
|
|
|
if not job_template:
|
|
|
|
|
return
|
|
|
|
|
|
2022-05-25 17:22:11 +08:00
|
|
|
|
|
|
|
|
|
# 创建pipeline
|
|
|
|
|
pipeline_model = db.session.query(Pipeline).filter_by(name=pipeline['name']).first()
|
2022-06-04 17:38:31 +08:00
|
|
|
|
if pipeline_model is None:
|
|
|
|
|
try:
|
|
|
|
|
pipeline_model = Pipeline()
|
|
|
|
|
pipeline_model.name = pipeline['name']
|
|
|
|
|
pipeline_model.describe = pipeline['describe']
|
|
|
|
|
pipeline_model.dag_json=json.dumps(pipeline['dag_json'],indent=4,ensure_ascii=False).replace('_','-')
|
|
|
|
|
pipeline_model.created_by_fk = 1
|
|
|
|
|
pipeline_model.changed_by_fk = 1
|
|
|
|
|
pipeline_model.project_id = org_project.id
|
2022-08-23 16:48:47 +08:00
|
|
|
|
pipeline_model.parameter = json.dumps(pipeline.get('parameter',{}),indent=4,ensure_ascii=False)
|
2022-06-04 17:38:31 +08:00
|
|
|
|
db.session.add(pipeline_model)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add pipeline %s' % pipeline['name'])
|
2022-06-04 17:38:31 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2022-06-04 17:38:31 +08:00
|
|
|
|
db.session.rollback()
|
|
|
|
|
else:
|
|
|
|
|
pipeline_model.describe = pipeline['describe']
|
|
|
|
|
pipeline_model.dag_json = json.dumps(pipeline['dag_json'],indent=4,ensure_ascii=False).replace('_', '-')
|
|
|
|
|
pipeline_model.created_by_fk = 1
|
|
|
|
|
pipeline_model.changed_by_fk = 1
|
|
|
|
|
pipeline_model.project_id = org_project.id
|
|
|
|
|
pipeline_model.parameter = json.dumps(pipeline.get('parameter', {}))
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('update pipeline %s' % pipeline['name'])
|
2022-06-04 17:38:31 +08:00
|
|
|
|
db.session.commit()
|
|
|
|
|
|
2022-05-25 17:22:11 +08:00
|
|
|
|
|
|
|
|
|
# 创建task
|
|
|
|
|
for task in tasks:
|
|
|
|
|
task_model = db.session.query(Task).filter_by(name=task['name']).filter_by(pipeline_id=pipeline_model.id).first()
|
|
|
|
|
job_template = db.session.query(Job_Template).filter_by(name=task['job_templete']).first()
|
|
|
|
|
if task_model is None and job_template:
|
|
|
|
|
try:
|
|
|
|
|
task_model = Task()
|
2022-06-04 17:38:31 +08:00
|
|
|
|
task_model.name = task['name'].replace('_','-')
|
2022-05-25 17:22:11 +08:00
|
|
|
|
task_model.label = task['label']
|
2022-06-04 17:38:31 +08:00
|
|
|
|
task_model.args = json.dumps(task['args'],indent=4,ensure_ascii=False)
|
|
|
|
|
task_model.volume_mount = task.get('volume_mount','')
|
|
|
|
|
task_model.resource_memory = task.get('resource_memory','2G')
|
|
|
|
|
task_model.resource_cpu = task.get('resource_cpu','2')
|
|
|
|
|
task_model.resource_gpu = task.get('resource_gpu','0')
|
2022-05-25 17:22:11 +08:00
|
|
|
|
task_model.created_by_fk = 1
|
|
|
|
|
task_model.changed_by_fk = 1
|
|
|
|
|
task_model.pipeline_id = pipeline_model.id
|
|
|
|
|
task_model.job_template_id = job_template.id
|
|
|
|
|
db.session.add(task_model)
|
|
|
|
|
db.session.commit()
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('add task %s' % task['name'])
|
2022-05-25 17:22:11 +08:00
|
|
|
|
except Exception as e:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print(e)
|
2022-05-25 17:22:11 +08:00
|
|
|
|
db.session.rollback()
|
2022-06-04 17:38:31 +08:00
|
|
|
|
else:
|
|
|
|
|
task_model.label = task['label']
|
|
|
|
|
task_model.args = json.dumps(task['args'],indent=4,ensure_ascii=False)
|
|
|
|
|
task_model.volume_mount = task.get('volume_mount', '')
|
2022-06-05 17:16:36 +08:00
|
|
|
|
task_model.node_selector = task.get('node_selector', 'cpu=true,train=true,org=public')
|
|
|
|
|
task_model.retry = int(task.get('retry', 0))
|
|
|
|
|
task_model.timeout = int(task.get('timeout', 0))
|
2022-06-04 17:38:31 +08:00
|
|
|
|
task_model.resource_memory = task.get('resource_memory', '2G')
|
|
|
|
|
task_model.resource_cpu = task.get('resource_cpu', '2')
|
|
|
|
|
task_model.resource_gpu = task.get('resource_gpu', '0')
|
|
|
|
|
task_model.created_by_fk = 1
|
|
|
|
|
task_model.changed_by_fk = 1
|
|
|
|
|
task_model.pipeline_id = pipeline_model.id
|
|
|
|
|
task_model.job_template_id = job_template.id
|
2022-07-17 18:38:49 +08:00
|
|
|
|
print('update task %s' % task['name'])
|
2022-06-04 17:38:31 +08:00
|
|
|
|
db.session.commit()
|
|
|
|
|
|
2022-06-05 17:16:36 +08:00
|
|
|
|
# 修正pipeline
|
|
|
|
|
pipeline_model.dag_json = pipeline_model.fix_dag_json() # 修正 dag_json
|
|
|
|
|
pipeline_model.expand = json.dumps(pipeline_model.fix_expand(), indent=4, ensure_ascii=False) # 修正 前端expand字段缺失
|
|
|
|
|
pipeline_model.expand = json.dumps(pipeline_model.fix_position(), indent=4, ensure_ascii=False) # 修正 节点中心位置到视图中间
|
|
|
|
|
db.session.commit()
|
|
|
|
|
# 自动排版
|
|
|
|
|
db_tasks = pipeline_model.get_tasks(db.session)
|
|
|
|
|
if db_tasks:
|
|
|
|
|
try:
|
|
|
|
|
tasks={}
|
|
|
|
|
for task in db_tasks:
|
|
|
|
|
tasks[task.name]=task.to_json()
|
|
|
|
|
|
|
|
|
|
from myapp.utils import core
|
|
|
|
|
expand = core.fix_task_position(pipeline_model.to_json(),tasks,json.loads(pipeline_model.expand))
|
|
|
|
|
pipeline_model.expand=json.dumps(expand,indent=4,ensure_ascii=False)
|
|
|
|
|
db.session.commit()
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
2022-05-25 17:22:11 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
2022-08-02 16:03:09 +08:00
|
|
|
|
print('begin init pipeline')
|
2022-06-04 17:38:31 +08:00
|
|
|
|
pipelines = json.load(open('myapp/init-pipeline.json',mode='r'))
|
|
|
|
|
for pipeline_name in pipelines:
|
|
|
|
|
pipeline = pipelines[pipeline_name]['pipeline']
|
|
|
|
|
tasks = pipelines[pipeline_name]['tasks']
|
|
|
|
|
create_pipeline(pipeline=pipeline,tasks=tasks)
|
2022-05-25 17:22:11 +08:00
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
|
|
|
2022-08-02 16:03:09 +08:00
|
|
|
|
# 添加 demo 推理 服务
|
2022-08-27 22:01:28 +08:00
|
|
|
|
def create_dataset(**kwargs):
|
|
|
|
|
dataset = db.session.query(Dataset).filter_by(name=kwargs['name']).first()
|
2022-08-02 16:03:09 +08:00
|
|
|
|
if not dataset:
|
|
|
|
|
try:
|
|
|
|
|
dataset = Dataset()
|
2022-08-27 22:01:28 +08:00
|
|
|
|
dataset.name = kwargs['name']
|
|
|
|
|
dataset.field=kwargs.get('field','')
|
|
|
|
|
dataset.label=kwargs.get('label','')
|
|
|
|
|
dataset.status=kwargs.get('status','')
|
|
|
|
|
dataset.describe=kwargs.get('describe','')
|
|
|
|
|
dataset.url = kwargs.get('url','')
|
|
|
|
|
dataset.source=kwargs.get('source','')
|
|
|
|
|
dataset.industry=kwargs.get('industry','')
|
|
|
|
|
dataset.source_type=kwargs.get('source_type','')
|
|
|
|
|
dataset.file_type=kwargs.get('file_type','')
|
|
|
|
|
dataset.research=kwargs.get('research','')
|
|
|
|
|
dataset.usage=kwargs.get('usage','')
|
|
|
|
|
dataset.years = kwargs.get('years', '')
|
|
|
|
|
dataset.path = kwargs.get('path', '')
|
|
|
|
|
dataset.duration = kwargs.get('duration', '')
|
|
|
|
|
dataset.entries_num = kwargs.get('entries_num', '')
|
|
|
|
|
dataset.price = kwargs.get('price', '')
|
|
|
|
|
dataset.icon = kwargs.get('icon', '')
|
|
|
|
|
dataset.storage_class=kwargs.get('storage_class','')
|
|
|
|
|
dataset.storage_size = kwargs.get('storage_size','')
|
|
|
|
|
dataset.download_url = kwargs.get('download_url','')
|
|
|
|
|
dataset.owner = 'admin'
|
2022-08-02 16:03:09 +08:00
|
|
|
|
dataset.created_by_fk=1
|
|
|
|
|
dataset.changed_by_fk=1
|
|
|
|
|
db.session.add(dataset)
|
|
|
|
|
db.session.commit()
|
2022-08-27 22:01:28 +08:00
|
|
|
|
print('add dataset %s' % kwargs.get('name',''))
|
2022-08-02 16:03:09 +08:00
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
db.session.rollback()
|
|
|
|
|
try:
|
|
|
|
|
print('begin init dataset')
|
|
|
|
|
datasets = db.session.query(Dataset).all() # 空白数据集才初始化
|
|
|
|
|
if not datasets:
|
|
|
|
|
import csv
|
|
|
|
|
csv_reader = csv.reader(open('myapp/init-dataset.csv', mode='r', encoding='utf-8-sig'))
|
|
|
|
|
header = None
|
|
|
|
|
for line in csv_reader:
|
|
|
|
|
if not header:
|
|
|
|
|
header = line
|
|
|
|
|
continue
|
|
|
|
|
data = dict(zip(header, line))
|
|
|
|
|
create_dataset(**data)
|
|
|
|
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 添加 示例 模型
|
|
|
|
|
# @pysnooper.snoop()
|
|
|
|
|
def create_train_model(name,describe,path,project_name,version,framework,api_type):
|
|
|
|
|
train_model = db.session.query(Training_Model).filter_by(name=name).filter_by(version=version).filter_by(framework=framework).first()
|
|
|
|
|
project = db.session.query(Project).filter_by(name=project_name).filter_by(type='org').first()
|
|
|
|
|
if not train_model and project:
|
|
|
|
|
try:
|
|
|
|
|
train_model = Training_Model()
|
|
|
|
|
train_model.name = name
|
|
|
|
|
train_model.describe=describe
|
|
|
|
|
train_model.path=path
|
|
|
|
|
train_model.project_id=project.id
|
|
|
|
|
train_model.describe=describe
|
|
|
|
|
train_model.version = version
|
|
|
|
|
train_model.framework=framework
|
|
|
|
|
train_model.api_type=api_type
|
|
|
|
|
train_model.created_by_fk=1
|
|
|
|
|
train_model.changed_by_fk=1
|
|
|
|
|
train_model.run_id='random_run_id_'+uuid.uuid4().hex[:32]
|
|
|
|
|
db.session.add(train_model)
|
|
|
|
|
db.session.commit()
|
|
|
|
|
print('add train model %s' % name)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
print('begin init train_models')
|
|
|
|
|
train_models = json.load(open('myapp/init-train-model.json',mode='r'))
|
|
|
|
|
for train_model_name in train_models:
|
|
|
|
|
train_model = train_models[train_model_name]
|
|
|
|
|
create_train_model(**train_model)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 添加demo 服务
|
2022-08-22 13:29:21 +08:00
|
|
|
|
# @pysnooper.snoop()
|
|
|
|
|
def create_service(project_name,service_name,service_describe,image_name,command,env,resource_memory='2G',resource_cpu='2',resource_gpu='0',ports='80',volume_mount='kubeflow-user-workspace(pvc):/mnt',expand={}):
|
2022-08-02 16:03:09 +08:00
|
|
|
|
service = db.session.query(Service).filter_by(name=service_name).first()
|
|
|
|
|
project = db.session.query(Project).filter_by(name=project_name).filter_by(type='org').first()
|
|
|
|
|
if service is None and project:
|
|
|
|
|
try:
|
|
|
|
|
service = Service()
|
|
|
|
|
service.name = service_name.replace('_','-')
|
|
|
|
|
service.label=service_describe
|
|
|
|
|
service.created_by_fk=1
|
|
|
|
|
service.changed_by_fk=1
|
|
|
|
|
service.project_id=project.id
|
|
|
|
|
service.images=image_name
|
|
|
|
|
service.command = command
|
|
|
|
|
service.resource_memory=resource_memory
|
|
|
|
|
service.resource_cpu=resource_cpu
|
|
|
|
|
service.resource_gpu=resource_gpu
|
|
|
|
|
service.env='\n'.join([x.strip() for x in env.split('\n') if x.split()])
|
|
|
|
|
service.ports = ports
|
|
|
|
|
service.volume_mount=volume_mount
|
2022-08-22 13:29:21 +08:00
|
|
|
|
service.expand = json.dumps(expand, indent=4, ensure_ascii=False)
|
2022-08-02 16:03:09 +08:00
|
|
|
|
db.session.add(service)
|
|
|
|
|
db.session.commit()
|
|
|
|
|
print('add service %s'%service_name)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
print('begin init services')
|
|
|
|
|
services = json.load(open('myapp/init-service.json',mode='r'))
|
|
|
|
|
for service_name in services:
|
|
|
|
|
service = services[service_name]
|
|
|
|
|
create_service(**service)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 添加 demo 推理 服务
|
2022-08-22 13:29:21 +08:00
|
|
|
|
# @pysnooper.snoop()
|
|
|
|
|
def create_inference(project_name,service_name,service_describe,image_name,command,env,model_name,workdir='',model_version='',model_path='',service_type='serving',resource_memory='2G',resource_cpu='2',resource_gpu='0',ports='80',volume_mount='kubeflow-user-workspace(pvc):/mnt',metrics='',health='',inference_config='',expand={}):
|
2022-08-02 16:03:09 +08:00
|
|
|
|
service = db.session.query(InferenceService).filter_by(name=service_name).first()
|
|
|
|
|
project = db.session.query(Project).filter_by(name=project_name).filter_by(type='org').first()
|
|
|
|
|
if service is None and project:
|
|
|
|
|
try:
|
|
|
|
|
service = InferenceService()
|
|
|
|
|
service.name = service_name.replace('_','-')
|
|
|
|
|
service.label=service_describe
|
|
|
|
|
service.service_type=service_type
|
|
|
|
|
service.model_name=model_name
|
|
|
|
|
service.model_version=model_version if model_version else datetime.now().strftime('v%Y.%m.%d.1')
|
|
|
|
|
service.model_path = model_path
|
|
|
|
|
service.created_by_fk=1
|
|
|
|
|
service.changed_by_fk=1
|
|
|
|
|
service.project_id=project.id
|
|
|
|
|
service.images=image_name
|
|
|
|
|
service.resource_memory=resource_memory
|
|
|
|
|
service.resource_cpu=resource_cpu
|
|
|
|
|
service.resource_gpu = resource_gpu
|
|
|
|
|
service.working_dir=workdir
|
|
|
|
|
service.command = command
|
|
|
|
|
service.inference_config = inference_config
|
|
|
|
|
service.env='\n'.join([x.strip() for x in env.split('\n') if x.split()])
|
|
|
|
|
service.ports = ports
|
|
|
|
|
service.volume_mount=volume_mount
|
|
|
|
|
service.metrics=metrics
|
|
|
|
|
service.health=health
|
2022-08-22 13:29:21 +08:00
|
|
|
|
service.expand = json.dumps(expand,indent=4,ensure_ascii=False)
|
2022-08-02 16:03:09 +08:00
|
|
|
|
|
|
|
|
|
from myapp.views.view_inferenceserving import InferenceService_ModelView_base
|
|
|
|
|
inference_class = InferenceService_ModelView_base()
|
|
|
|
|
inference_class.src_item_json = {}
|
|
|
|
|
inference_class.pre_add(service)
|
|
|
|
|
|
|
|
|
|
db.session.add(service)
|
|
|
|
|
db.session.commit()
|
|
|
|
|
print('add inference %s' % service_name)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
db.session.rollback()
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
print('begin init inferences')
|
|
|
|
|
inferences = json.load(open('myapp/init-inference.json',mode='r'))
|
|
|
|
|
for inference_name in inferences:
|
|
|
|
|
inference = inferences[inference_name]
|
|
|
|
|
create_inference(**inference)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|