Concept
This section describes the basic concept and core functionality of the Jalapeño API Gateway.
#
Deployment Diagram#
Behavior of Jalapeño ComponentsTo understand how the Jalapeño API Gateway works, it helps to understand how Jalapeño itself works.
Here the basic principle of Jalapeño is described:
- Changes to the network are published in various Kafka topics, i.e. in the topic
gobmp.parsed.ls_node
, byGoBMP
andTelegraf
.
Kafka Topics for unprocessed events
- These are all Kafka topics to which
GoBMP
writes topology updates:- gobmp.parsed.evpn
- gobmp.parsed.flowspec
- gobmp.parsed.flowspec_v4
- gobmp.parsed.flowspec_v6
- gobmp.parsed.l3vpn
- gobmp.parsed.l3vpn_v4
- gobmp.parsed.l3vpn_v6
- gobmp.parsed.ls_link
- gobmp.parsed.ls_node
- gobmp.parsed.ls_prefix
- gobmp.parsed.ls_srv6_sid
- gobmp.parsed.peer
- gobmp.parsed.sr_policy
- gobmp.parsed.sr_policy_v4
- gobmp.parsed.sr_policy_v6
- gobmp.parsed.unicast_prefix
- gobmp.parsed.unicast_prefix_v4
- gobmp.parsed.unicast_prefix_v6
- This is the Kafka topic to which
Telegraf
(the one connected to the network) writes telemetry updates:- jalapeno.telemetry
- The data processor
Topology
processes the events and updates the GraphDB. - When it has successfully updated the database, it writes a message to a seperate Kafka topic (ending in
_events
), i.e.gobmp.parsed.ls_node_events
. This message contains the key to the document in the GraphDB that has been updated (or deleted).
Kafka Topics for processed events
- These are all Kafka topics to which the processor
Topology
writes updates, once it has successfully updated theGraphDB
:- gobmp.parsed.evpn_events
- gobmp.parsed.flowspec_events
- gobmp.parsed.flowspec_v4_events
- gobmp.parsed.flowspec_v6_events
- gobmp.parsed.l3vpn_events
- gobmp.parsed.l3vpn_v4_events
- gobmp.parsed.l3vpn_v6_events
- gobmp.parsed.ls_link_events
- gobmp.parsed.ls_node_events
- gobmp.parsed.ls_prefix_events
- gobmp.parsed.ls_srv6_sid_events
- gobmp.parsed.peer_events
- gobmp.parsed.sr_policy_events
- gobmp.parsed.sr_policy_v4_events
- gobmp.parsed.sr_policy_v6_events
- gobmp.parsed.unicast_prefix_events
- gobmp.parsed.unicast_prefix_v4_events
- gobmp.parsed.unicast_prefix_v6_events
- jalapeno.ls_node_edge_events
- The processor
Telegraf
(the one connected to theTSDB
) does not currently write anything back to Kafka.
Event Message
An event message produced by the processor
Topology
and published in one of the _events
topics looks like this: type EventMessage struct { TopicType int //represents an enum Key string ID string Action string }
#
CachingThis is the behavior of the caching system when the API Gateway is started for the first time:
- The Cache Service subscribes to all Kafka topics ending in
_events
(they all contain updates on topology data), i.e.gobmp.parsed.ls_node_events
. It does not yet start processing these events. - It then fetches the current state of all existing documents from the GraphDB and stores them in the cache.
- It now starts processing the messages from the Kafka topics.
- If the message describes an update, the Cache Service refetches the document from the GraphDB and overwrites the entry in the cache.
- If the message describes a deletion, the Cache Service deletes the entry from the cache.
The Cache is now always an exact duplicate of the GraphDB. Even though it is not the most space efficient solution to cache all topology data (this can be improved upon in the future), it has two advantages.
- It reduces the load on the GraphDB.
- It reduces response times to API requests (reading from the cache is faster than reading from the database).
Telemetry data is not cached for two reasons:
- Telemetry data updates too frequently to justify caching.
- The amount of telemetry data makes caching it unfeasible.
#
Requests- To request data from the API Gateway, an SR-App first initializes a gRPC connection with the Request Service.
- The SR-App calls gRPC methods to request either topology or telemetry data.
- The Request Service either queries the cache (for topology data) or the TSDB (for telemetry data) and returns the result to the SR-App.
#
Subscriptions- The Subscription Service allows SR-Apps to subscribe to both topology and telemetry data.
- The Subscription Service constantly watches Kafka topics for topology data (topics ending in
_events
). Upon receiving a message, it fetches the updated document from the GraphDB (unless it has been deleted) and informs all subscribers. - The Subscription Service also constantly watches the Kafka topic for telemetry data (topic
jalapeno.telemetry
). Upon receiving a message, it extracts the data from the telemetry string and informs all subscribers.