Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzdst
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
1
议题
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzdst
提交
fad5b671
提交
fad5b671
编写于
12月 18, 2020
作者:
hebao@lab.ibiz5.com
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
引擎构建MQ消息格式调整,构建时传递引擎配置参数到分析数据对象,以便分析结果保存时可用动态指定数据源和表名
上级
134bef4d
变更
5
显示空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
99 行增加
和
42 行删除
+99
-42
BaseRequest.java
...n/java/cn/ibizlab/core/extensions/domain/BaseRequest.java
+2
-0
EngineMQMsg.java
...n/java/cn/ibizlab/core/extensions/domain/EngineMQMsg.java
+15
-0
BaseEntityServiceImpl.java
...bizlab/core/extensions/service/BaseEntityServiceImpl.java
+12
-0
RuleEngineExService.java
.../ibizlab/core/extensions/service/RuleEngineExService.java
+53
-28
MQConsumeMsgListenerProcessor.java
...b/core/extensions/util/MQConsumeMsgListenerProcessor.java
+17
-14
未找到文件。
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/domain/BaseRequest.java
浏览文件 @
fad5b671
...
...
@@ -42,6 +42,8 @@ public class BaseRequest
private
List
<
ModelObj
>
datas
;
private
String
model
;
private
String
resultDataSource
;
private
String
resultTableName
;
private
String
batch
;
private
List
<
String
>
rules
;
...
...
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/domain/EngineMQMsg.java
0 → 100644
浏览文件 @
fad5b671
package
cn
.
ibizlab
.
core
.
extensions
.
domain
;
import
cn.ibizlab.core.lite.extensions.domain.EntityObj
;
import
lombok.Data
;
import
java.sql.Timestamp
;
import
java.util.List
;
@Data
public
class
EngineMQMsg
{
private
String
engineId
;
private
String
batch
;
private
Timestamp
runTime
;
private
List
<
EntityObj
>
datas
;
}
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/service/BaseEntityServiceImpl.java
浏览文件 @
fad5b671
...
...
@@ -104,6 +104,12 @@ public class BaseEntityServiceImpl implements BaseEntityService
result
.
setExt1Field
(
EXT1FIELD
.
toString
());
if
(
EXT2FIELD
!=
null
)
result
.
setExt2Field
(
EXT2FIELD
.
toString
());
if
(
param
.
containsKey
(
RuleEngineExService
.
Setting_ResultDataSource
)){
result
.
set
(
RuleEngineExService
.
Setting_ResultDataSource
,
param
.
get
(
RuleEngineExService
.
Setting_ResultDataSource
));
}
if
(
param
.
containsKey
(
RuleEngineExService
.
Setting_ResultTableName
)){
result
.
set
(
RuleEngineExService
.
Setting_ResultTableName
,
param
.
get
(
RuleEngineExService
.
Setting_ResultTableName
));
}
if
(
DIMFIELD
==
null
){
return
;
...
...
@@ -385,6 +391,12 @@ public class BaseEntityServiceImpl implements BaseEntityService
count
++;
modelObj
.
set
(
"BATCH"
,
msg
.
getBatch
());
if
(!
StringUtils
.
isEmpty
(
msg
.
getResultDataSource
())){
modelObj
.
set
(
RuleEngineExService
.
Setting_ResultDataSource
,
msg
.
getResultDataSource
());
}
if
(!
StringUtils
.
isEmpty
(
msg
.
getResultTableName
())){
modelObj
.
set
(
RuleEngineExService
.
Setting_ResultTableName
,
msg
.
getResultTableName
());
}
processRule
(
modelObj
,
modelObj
.
getRowKey
(),
strResId
);
}
...
...
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/service/RuleEngineExService.java
浏览文件 @
fad5b671
package
cn
.
ibizlab
.
core
.
extensions
.
service
;
import
cn.ibizlab.core.extensions.domain.BaseRequest
;
import
cn.ibizlab.core.extensions.domain.EngineMQMsg
;
import
cn.ibizlab.core.lite.extensions.domain.EntityModel
;
import
cn.ibizlab.core.lite.extensions.domain.EntityObj
;
import
cn.ibizlab.core.lite.extensions.domain.FieldModel
;
import
cn.ibizlab.core.lite.extensions.domain.Setting
;
import
cn.ibizlab.core.lite.extensions.filter.DbEntitySearchContext
;
import
cn.ibizlab.core.lite.extensions.model.DataModel
;
import
cn.ibizlab.core.lite.extensions.service.DbEntityService
;
import
cn.ibizlab.core.lite.extensions.service.LiteModelService
;
import
cn.ibizlab.core.lite.service.IMetaModelService
;
import
cn.ibizlab.core.rule.domain.ExecLog
;
import
cn.ibizlab.core.rule.domain.RuleEngine
;
import
cn.ibizlab.core.rule.domain.RuleItem
;
import
cn.ibizlab.core.rule.filter.RuleItemSearchContext
;
import
cn.ibizlab.core.rule.service.IRuleItemService
;
import
cn.ibizlab.core.rule.service.impl.RuleEngineServiceImpl
;
import
cn.ibizlab.util.filter.QueryFilter
;
import
cn.ibizlab.util.helper.CachedBeanCopier
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSON
Object
;
import
com.alibaba.fastjson.JSON
Array
;
import
com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.baomidou.mybatisplus.core.toolkit.IdWorker
;
import
com.baomidou.mybatisplus.core.toolkit.Wrappers
;
import
lombok.extern.slf4j.Slf4j
;
import
cn.ibizlab.core.rule.domain.RuleEngine
;
import
org.apache.ibatis.session.SqlSessionFactory
;
import
org.apache.rocketmq.client.exception.MQBrokerException
;
import
org.apache.rocketmq.client.exception.MQClientException
;
import
org.apache.rocketmq.client.producer.DefaultMQProducer
;
import
org.apache.rocketmq.client.producer.SendResult
;
import
org.apache.rocketmq.common.message.Message
;
import
org.apache.rocketmq.remoting.exception.RemotingException
;
import
org.mybatis.spring.batch.MyBatisCursorItemReader
;
import
org.springframework.batch.item.ExecutionContext
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.context.annotation.Lazy
;
import
org.springframework.context.annotation.Primary
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.context.annotation.Primary
;
import
org.springframework.util.ObjectUtils
;
import
org.springframework.util.StringUtils
;
import
org.apache.rocketmq.common.message.Message
;
import
java.io.File
;
import
java.util.*
;
...
...
@@ -59,6 +58,9 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
return
com
.
baomidou
.
mybatisplus
.
core
.
toolkit
.
ReflectionKit
.
getSuperClassGenericType
(
this
.
getClass
().
getSuperclass
(),
1
);
}
public
static
final
String
Setting_ResultDataSource
=
"resultDataSource"
;
public
static
final
String
Setting_ResultTableName
=
"resultTableName"
;
@Autowired
private
DbEntityService
dbEntityService
;
...
...
@@ -102,6 +104,19 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
{
CachedBeanCopier
.
copy
(
get
(
et
.
getEngineId
()),
et
);
BaseRequest
msg
=
new
BaseRequest
();
msg
.
setId
(
IdWorker
.
getIdStr
());
msg
.
setModel
(
et
.
getModelName
());
String
resultDataSource
=
Setting
.
getValue
(
et
.
getExtParams
(),
Setting_ResultDataSource
);
String
resultTableName
=
Setting
.
getValue
(
et
.
getExtParams
(),
Setting_ResultTableName
);
if
(!
StringUtils
.
isEmpty
(
resultDataSource
)){
msg
.
setResultDataSource
(
resultDataSource
);
}
if
(!
StringUtils
.
isEmpty
(
resultTableName
)){
msg
.
setResultTableName
(
resultTableName
);
}
java
.
sql
.
Timestamp
starttime
=
new
java
.
sql
.
Timestamp
(
System
.
currentTimeMillis
());
if
(
true
){
DataModel
dataModel
=
JSON
.
toJavaObject
(
JSON
.
parseObject
(
metaModelService
.
get
(
et
.
getModelId
()).
getConfig
()),
DataModel
.
class
);
EntityModel
entityModel
=
dataModel
.
getFactEntityModel
();
...
...
@@ -111,8 +126,6 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
if
(
lastModifyField
!=
null
)
filter
.
ge
(
lastModifyField
.
getColumnName
(),
et
.
getLastRuntime
());
String
sql
=
entityModel
.
getSqlSegment
(
"CORE"
);
MyBatisCursorItemReader
myMyBatisCursorItemReader
=
new
MyBatisCursorItemReader
();
try
{
...
...
@@ -140,17 +153,27 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
DynamicDataSourceContextHolder
.
push
(
entityModel
.
getDsName
());
myMyBatisCursorItemReader
.
open
(
new
ExecutionContext
());
// 开启游标
DynamicDataSourceContextHolder
.
poll
();
List
<
EntityObj
>
batch
=
new
ArrayList
<>();
List
<
EntityObj
>
datas
=
new
ArrayList
<>();
EntityObj
rowdata
;
while
((
rowdata
=
(
EntityObj
)
myMyBatisCursorItemReader
.
read
())
!=
null
)
{
batch
.
add
(
rowdata
);
if
(
batch
.
size
()
>
500
){
this
.
sendToMQ
(
et
.
getEngineId
(),
batch
);
batch
.
clear
();
datas
.
add
(
rowdata
);
if
(
datas
.
size
()
>
500
){
EngineMQMsg
engineMQMsg
=
new
EngineMQMsg
();
engineMQMsg
.
setEngineId
(
et
.
getEngineId
());
engineMQMsg
.
setBatch
(
msg
.
getBatch
());
engineMQMsg
.
setRunTime
(
starttime
);
engineMQMsg
.
setDatas
(
datas
);
this
.
sendToMQ
(
engineMQMsg
);
datas
.
clear
();
}
}
if
(
batch
.
size
()
>
0
){
this
.
sendToMQ
(
et
.
getEngineId
(),
batch
);
if
(
datas
.
size
()
>
0
){
EngineMQMsg
engineMQMsg
=
new
EngineMQMsg
();
engineMQMsg
.
setEngineId
(
et
.
getEngineId
());
engineMQMsg
.
setBatch
(
msg
.
getBatch
());
engineMQMsg
.
setRunTime
(
starttime
);
engineMQMsg
.
setDatas
(
datas
);
this
.
sendToMQ
(
engineMQMsg
);
}
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
...
...
@@ -167,10 +190,6 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
if
(!
StringUtils
.
isEmpty
(
et
.
getModelId
()))
{
BaseRequest
msg
=
new
BaseRequest
();
msg
.
setId
(
IdWorker
.
getIdStr
());
msg
.
setModel
(
et
.
getModelName
());
java
.
sql
.
Timestamp
starttime
=
new
java
.
sql
.
Timestamp
(
System
.
currentTimeMillis
());
List
<
String
>
rules
=
new
ArrayList
<>();
DataModel
dataModel
=
liteModelService
.
getDataModel
(
et
.
getModelId
());
...
...
@@ -226,18 +245,26 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
return
super
.
run
(
et
);
}
protected
void
sendToMQ
(
String
engineId
,
List
<
EntityObj
>
batch
)
throws
InterruptedException
,
RemotingException
,
MQClientException
,
MQBrokerException
{
String
msg
=
JSON
.
toJSONString
(
batch
);
Message
sendMsg
=
new
Message
(
ruleEngineTopic
,
engine
Id
,
msg
.
getBytes
());
protected
void
sendToMQ
(
EngineMQMsg
engineMQMsg
)
throws
InterruptedException
,
RemotingException
,
MQClientException
,
MQBrokerException
{
String
msg
=
JSON
.
toJSONString
(
engineMQMsg
);
Message
sendMsg
=
new
Message
(
ruleEngineTopic
,
engine
MQMsg
.
getEngineId
()
,
msg
.
getBytes
());
SendResult
sendResult
=
defaultMQProducer
.
send
(
sendMsg
);
log
.
info
(
"消息发送响应:"
+
sendResult
.
toString
());
}
public
void
processData
(
String
engineId
,
List
<
EntityObj
>
batch
){
RuleEngine
et
=
get
(
engine
Id
);
public
void
processData
(
EngineMQMsg
engineMQMsg
){
RuleEngine
et
=
get
(
engine
MQMsg
.
getEngineId
()
);
BaseRequest
msg
=
new
BaseRequest
();
msg
.
setId
(
IdWorker
.
getIdStr
());
msg
.
setModel
(
et
.
getModelName
());
String
resultDataSource
=
Setting
.
getValue
(
et
.
getExtParams
(),
Setting_ResultDataSource
);
String
resultTableName
=
Setting
.
getValue
(
et
.
getExtParams
(),
Setting_ResultTableName
);
if
(!
StringUtils
.
isEmpty
(
resultDataSource
)){
msg
.
setResultDataSource
(
resultDataSource
);
}
if
(!
StringUtils
.
isEmpty
(
resultTableName
)){
msg
.
setResultTableName
(
resultTableName
);
}
java
.
sql
.
Timestamp
starttime
=
new
java
.
sql
.
Timestamp
(
System
.
currentTimeMillis
());
...
...
@@ -277,14 +304,12 @@ public class RuleEngineExService extends RuleEngineServiceImpl {
msg
.
setRules
(
rules
);
msg
.
setDatas
(
dbEntityService
.
getModelObjs
(
et
.
getModelId
(),
fillpropertys
,
batch
));
msg
.
setDatas
(
dbEntityService
.
getModelObjs
(
et
.
getModelId
(),
fillpropertys
,
engineMQMsg
.
getDatas
()
));
ExecLog
execlog
=
baseEntityService
.
processAll
(
msg
);
}
/**
* [Check:校验] 行为扩展
...
...
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/util/MQConsumeMsgListenerProcessor.java
浏览文件 @
fad5b671
package
cn
.
ibizlab
.
core
.
extensions
.
util
;
import
cn.ibizlab.core.extensions.domain.EngineMQMsg
;
import
cn.ibizlab.core.extensions.service.RuleEngineExService
;
import
cn.ibizlab.core.lite.extensions.domain.EntityObj
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.TypeReference
;
import
lombok.extern.slf4j.Slf4j
;
...
...
@@ -9,20 +9,15 @@ import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyContext;
import
org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus
;
import
org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently
;
import
org.apache.rocketmq.common.message.MessageExt
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.stereotype.Component
;
import
org.springframework.util.CollectionUtils
;
import
java.util.ArrayList
;
import
java.util.List
;
/**
* @author: lockie
* @Date: 2020/4/21 11:05
* @Description: 消费者监听
* MQ订阅消息处理
*/
@Slf4j
@Component
...
...
@@ -56,18 +51,26 @@ public class MQConsumeMsgListenerProcessor implements MessageListenerConcurrentl
log
.
info
(
"MQ消息topic={}, tags={}, 消息内容={}"
,
topic
,
tags
,
body
);
if
(
ruleEngineTopic
.
equalsIgnoreCase
(
topic
)){
this
.
processRuleEngineData
(
tags
,
body
);
}
}
catch
(
Exception
e
)
{
log
.
error
(
"获取MQ消息内容异常{}"
,
e
);
}
// TODO 处理业务逻辑
// 处理规则引擎构建消息
if
(
ruleEngineTopic
.
equalsIgnoreCase
(
messageExt
.
getTopic
())){
this
.
processRuleEngineData
(
messageExt
);
}
return
ConsumeConcurrentlyStatus
.
CONSUME_SUCCESS
;
}
protected
void
processRuleEngineData
(
String
engineId
,
String
body
){
List
<
EntityObj
>
batch
=
JSON
.
parseObject
(
body
,
new
TypeReference
<
ArrayList
<
EntityObj
>>()
{});
ruleEngineExService
.
processData
(
engineId
,
batch
);
protected
void
processRuleEngineData
(
MessageExt
messageExt
){
try
{
String
body
=
new
String
(
messageExt
.
getBody
(),
"utf-8"
);
EngineMQMsg
engineMQMsg
=
JSON
.
parseObject
(
body
,
new
TypeReference
<
EngineMQMsg
>()
{});
ruleEngineExService
.
processData
(
engineMQMsg
);
}
catch
(
Exception
e
)
{
log
.
error
(
"获取MQ消息内容异常{}"
,
e
);
}
}
}
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录