如何用Nop平台提升第三方框架的可扩展性

Nop平台的底层可以很容易的和任何设计良好的第三方框架集成在一起使用,只需要极少量的整合代码就可以极大提升第三方框架的可扩展性。 正好最近solon框架引入了一个流处理的插件,它的示例代码中有一个明显的可以集成使用Nop平台的扩展点。

在这个示例中,Chain是一种可以通过json文件定义的模型对象,它的解析和装载可以通过Chain.parseByUrl函数进行。

如果和Nop平台集成,我们可以直接将Chain.parseByUrl替换为ResourceComponentManager.loadComponentModel(path),然后把json文件移动到resources/_vfs目录下即可。

通过这一修改之后,我们可以立刻得到如下功能:

  1. JSON文件解析的结果会被自动缓存,只有到缓存中未找到的时候才会真正读取模型文件。
  2. 如果要定制一个模型文件,不需要修改原始文件,只需要在resources/_delta/default目录下创建一个同名文件即可。Nop平台会优先加载Delta目录下的文件。
  3. 如果希望将模型文件保存到数据库中,而不是放在classpath下,只需要引入一个dao文件协议,例如dao:Chain/my-task/v1
  4. 如果一个文件过大,在任意子节点上都可以使用x:extends语法来引入基础文件,当前节点和引入的节点会自动合并,从而实现大模型文件的拆分和重组。
  5. ResourceComponentManager会自动跟踪模型文件的依赖关系,任何依赖文件发生变化的时候都会自动设置模型缓存失效。
  6. 可以通过x:gen-extendsx:post-extends等机制通过元编程来动态生成模型节点,提供更加灵活的二次抽象机制。
  7. 使用Nop平台之后,在模型文件内部完全不需要再设计自己特定的import/plugin等机制。
json 复制代码
{
  "x:gen-extends": "<chain-gen:GenBaseFlow xpl:lib='/xlib/chain-gen.xlib'/>",
  "steps": [
    {
      "x:extends": "my-step.chain.json",
      "name": "step1",
      "ui:hidden": false
    }
  ]
}

如果自行实现以上内容也很简单,只需要两三千行代码。

java 复制代码
interface IDeltaModelLoader{
  <T> T loadDeltaModel(String path, Class<T> clazz);
}

比如增加一个上面定义的IDeltaModelLoader接口,然后通过DeltaFileSystem来查找path对应的文件,在JSON层面实现Delta合并后再转型为指定Java模型类。

无需修改solon框架的任何运行时代码,只需要将模型加载器的调用这一行代替替换,就可以获得Nop平台独有的Delta定制能力和强大的元编程抽象能力。使用Delta定制,可以实现当所有json都打包到jar包中以后,无需修改jar包中的文件,通过额外增加delta配置就可以实现对任何模型文件的深度定制调整。可以选择替换整个模型文件,也可以选择只定制模型文件中的某个属性。

元模型增强

如果为json文件补充一个xdef元模型,则可以立刻得到如下功能:

  1. 可以使用XML、JSON、YAML等多种格式来定义模型文件
  2. 可以自动生成模型文件对应的Java类,方便在Java代码中直接使用
  3. 在IDEA开发工具中自动实现语法校验、自动补全、断点调试等功能
  4. 可以通过Excel来定义该模型内容,无需编写Excel解析代码,就可以自动实现复杂嵌套结构的模型对象与Excel文件之间的双向转换。
  5. 模型节点自动支持扩展属性。XDef元模型格式检查会自动跳过所有带名字空间的属性。
相关推荐
Easonmax14 小时前
用 Rust 打造可复现的 ASCII 艺术渲染器:从像素到字符的完整工程实践
开发语言·后端·rust
百锦再14 小时前
选择Rust的理由:从内存管理到抛弃抽象
android·java·开发语言·后端·python·rust·go
小羊失眠啦.14 小时前
深入解析Rust的所有权系统:告别空指针和数据竞争
开发语言·后端·rust
q***718515 小时前
Spring Boot 集成 MyBatis 全面讲解
spring boot·后端·mybatis
大象席地抽烟15 小时前
使用 Ollama 本地模型与 Spring AI Alibaba
后端
程序员小假15 小时前
SQL 语句左连接右连接内连接如何使用,区别是什么?
java·后端
小坏讲微服务15 小时前
Spring Cloud Alibaba Gateway 集成 Redis 限流的完整配置
数据库·redis·分布式·后端·spring cloud·架构·gateway
方圆想当图灵16 小时前
Nacos 源码深度畅游:Nacos 配置同步详解(下)
分布式·后端·github
方圆想当图灵16 小时前
Nacos 源码深度畅游:Nacos 配置同步详解(上)
分布式·后端·github
小羊失眠啦.16 小时前
用 Rust 实现高性能并发下载器:从原理到实战
开发语言·后端·rust