diff --git a/application/admin/controller/Queue.php b/application/admin/controller/Queue.php index cb5662d73..a6d811362 100644 --- a/application/admin/controller/Queue.php +++ b/application/admin/controller/Queue.php @@ -16,7 +16,9 @@ namespace app\admin\controller; use library\Controller; +use library\service\ProcessService; use think\Console; +use think\Db; use think\exception\HttpResponseException; /** @@ -45,13 +47,14 @@ class Queue extends Controller public function index() { if (session('user.username') === 'admin') try { - $this->cmd = 'php ' . env('root_path') . 'think xtask:start'; $this->message = Console::call('xtask:state')->fetch(); + $this->command = ProcessService::instance()->think('xtask:start'); + $this->listen = preg_match('/process.*?\d+.*?running/', $this->message, $attr); } catch (\Exception $exception) { $this->message = $exception->getMessage(); } $this->title = '系统任务管理'; - $this->iswin = PATH_SEPARATOR === ';'; + $this->iswin = ProcessService::instance()->iswin(); $query = $this->_query($this->table)->dateBetween('create_at,start_at,end_at'); $query->like('title,preload')->equal('status')->order('id desc')->page(); } @@ -71,10 +74,15 @@ class Queue extends Controller * WIN开始监听任务 * @auth true */ - public function processStart() + public function start() { try { - $this->success(nl2br(Console::call('xtask:start')->fetch())); + $message = nl2br(Console::call('xtask:start')->fetch()); + if (preg_match('/process.*?\d+/', $message, $attr)) { + $this->success('任务监听主进程启动成功!'); + } else { + $this->error($message); + } } catch (HttpResponseException $exception) { throw $exception; } catch (\Exception $e) { @@ -86,10 +94,17 @@ class Queue extends Controller * WIN停止监听任务 * @auth true */ - public function processStop() + public function stop() { try { - $this->success(nl2br(Console::call('xtask:stop')->fetch())); + $message = nl2br(Console::call('xtask:stop')->fetch()); + if (stripos($message, 'succeeded')) { + $this->success('停止任务监听主进程成功!'); + } elseif (stripos($message, 'finish')) { + $this->success('没有找到需要停止的进程!'); + } else { + $this->error($message); + } } catch (HttpResponseException $exception) { throw $exception; } catch (\Exception $e) { @@ -97,6 +112,23 @@ class Queue extends Controller } } + /** + * 清理3天前的记录 + * @auth true + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function clear() + { + $map = [['time', '<', strtotime('-3days')]]; + $result = Db::name($this->table)->where($map)->delete(); + if ($result !== false) { + $this->success('成功清理3天前的任务记录!'); + } else { + $this->error('清理3天前的任务记录失败!'); + } + } + /** * 删除系统任务 * @auth true diff --git a/application/admin/view/config/info.html b/application/admin/view/config/info.html index 16abc472b..4807d8766 100644 --- a/application/admin/view/config/info.html +++ b/application/admin/view/config/info.html @@ -1,14 +1,15 @@ {extend name="main"} -{block name="content"} +{block name="button"} {if auth('config')} -
- 系统参数配置: - 修改系统配置 -
+修改系统配置 {/if} +{/block} + +{block name="content"} +
文件存储引擎: {foreach ['local'=>'本地服务器存储','qiniu'=>'七牛云对象存储','oss'=>'阿里云OSS存储'] as $k=>$v} diff --git a/application/admin/view/queue/index.html b/application/admin/view/queue/index.html index abd828b21..1b543e805 100644 --- a/application/admin/view/queue/index.html +++ b/application/admin/view/queue/index.html @@ -2,16 +2,20 @@ {block name="button"} +{if auth("start") && $iswin} + +{/if} + +{if auth("stop") && $iswin} + +{/if} + {if auth("remove")} - + {/if} -{if auth("processstart") && $iswin} - -{/if} - -{if auth("processstop") && $iswin} - +{if auth("clear")} + {/if} {/block} @@ -44,35 +48,40 @@ 任务指令:{$vo.preload} - 创建时间:{$vo.create_at|format_datetime} / {$vo.time|format_datetime}
- 执行时间:{$vo.start_at|format_datetime} / {$vo.end_at|format_datetime} + 计划时间:{$vo.time|format_datetime} {if isset($vo.exec_pid) and $vo.exec_pid>0}( 进程 {$vo.exec_pid|default='-'} ){/if}
+ {if $vo.status eq 3 or $vo.status eq 4} + 执行时间:{$vo.start_at|format_datetime}( 耗时 {:sprintf("%.4f",strtotime($vo.end_at)-strtotime($vo.start_at))} 秒 ) + {elseif $vo.status eq 2} 开始时间:{$vo.start_at|format_datetime} + {else} 创建时间:{$vo.create_at|format_datetime} {/if} - 任务状态:{eq name='vo.double' value='1'} - - {else} - - {/eq} +
+ {eq name='vo.double' value='1'} + + {else} + + {/eq} - {eq name='vo.status' value='1'} - 待处理 - {elseif $vo.status eq 2} - 处理中 - {elseif $vo.status eq 3} - 处理完成 - {elseif $vo.status eq 4} - 处理失败 - - - - {/eq} - {if auth("admin/queue/remove") and in_array($vo.status,[1,3,4])} - - - - {/if} -
- 状态描述:{$vo.desc|raw|default="没有获取到状态描述"} + {eq name='vo.status' value='1'} + 待处理 + {elseif $vo.status eq 2} + 处理中 + {elseif $vo.status eq 3} + 处理完成 + {elseif $vo.status eq 4} + 处理失败 + + + + {/eq} + + {if auth("admin/queue/remove") and in_array($vo.status,[1,3,4])} + + + + {/if} +
+
{$vo.desc|raw|default="没有获取到状态描述"}
{/foreach} diff --git a/application/admin/view/queue/index_search.html b/application/admin/view/queue/index_search.html index 182e1ff2a..114cca657 100644 --- a/application/admin/view/queue/index_search.html +++ b/application/admin/view/queue/index_search.html @@ -1,14 +1,19 @@ {if session('user.username') eq 'admin'} -
- 进程守护 +
+ 守护状态
-

当前消息队列守护进程运行状态

- {$message|raw|default='--'} -

配置定时任务来检查并启动进程(建议每分钟执行)

- {$cmd|default='--'} +

守护进程运行状态

+ {if $listen} + {$message|raw|default='--'} + {else} + {$message|raw|default='--'} + {/if} +

配置定时任务来检查并启动进程(建议每分钟执行)

+

{$command|default='--'}

{/if} +
条件搜索