流程一直处于Running状态,应该怎么停止?

概述

我们有遇到这种情况:可能由于某些原因,流程发起后一直处于Running状态,然后我们想Stop掉这些出问题的流程,这个时候你在Workspace里面进行操作,这个操作是不可能完成的,Workspace也会一直处于Loading状态。

这种情况下,您唯一的选择就是通过更新K2 Database来停止这些流程。

在执行这些操作之前,应该尝试通过Workspace停止流程实例,只有在Workspace处理不了的时候,才去更新K2 Database

在执行操作之前,请熟悉每个状态的含义,这些状态可以在[ServerLog].[Status]表找到,它的结构如下:

0 - Error

1 - Running

2 - Active

3 - Completed

4 - Stopped

5 - Deleted

Running状态的流程实例通常意味着K2服务器仍然在尝试处理有关WF已构建的操作,此状态不需要用户输入,K2正在尝试处理待办生成前的数据。

通过更新 K2 数据库来停止进程的步骤

在执行以下步骤之前, 请确保 K2 数据库已经备份,安全第一!

通常有两种情况下, 您将停止进程实例:

  1. 只是需要停止某些实例, 但它不会让用户通过Workspace(将状态设置为停止4 - Stopped)
  2. 通过调查, 您发现运行的实例会导致 K2 产品的不良行为。(将状态设置为暂停11 - Paused)

方案1

  1. 标识需要停止的运行实例
SELECT * FROM [K2].[Server].[ProcInst]
WHERE Status = 1
  1. 确定是否需要停止所有这些进程实例, 或仅对其中的某个子集进行停止。
/**为某一流程运行实例。可以从[Server].[ProcSet]表中抓取进程 ID**/
SELECT * FROM [K2].[Server].[ProcInst]
WHERE ProcID = 3
  1. 运行查询, 将所需的流程实例更新为停止状态, 例如:
/**更新正在运行状态中的所有流程实例为停止状态 4 - Stopped**/
UPDATE [K2].[Server].[ProcInst]
SET Status = 4, ServerID = 0
WHERE Status = 1
  1. 现在应该能在过Workspace看到这些流程实例已经停止,也可以单独启动一个测试或删除它们。

如果您试图更新数据库中的状态而不将Server ID设为0,则状态将自动更新为1(运行)。ServID=1指示K2服务仍在这个进程上运行。设置ServID=0将告诉K2服务不再使用此服务。

方案2

  1. 首先计算出如果没有完成的话,有多少个运行实例:
SELECT * FROM [K2].[Server].[ProcInst]
WHERE Status = 1
  1. 确定是否需要停止所有这些过程实例,或者仅仅是其中的一个子集。
/**为某一流程运行实例。可以从[Server].[ProcSet]表中抓取进程 ID**/
SELECT * FROM [K2].[Server].[ProcInst]
WHERE ProcID = 3
  1. 一旦您建立了 ProcInst 表中的哪些条目需要更新, 我们需要构建更新查询脚本:
/**更新正在运行状态中的所有流程实例为停止状态 11 - Paused**/
UPDATE [K2].[Server].[ProcInst]
SET Status = 11, ServerID = 0
WHERE Status = 1
  1. 现在启动SQL Management Studio, 在SQL Management Studio上运行上面构建的更新查询脚本。
  2. 运行更新查询并确认状态列(Status)更新为 11。

在方案2中,我们将状态列更新为11,而不是停止4。提供11的ID提供多种好处:

  1. 因为它是K2不期望的状态(11),K2服务会把它忽略掉,不会当做流程实例,甚至不会注意到它存在;因此,没有任何操作(action takes)发生在它上面;11不是特别需要的,你可以提供任何不被用作状态的数字,它也会做同样的事情(例如,你可以把它更新为666,如果你觉得有意义的话;我把它保持为11,因为这意味着它以前是1 - Running
  2. 将进程置于Paused状态后,将不会使用K2资源;如果您需要再次启动流程实例,可以将其更新为1,并且它将很快从上次更新到11的中断位置被拾起;请记住,已完成(completed)的实例无法再次启动。
  3. 如果您有一个可疑的进程,将状态设置为11将在将来帮助您,因为您可以获得在K2服务处于更好状态之后需要检查的ProcInst ID列表。然后你就可以弄明白他们为什么会跑;请记住,因为它们是状态11,客户将无法通过K2 Management/K2 Workspace(Legacy)看到它们,此过程仅在您检查支持时才保留选项。

流程一直处于Running状态,应该怎么停止?的更多相关文章

  1. kubernetes创建yaml,pod服务一直处于 ContainerCreating状态的原因查找与解决

    最近刚刚入手研究kubernetes,运行容器的时候,发现一直处于ContainerCreating状态,悲了个催,刚入手就遇到了点麻烦,下面来讲讲如何查找问题及解决的 运行容器命令: kubectl ...

  2. 生活实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决?

    2018-01-02 实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决? 今天我翻腾出自己的kindle,好久没用了,屏幕一直是一个电池状态,充电头+线充了2个钟头,按电源键木有反应,也是 ...

  3. 使用kubernetes创建容器一直处于ContainerCreating状态的原因查找与解决

    运行容器的时候,发现一直处于ContainerCreating状态,悲了个催,刚入手就遇到了点麻烦,下面来讲讲如何查找问题及解决的 运行容器命令: [root@master- ~]# kubectl ...

  4. bash 统计在线时长最长的十个玩/统计一天内一直处于不活跃状态的玩家的百分比

    1.某游戏的客户端每隔5分钟会向服务端报告一次玩家的账户积分,如果两次报告的时间间隔不大于5分钟,认为该玩家在这5分钟内在线,假设报告数据的格式如下: IP                   Dat ...

  5. 为什么JAVA线程中没有Running状态?

    面试官问:为什么 Java 线程没有 Running 状态?我懵了 —— 转  芋道源码 什么是 RUNNABLE? 与传统的ready状态的区别 与传统的running状态的区别 当I/O阻塞时 如 ...

  6. 【原创】大叔经验分享(70)marathon重启app后一直处于waiting状态

    marathon重启app后一直处于waiting状态,查看marathon日志 # journalctl -u marathon -f 有如下日志: Jun 14 12:58:38 DataOne- ...

  7. 为什么 Java 线程没有 Running 状态?

    Java虚拟机层面所暴露给我们的状态,与操作系统底层的线程状态是两个不同层面的事.具体而言,这里说的 Java 线程状态均来自于 Thread 类下的 State 这一内部枚举类中所定义的状态: 什么 ...

  8. k8s删除namespace一直处于terminating状态

    k8s删除namespace一直处于terminating状态 当遇到删除ns是一直处于terminating情况可以用调k8s api进行删除. 1.创建api proxy. [root@node1 ...

  9. kubernetes删除pod,pod一直处于Terminating状态

    删除pod,pod一直处于Terminating状态 [root@yxz-cluster01 deploy_yaml]# kubectl get pod -n yunanbao NAME READY ...

随机推荐

  1. Centos7配置

    1.静态ip配置 1.1  cd  /etc/sysconfig/network-scripts/ 1.2 vim ifcfg-ens33 (可通过ls查看  一般为第一个) (网关DNS1可以通过V ...

  2. css动画和jq动画的简单区分

    有很多不怎么用css3写动画的同学经常会对其中css3的transform,transition,translate,animation,@keyframes等等动画属性混淆错乱,经常使用了发现没有效 ...

  3. CentOS7系列--3.1CentOS7中配置NFS服务

    CentOS7配置NFS服务 1. 配置NFS服务器端 1.1. 安装nfs-utils软件 [root@server1 ~]# yum install -y nfs-utils Loaded plu ...

  4. Java 之常用API(二)

    Object类 & System类 日期相关类 包装类 & 正则表达式 Object类 & System类 1.1 Object类 1.1.1 概述 Object类是Java语 ...

  5. python学习笔记之——range()函数

    range函数的三种用法:>>> range(1,5) # 代表从1到5(不包含5) [1, 2, 3, 4] >>> range(1,5,2) # 代表从1到5, ...

  6. 润乾V4的最小化部署方式

     在接触到的很多项目实际应用中,部署润乾V4都是使用润乾V4设计器自带的WEB发布向导,直接生成webRoot目录,然后将该目录下的所有文件COPY到项目目录下,然后修改web.xml文件和rep ...

  7. ASP.NET MVC 实现区域 项目分离 (比较好的方式)

    说明: ZRT.Web 是前台网站,目录[D:\ZRT.Web\] ZRT.Admin 是后台管理,目录[D:\ZRT.Web\Applications\Admin\],删除文件[Global.asa ...

  8. paypal文档

    https://blog.csdn.net/daily886/article/details/73164643?ref=myread.

  9. C#下使用XmlDocument详解

    XML在开发中作为文件存储格式.数据交换的协议用的非常普遍,各个编程语言有都支持.W3C也制定了XML DOM的标准.在这里主要介绍下.Net中的XmlDocument,包括xml读取和写入等功能.一 ...

  10. 18c新特性的一些小结(from JimmyHe)

    Oracle 18c在2018-02-16 release出来的,还是秉承着Oracle的cloud first理念,18c现在cloud和Engineered Systems上推出,想在传统的机器上 ...