# 模式管理
eKuiper 模式命令行工具使您可以管理模式,例如创建,显示和删除插件。
# 创建模式
该命令用于创建模式。 模式的定义以 JSON 格式指定。
create schema $schema_type $schema_name $schema_json
1
模式可以通过两种方式创建。
- 在命令行中指定模式文本。
示例:
# bin/kuiper create schema protobuf schema1 '{"name": "schema1","content": "message Book {required string title = 1; required int32 price = 2;}"}'
1
该命令创建一个名为 schema1
的模式,模式内容由 json 中的 content 指定。
- 在命令行中指定模式位置。
示例:
# bin/kuiper create schema protobuf schema1 '{"name": "schema1","file": "file:///tmp/aschema.proto"}'
1
该命令创建一个名为 schema1
的模式,模式内容由 json 中的 file 指定。文件将被复制到 data/schemas/protobuf
下并重命名为 schema1.proto
。
# 参数
- schema_type:模式类型,可用值为
protobuf
。 - schema_name:模式的唯一名称,模式内容将保存在以此为名的文件中。
- schema_json:定义模式内容的 json,需要包含 name 以及 file 或 content。
# 显示模式
该命令用于显示服务器中为模式类型定义的所有模式。
show schemas $schema_type
1
示例:
# bin/kuiper show schemas protobuf
schema1
schema2
1
2
3
2
3
# 描述模式
该命令用于打印模式的详细定义。
describe schema $schema_type $schema_name
1
示例:
# bin/kuiper describe schema protobuf schema1
{
"type": "protobuf",
"name": "schema1",
"content": "message Book {required string title = 1; required int32 price = 2;}",
"file": "ekuiper\\etc\\schemas\\protobuf\\schema1.proto"
}
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 删除模式
该命令用于删除模式。模式删除后,已经被规则载入的模式仍然可继续使用,但重启之后规则将报错。
drop schema $schema_type $schema_name
1
示例:
# bin/kuiper drop schema protobuf schema1
Schema schema1 is dropped.
1
2
2