Skip to content

Timothy-Liuxf/bgp_platform

Repository files navigation

bgp_platform

bgp_platform - BGP outage detection experimental platform

Origin Repo: https://github.com/Timothy-Liuxf/bgp_platform

How to Build

Prerequisites

  • Linux operating system
  • C++ compiler which supports C++17
  • GNU Autoconf and GNU Automake
  • libpq and libpqxx-6.4
  • bgpdump
  • Python 3 with PyTorch

or

  • Docker

Clone this repository

$ git clone --recursive https://github.com/Timothy-Liuxf/bgp_platform.git
$ cd bgp_platform

or

$ git clone https://github.com/Timothy-Liuxf/bgp_platform.git
$ cd bgp_platform
$ git submodule update --init --recursive

Build with Docker (Recommended)

Build base image

$ docker build . -f Dockerfile.base -t <base image name>

Build target image

  1. Open Dockerfile:
FROM timothyliuxf/bgp_platform_base AS builder

Then change timothyliuxf/bgp_platform_base to <base image name> you set in the previous step.

  1. Build the target image:
$ docker build . -t <target image name>

Build on a local machine

Configure build system

# Requires GNU Autoconf and GNU Automake

$ autoreconf -i
$ [ENV=VAL] ./configure

The ENV and VAL can be:

  • BUILD_CONFIG: Choose configuration.
    • Debug / debug: Debug configuration.
    • Release / release (default): Release configuration.
  • CXX: The C++ compiler to use. The default value is g++.

Build the target

$ make -j$(nproc)

How to Run

Setup Database

Setup a PostgreSQL server.

Configuration

Write configurations in config/config.json. Take config/examples/config.json for an example.

Run the program

Run with docker

  • Mount the directory where the config.json is located to /app/config.
  • Mount the directory where the initalization information files are located to /app/info.
  • Mount the directory where the data files are located to /app/data.

Take scripts/launch_docker.sh for an example.

Run on a local machine

$ ./build/bin/bgp_platform [options]

About

bgp_platform - BGP outage detection experimental platform

Topics

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published