summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--ryu/services/protocols/bgp/bgp_sample_conf.py113
1 files changed, 113 insertions, 0 deletions
diff --git a/ryu/services/protocols/bgp/bgp_sample_conf.py b/ryu/services/protocols/bgp/bgp_sample_conf.py
new file mode 100644
index 00000000..61f203cc
--- /dev/null
+++ b/ryu/services/protocols/bgp/bgp_sample_conf.py
@@ -0,0 +1,113 @@
+import os
+
+# =============================================================================
+# BGP configuration.
+# =============================================================================
+BGP = {
+
+ # General BGP configuration.
+ 'routing': {
+ # ASN for this BGP instance.
+ 'local_as': 64512,
+
+ # BGP Router ID.
+ 'router_id': '10.10.0.1',
+
+ # We list all BGP neighbors below. We establish EBGP sessions with peer
+ # with different AS number then configured above. We will
+ # establish IBGP session if AS number is same.
+ 'bgp_neighbors': {
+ '10.0.0.1': {
+ 'remote_as': 64513,
+ 'multi_exit_disc': 100
+ },
+ '10.10.0.2': {
+ 'remote_as': 64514,
+ },
+ },
+
+ 'networks': [
+ '10.20.0.0/24',
+ '10.30.0.0/24',
+ '10.40.0.0/16',
+ '10.50.0.0/16',
+ ],
+ },
+
+}
+
+# =============================================================================
+# Logging configuration.
+# =============================================================================
+LOGGING = {
+
+ # We use python logging package for logging.
+ 'version': 1,
+ 'disable_existing_loggers': False,
+
+ 'formatters': {
+ 'verbose': {
+ 'format': '%(levelname)s %(asctime)s %(module)s ' +
+ '[%(process)d %(thread)d] %(message)s'
+ },
+ 'simple': {
+ 'format': '%(levelname)s %(asctime)s %(module)s %(lineno)s ' +
+ '%(message)s'
+ },
+ 'stats': {
+ 'format': '%(message)s'
+ },
+ },
+
+ 'handlers': {
+ # Outputs log to console.
+ 'console': {
+ 'level': 'DEBUG',
+ 'class': 'logging.StreamHandler',
+ 'formatter': 'simple'
+ },
+ 'console_stats': {
+ 'level': 'DEBUG',
+ 'class': 'logging.StreamHandler',
+ 'formatter': 'stats'
+ },
+ # Rotates log file when its size reaches 10MB.
+ 'log_file': {
+ 'level': 'ERROR',
+ 'class': 'logging.handlers.RotatingFileHandler',
+ 'filename': os.path.join('.', 'bgpspeaker.log'),
+ 'maxBytes': '10000000',
+ 'formatter': 'verbose'
+ },
+ 'stats_file': {
+ 'level': 'DEBUG',
+ 'class': 'logging.handlers.RotatingFileHandler',
+ 'filename': os.path.join('.', 'statistics_bgps.log'),
+ 'maxBytes': '10000000',
+ 'formatter': 'stats'
+ },
+ },
+
+ # Fine-grained control of logging per instance.
+ 'loggers': {
+ 'bgpspeaker': {
+ 'handlers': ['console', 'log_file'],
+ 'handlers': ['console'],
+ 'level': 'DEBUG',
+ 'propagate': False,
+ },
+ 'stats': {
+ 'handlers': ['stats_file', 'console_stats'],
+ 'level': 'INFO',
+ 'propagate': False,
+ 'formatter': 'stats',
+ },
+ },
+
+ # Root loggers.
+ 'root': {
+ 'handlers': ['console', 'log_file'],
+ 'level': 'DEBUG',
+ 'propagate': True,
+ },
+}