# taskflow **Repository Path**: myw31415926/taskflow ## Basic Information - **Project Name**: taskflow - **Description**: Linux 下任务管理可视化系统 - **Primary Language**: C++ - **License**: BSD-3-Clause - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2023-11-05 - **Last Updated**: 2023-12-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: Qt, TaskFlow ## README # taskflow Linux 下任务管理可视化系统。 # taskflow 目录结构 * Server 端(非GUI工程) * 收集每个客户端任务执行的状态,避免多客户端同时打开一个任务(都有可执行权限),只支持单个执行,多个查看。 * 将task状态推送给其他可以查看的client(这些client不可操作)。 * 将task执行结果保存到本地数据库中(sqlite),先暂定所有客户端都可以查看(先不做用户管理)。 * Client 端(GUI工程) * 管理任务,一个任务一个工程,任务使用json字符串描述,包含一系列的子任务(target),每个子任务包含: ```json { "name": "任务名称", "in": ["输入文件列表"], "out": ["输出文件列表"], "cmd": "执行命令或脚本", "dir": "执行目录", "prev": ["任务直接前驱列表"], "expected": "任务预期执行时间(毫秒)", "info": {"任务信息"} } ``` * 任务执行完成后,保存任务结果,下次打开,直接定位到上一次执行的镜像(可以一键重置) * 每个工程对应一个task_agent进程,执行完成后,task_agent进程退出 * 每个子任务都有start,stop,reset三个操作 * 客户端保存每个任务的执行状态,定时更新,并将状态发送给服务端。owner用户可以操作,非owner用户只能看,不能操作 * 子任务使用矩形框,输入输出使用椭圆框 * 颜色: * 紫色:默认/文件不存在; * 绿色:任务成功/文件存在; * 红色:任务失败; * 黄色:正在执行; * 蓝色:等待执行 * Agent 代理(非GUI工程) * 负责执行一个任务,返回每个子任务的执行结果(标准输出和内部输出) * 不存在依赖关系的子任务可以并行执行 * 执行完后,agent退出 * 模拟client执行某些操作,如启动子任务(target) # taskflow 通信流程 ![new_flow](doc/new_flow.png) #### 介绍 Linux 下任务管理可视化系统 #### 软件架构 软件架构说明 #### 安装教程 1. xxxx 2. xxxx 3. xxxx #### 使用说明 1. xxxx 2. xxxx 3. xxxx #### 参与贡献 1. Fork 本仓库 2. 新建 Feat_xxx 分支 3. 提交代码 4. 新建 Pull Request #### 特技 1. 使用 Readme\_XXX.md 来支持不同的语言,例如 Readme\_en.md, Readme\_zh.md 2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com) 3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目 4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目 5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help) 6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)