StreamBase's formal path notation is designed to avoid naming conflicts when you run multiple modules in the same fragment in different EventFlow containers, and to avoid conflicts when operators are run in separate parallel regions.
You use StreamBase path notation to address individual streams or operators when using the sbadmin and sbc commands, or when configuring container connections in a StreamBase configuration file. For example, the following command requests the XML representation of one particular stream:
sbc describe default.OutputStream1
In addition, StreamBase path notation is used in the output of the StreamBase profiling tools, especially in the Operators View and Queues View of those tools.
StreamBase path notation has the following syntax, with a period separator between each element:
[containerName
.][moduleRefName
[[.moduleRef2Name
].[..]]entityName
- containerName
-
The name of the EventFlow container hosting the application. Container names are either
system
,default
, or a name you assign when creating a container. The following example addresses two operators with the same name in separate containers:container1.ReadOrders default.ReadOrders
When
containerName
is omitted, the EventFlow container nameddefault
is assumed. Every EventFlow fragment has a default container nameddefault
, which contains the application's top-level module unless you explicitly create a non-default container. This means you can often omit thecontainerName
portion of the address. For example, the following commands are equivalent if the server is running a single container fragment:sbc enqueue default.InputStream1 sbc enqueue InputStream1
Use the
containerName
portion of the address when you are addressing a non-default container, or when a name conflict would otherwise occur. - moduleRefName
-
The name of a module that is either referenced explicitly in the fragment, or referenced implicitly by StreamBase. Implicit references occur when a component runs in separate or multiple parallel regions; in this case, StreamBase automatically creates a module for each running instance. There can be multiple
moduleRefName
levels in the address syntax.The following line addresses an operator named
SumOrders
within a module reference namedMWindowModuleRef1
:MWindowModuleRef1.SumOrders
The next example addresses a group of entities associated with an operator that you have configured, using the Concurrency tab of the operator's Properties view, to run in a parallel region. In each entity, the prefix references the module that StreamBase creates for the operator's parallel region.
MyOperator.InputStream1 (input stream) MyOperator.out:MyOperator_1 (output stream) MyOperator.schema:RetrieveLastOrders (schema) MyOperator.MyOperator (operator)
Finally, If you set a component to run in multiple parallel regions, you can address each region separately. The following example addresses two instances for the same operator, each running in its own parallel region.
default.Filter:0.Filter default.Filter:1.Filter
- entityName
-
The name of an individual stream, operator, schema, or queue.
When used in the output of profiling tools, you might also see a parallel region instance number appended to the
entityName
in the formentityName[:
, using zero-based instance numbers. For example:instanceNumber
]Update_Bids_and_Asks:0
,Update_Bids_and_Asks:1
, and so on.