All notable changes to this project will be documented in this file.
- migrate default broker API endpoint to
https://api.bgpkit.com/v3/broker
- Full API docs is available at
https://api.bgpkit.com/docs
- Full API docs is available at
- add
get_peers
toBgpkitBroker
struct- fetches the list of peers for a given collector
- allow specifying filters the same way as querying MRT files
- available filter functions include:
.peers_asn(ASN)
.peers_ip(IP)
.collector_id(COLLECTOR_ID)
.peers_only_full_feed(TRUE/FALSE)
- returns
Vec<BrokerPeer>
#[derive(Debug, Clone, Eq, PartialEq, Serialize, Deserialize)]
pub struct BrokerPeer {
/// The date of the latest available data.
pub date: NaiveDate,
/// The IP address of the collector peer.
pub ip: IpAddr,
/// The ASN (Autonomous System Number) of the collector peer.
pub asn: u32,
/// The name of the collector.
pub collector: String,
/// The number of IPv4 prefixes.
pub num_v4_pfxs: u32,
/// The number of IPv6 prefixes.
pub num_v6_pfxs: u32,
/// The number of connected ASNs.
pub num_connected_asns: u32,
}
- add a deployment config file for fly.io
- fix an issue where the API returns URL with additional
/bgpdata
for some new route-views collectors.
- improved documentation on deploying bgpkit-broker services.
- add a new 30s timeout for fetching web page content for the crawler
- the async
reqwest::get
function by default does not have a timeout and thus we could potentially stuck waiting forever.
- the async
- add new
max_delay_secs
parameter to the/health
endpoint to allow user specify a maximum delay in seconds and the API will return error code 503 if the delay for the latest file timestamp (any file) is greater than the specified value.- this allows better monitoring for the API's health without sending heartbeats.
- fix an issue where the main thread waits for updater thread and never starts the API thread
- panic if the cli updater thread failed for some reason
- previously, the failed thread goes silently, and the main process continues running
- reduce logging if not configuring NATS notifier
- previously, the missing notifier message appear at every fetch
- updated the
bgpkit-broker update
command to allow bootstrapping new collectors on demand - a number of new RouteViews collectors have been added
amsix.ams
cix.atl
decix.jhb
iraq-ixp.bgw
pacwave.lax
pit.scl
pitmx.qro
route-views7
- added a new
allow_invalid_cert
function to the constructor and deprecated thedisable_ssl_check
function- they work the same way, but the new function name is more accurate
- constructor also checks for
ONEIO_ACCEPT_INVALID_CERTS=true
environment variable to allow invalid certs (not recommended, use at your own risk) - improved project filter. it now matches the name of the collector to project names
- this works with the newly added RouteViews collectors whose names do not prefix with
route-views
- this works with the newly added RouteViews collectors whose names do not prefix with
Added new-file notification by publishing newly indexed BGP MRT file meta information in JSON format to user-specified NATS server.
The NATS URL and credentials is configured via environment variables:
BGPKIT_BROKER_NATS_URL
likenats://nats.bgpkit.com:4222
(default)BGPKIT_BROKER_NATS_ROOT_SUBJECT
such aspublic.broker.
(default)
The notification is published to public.broker.{PROJECT}.{COLLECTOR}.{DATA_TYPE}
where
PROJECT
isriperis
orroute-views
COLLECTOR
is the route collector IDs likerrc00
orroute-views2
DATA_TYPE
isrib
orupdates
Example of what a subscriber can be notified for:
public.broker.>
: any new MRT filespublic.broker.route-views.>
: new RouteViews updates filespublic.broker.rrc00.rib
: new RIPE RIS rrc00 RIB dump filespublic.broker.*.rib
: any new RIB dump files
This PR also adds a new subcommand bgpkit-broker live
that listens to the specified NATS server for new file
notification.
Streaming live from a broker NATS server
Usage: bgpkit-broker live [OPTIONS]
Options:
--no-log disable logging
-u, --url <URL> URL to NATS server, e.g. nats://localhost:4222. If not specified, will try to read from BGPKIT_BROKER_NATS_URL env variable
--env <ENV>
-s, --subject <SUBJECT> Subject to subscribe to, default to public.broker.>
-p, --pretty Pretty print JSON output
-h, --help Print help
-V, --version Print version
Added bgpkit-broker doctor
subcommand that checks the broker instance status and missing collectors.
Check broker instance health and missing collectors
Usage: bgpkit-broker doctor [OPTIONS]
Options:
--no-log disable logging
--env <ENV>
-h, --help Print help
-V, --version Print version
Example output:
checking broker instance health...
broker instance at https://api.broker.bgpkit.com/v3 is healthy
checking for missing collectors...
missing the following collectors:
| project | name | country | activated_on | data_url |
|------------|--------------|-----------------|---------------------|----------------------------------------------------|
| routeviews | decix.jhb | Malaysia | 2022-12-20 12:00:00 | http://archive.routeviews.org/decix.jhb/bgpdata |
| routeviews | pacwave.lax | United States | 2023-03-30 12:00:00 | http://archive.routeviews.org/pacwave.lax/bgpdata |
| routeviews | pit.scl | Chile | 2023-08-31 23:45:00 | http://archive.routeviews.org/pit.scl/bgpdata |
| routeviews | amsix.ams | The Netherlands | 2024-02-22 23:20:00 | http://archive.routeviews.org/amsix.ams/bgpdata |
| routeviews | pitmx.qro | Mexico | 2024-02-23 22:15:00 | http://archive.routeviews.org/pitmx.qro/bgpdata |
| routeviews | iraq-ixp.bgw | Iraq | 2024-04-13 00:01:00 | http://archive.routeviews.org/iraq-ixp.bgw/bgpdata |
If BGPKIT_BROKER_HEARTBEAT_URL
environment is set, when running the bgpkit-broker serve
subcommand, the instance
will periodically send a GET request to the configured heartbeat URL.
Added latest
subcommand to CLI to display latest MRT files for all collectors.
- add
.is_rib()
toBrokerItem
struct - add strict ordering definition for
BrokerItem
struct
An array of BrokerItem
s can be sorted with the following order:
- smaller timestamp before larger timestamp
- RIB before updates
- then alphabetical order on collector ID (route-views before rrc)
- switch to
rustls
as the default TLS backend
- switch http lib to reqwest from ureq by @digizeph in #20
Full Changelog: https://github.com/bgpkit/bgpkit-broker/compare/v0.6.0...v0.6.1