CRUD Streams
CRUD operations create, read, update and delete streams.
bydbctl
is the command line tool in examples.
Stream intends to store streaming data, for example, traces or logs.
Create operation
Create operation adds a new stream to the database’s metadata registry repository. If the stream does not currently exist, create operation will create the schema.
Examples of creating
A stream belongs to a unique group. We should create such a group with a catalog CATALOG_STREAM
before creating a stream.
$ bydbctl group create -f - <<EOF
metadata:
name: default
catalog: CATALOG_STREAM
resource_opts:
shard_num: 2
block_interval:
unit: UNIT_HOUR
num: 2
segment_interval:
unit: UNIT_DAY
num: 1
ttl:
unit: UNIT_DAY
num: 7
EOF
The group creates two shards to store stream data points. Every one day, it would create a segment which will generate a block every 2 hours.
The data in this group will keep 7 days.
Then, below command will create a new stream:
$ bydbctl stream create -f - <<EOF
metadata:
name: sw
group: default
tagFamilies:
- name: searchable
tags:
- name: trace_id
type: TAG_TYPE_STRING
entity:
tagNames:
- stream_id
EOF
Get operation
Get(Read) operation get a stream’s schema.
Examples of getting
$ bydbctl stream get -g default -n sw
Update operation
Update operation update a stream’s schema.
Examples of updating
bydbctl
is the command line tool to update a stream in this example.
$ bydbctl stream update -f - <<EOF
metadata:
name: sw
group: default
tagFamilies:
- name: searchable
tags:
- name: trace_id
type: TAG_TYPE_STRING
entity:
tagNames:
- stream_id
EOF
Delete operation
Delete operation delete a stream’s schema.
Examples of deleting
bydbctl
is the command line tool to delete a stream in this example.
$ bydbctl stream delete -g default -n sw
List operation
List operation list all streams' schema in a group.
Examples of listing
$ bydbctl stream list -g default