BPM流程设计的最佳实践(1)

在简书上新开博客,趁着热乎劲,写篇工作心得过过瘾。

这个最佳实践来自于一个defect。准确说是BPM的一些不足带来的一些不方便trouble shooting的问题,加上随意的流程设计,造成了出错的地方和问题暴露的地方相差十万八千里,甚至开始时很难把这两个问题联想到一起。

错误的Log像这样:

[4/28/16 20:52:47:304 CEST] 0002f2c7 wle          E  CWLLG0326E: The BPD encountered an error.

com.lombardisoftware.core.TeamWorksException: java.lang.Object

at com.lombardisoftware.core.TeamWorksException.asTeamWorksException(TeamWorksException.java:136)

at com.lombardisoftware.client.persistence.common.DAOHelper.serializeObject(DAOHelper.java:166)

at com.lombardisoftware.client.persistence.common.DAOHelper.serializeAndCompressIfNeeded(DAOHelper.java:140)

at com.lombardisoftware.bpd.runtime.engine.BPDInstanceDAO.updateExecutionContext(BPDInstanceDAO.java:416)

at com.lombardisoftware.bpd.runtime.engine.BPDInstanceDAO.save(BPDInstanceDAO.java:338)

[4/28/16 20:52:47:390 CEST] 0002f2c7 wle_scheduler E   CWLLG0181E: The following error occurred in the 5,374,817 task: Not a valid char constructor input: in_creation

com.lombardisoftware.core.TeamWorksException: Not a valid char constructor input: in_creation

at com.lombardisoftware.core.TeamWorksException.asTeamWorksException(TeamWorksException.java:136)

at com.lombardisoftware.bpd.runtime.engine.quartz.AbstractBpdTask.execute(AbstractBpdTask.java:137)

at com.lombardisoftware.bpd.runtime.engine.quartz.AbstractBpdTask.execute(AbstractBpdTask.java:55)

at com.lombardisoftware.server.scheduler.Engine.execute(Engine.java:918)

错误的原因看着很简单,串行化失败。当时结合日志上下文,错误地点定位在非本人维护的activity当中,想当然的就transfer出去了。

问题又很快被踢回来了,原因是错误也没有在他们的activity当中。两个activity之间出错,那90%是传递的参数问题。两个activity虽然传递的参数不多,但要debug还挺花时间,费了番功夫之后,神奇的事情出现了。所有参数直接显式赋值确保没有串行化问题之后还是报错。带着绝望的心情,我又费了更大的功夫(妈妈说有5x个,赋值逻辑分散在各个activities里面,调试还没有整套环境T_T)把所有BPD中间定义的所有参数全部隐去,错误消失了!

后面事情就简单了,过滤/定位后发现原来是新人加的一个Any类型的参数,参数的初始化赋值是转化自一个javascript的JSON object,并用Java的map重构。但没有考虑multi-layer,把一个javascript JSON object赋值到了java的object里面。修改逻辑后问题解决。

重新来看这个问题,为什么这个参数为什么之前一直没有暴露问题,而单单到其它activity,还且还是没有任何调用操作的activity出错了?现在事后想想,首先报错的activity是一个existing的BPD,而不是当前BPD下面定义的一个activity。当流程从当前BPD转到报错的activity时,BPM的内在逻辑看来把所有原BPD中的参数都串行化并持久存储起来,然后切换上下文环境来跑下一个由existing BPD生成的activity。但由于初始化的错误,串行化失败,无法持久化,报错了。

这个问题总共花了4天时间debug,中间情节曲折,问题定位艰难,一个是我自身对BPM不熟,第二是当时候BPD设计过分依赖Any参数。Any参数忽略的类型检验,虽然易于编程,但调试却困难重重。所以不是万不得已,不建议在BPD中使用Any类型的参数。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容