Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Extended simple-nva module to manage BGP service running on FR routing docker container #1195

Merged
merged 46 commits into from
Mar 8, 2023
Merged
Show file tree
Hide file tree
Changes from 40 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
ebb4bf7
add frr configuration for running bgp on the nva
simonebruzzechesse Feb 27, 2023
c7fefa8
add ip masquerading config on network interfaces
simonebruzzechesse Feb 28, 2023
12fd6de
small fixes
simonebruzzechesse Feb 28, 2023
822cd83
fmt terraform code
simonebruzzechesse Feb 28, 2023
2fe6572
fix variable description
simonebruzzechesse Feb 28, 2023
3aafecf
remove redundant check on LB ip address
simonebruzzechesse Feb 28, 2023
a6ac4cd
Merge branch 'master' into simple-nva
simonebruzzechesse Feb 28, 2023
e2602f9
Merge branch 'master' into simple-nva
simonebruzzechesse Feb 28, 2023
4cdc5c1
Fix secondary ranges in net-vpc readme (#1198)
ludoo Mar 1, 2023
c11b07e
Add test for #1197
juliocc Mar 1, 2023
b842bd7
Add missing tfvars template to the tfc blueprint
averbuks Mar 1, 2023
cbb40a2
Add more explicit template
averbuks Mar 1, 2023
2efdef5
Missing newline
averbuks Mar 1, 2023
88af3bf
Fix tfvars template
averbuks Mar 1, 2023
0f6e94a
Fix Variables
lcaggio Mar 1, 2023
d53ea84
Fix linting
lcaggio Mar 1, 2023
7fd3ebc
Update README.
lcaggio Mar 1, 2023
6c12a33
Update README
lcaggio Mar 1, 2023
bffdb29
Remove wrongly submitted file.
lcaggio Mar 1, 2023
06a6a2c
Fix README
lcaggio Mar 1, 2023
0ed0a5a
Fix url_redirect issue on net-glb module (#1204)
erabusi Mar 2, 2023
4d948b3
Blueprint: GLB hybrid NEG internal
LucaPrete Mar 2, 2023
2915177
Fix issue with GKE cluster notifications topic, change pubsub module …
rosmo Mar 2, 2023
5b433d8
small fixes
simonebruzzechesse Mar 2, 2023
ac6aa5f
small fixes
simonebruzzechesse Mar 2, 2023
740d8cd
fmt terraform
simonebruzzechesse Mar 2, 2023
23ab4df
Merge branch 'master' into simple-nva
simonebruzzechesse Mar 2, 2023
db5dd14
update README
simonebruzzechesse Mar 2, 2023
8f2e0ac
fix issue in README
simonebruzzechesse Mar 2, 2023
04377fc
fmt terraform code in example in README
simonebruzzechesse Mar 2, 2023
a085213
update copyright on outdated files
simonebruzzechesse Mar 3, 2023
c147c80
update copyright on poutdated ones
simonebruzzechesse Mar 3, 2023
cccf5e6
small fixes
simonebruzzechesse Mar 3, 2023
a2fcce0
upgrade terraform required version for simple-nva module
simonebruzzechesse Mar 3, 2023
4a0b080
add simple BGP configuration for BGP session with neighbor
simonebruzzechesse Mar 3, 2023
0dd3349
add _ on local values not referenced outside locals
simonebruzzechesse Mar 3, 2023
6961158
add sample frr.conf file in README
simonebruzzechesse Mar 6, 2023
c7ae02c
remove typo
simonebruzzechesse Mar 6, 2023
7caaf28
formatted example code
simonebruzzechesse Mar 6, 2023
1975619
Merge branch 'master' into simple-nva
simonebruzzechesse Mar 6, 2023
42f963a
small fixes
simonebruzzechesse Mar 7, 2023
648e7dc
small fixes
simonebruzzechesse Mar 7, 2023
7e41adf
fix documentation
simonebruzzechesse Mar 7, 2023
0a8b500
Merge branch 'master' into simple-nva
simonebruzzechesse Mar 7, 2023
281e57b
Merge branch 'master' into simple-nva
simonebruzzechesse Mar 7, 2023
1b383f1
Merge branch 'master' into simple-nva
simonebruzzechesse Mar 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
67 changes: 67 additions & 0 deletions fast/stages/2-networking-c-nva/bgp-files/ew1b
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
log syslog informational
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
no ipv6 forwarding
service integrated-vtysh-config
interface lo
ip address 10.128.0.101/32
route-map ALLOW-ALL permit 100
route-map PRIMARY permit 10
set metric 100
route-map SECONDARY permit 20
set metric 10100
route-map NVA-TO-NVA permit 30
set metric 50
router bgp 65514 view trusted
no bgp ebgp-requires-policy
no bgp network import-check
neighbor 10.128.64.201 remote-as 64515
neighbor 10.128.64.202 remote-as 64515
address-family ipv4 unicast
neighbor 10.128.64.201 activate
neighbor 10.128.64.201 soft-reconfiguration inbound
neighbor 10.128.64.202 activate
neighbor 10.128.64.202 soft-reconfiguration inbound
network 10.128.0.0/24 route-map PRIMARY
network 0.0.0.0/0 route-map PRIMARY
network 10.128.32.0/24 route-map SECONDARY
exit-address-family
router bgp 65514
bgp router-id 10.128.0.101
no bgp ebgp-requires-policy
no bgp network import-check
neighbor 10.128.32.101 remote-as 65513
neighbor 10.128.32.101 update-source lo
neighbor 10.128.32.101 ebgp-multihop 2
neighbor 10.128.32.101 next-hop-self
neighbor 10.128.32.102 remote-as 65513
neighbor 10.128.32.102 update-source lo
neighbor 10.128.32.102 ebgp-multihop 2
neighbor 10.128.32.102 next-hop-self
address-family ipv4 unicast
neighbor 10.128.32.101 activate
neighbor 10.128.32.101 soft-reconfiguration inbound
neighbor 10.128.32.102 activate
neighbor 10.128.32.102 soft-reconfiguration inbound
network 10.128.192.0/24 route-map NVA-TO-NVA
network 10.128.128.0/24 route-map NVA-TO-NVA
network 10.128.48.0/24 route-map NVA-TO-NVA
exit-address-family
router bgp 65514 view untrusted
no bgp ebgp-requires-policy
no bgp network import-check
neighbor 10.128.0.201 remote-as 64515
neighbor 10.128.0.202 remote-as 64515
address-family ipv4 unicast
neighbor 10.128.0.201 activate
neighbor 10.128.0.201 soft-reconfiguration inbound
neighbor 10.128.0.202 activate
neighbor 10.128.0.202 soft-reconfiguration inbound
network 10.128.0.0/27 route-map PRIMARY
network 10.0.0.0/8 route-map PRIMARY
network 172.16.0.0/12 route-map PRIMARY
network 192.168.0.0/16 route-map PRIMARY
network 10.128.96.0/24 route-map SECONDARY
network 10.128.128.0/24 route-map PRIMARY
network 10.128.48.0/24 route-map PRIMARY
network 10.128.192.0/24 route-map PRIMARY
exit-address-family
line vty
81 changes: 80 additions & 1 deletion modules/cloud-config-container/simple-nva/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -62,16 +62,95 @@ module "vm" {
}
# tftest modules=1 resources=1
```

### Example with advanced routing capabilities

Below a sample terraform example for bootstrapping a simple-nva powered by [COS](https://cloud.google.com/container-optimized-os/docs) and running [FRRouting](https://frrouting.org/) container.
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
Please find below s sample frr.conf file based on documentation available at the following [link](https://docs.frrouting.org/en/latest/basic.html) for hosting a BGP service with ASN 65001 on FRR container establishing a BGP session with a remote neighbor with IP address 10.128.0.2 and ASN 65002.
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved

```
# tftest-file id=frr_conf path=./frr.conf
# Example frr.conmf file

log syslog informational
no ipv6 forwarding
router bgp 65001
neighbor 10.128.0.2 remote-as 65002
line vty
```

Following code assumes a file in the same folder named frr.conf exists.

```hcl
locals {
network_interfaces = [
{
addresses = null
name = "dev"
nat = false
network = "dev_vpc_self_link"
routes = ["10.128.0.0/9"]
subnetwork = "dev_vpc_nva_subnet_self_link"
enable_masquerading = true
non_masq_cidrs = ["10.0.0.0/8"]
},
{
addresses = null
name = "prod"
nat = false
network = "prod_vpc_self_link"
routes = ["10.0.0.0/9"]
subnetwork = "prod_vpc_nva_subnet_self_link"
}
]
}

module "cos-nva" {
source = "./fabric/modules/cloud-config-container/simple-nva"
enable_health_checks = true
network_interfaces = local.network_interfaces
frr_config = { config_file = "./frr.conf", daemons_enabled = ["bgpd"] }
optional_run_cmds = ["ls -l"]
# files = {
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
# "/var/lib/cloud/scripts/per-boot/firewall-rules.sh" = {
# content = file("./your_path/to/firewall-rules.sh")
# owner = "root"
# permissions = 0700
# }
# }
}

module "vm" {
source = "./fabric/modules/compute-vm"
project_id = "my-project"
zone = "europe-west8-b"
name = "cos-nva"
network_interfaces = local.network_interfaces
metadata = {
user-data = module.cos-nva.cloud_config
google-logging-enabled = true
}
boot_disk = {
image = "projects/cos-cloud/global/images/family/cos-stable"
type = "pd-ssd"
size = 10
}
tags = ["nva", "ssh"]
}
# tftest modules=1 resources=1 files=frr_conf
```
<!-- BEGIN TFDOC -->

## Variables

| name | description | type | required | default |
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
|---|---|:---:|:---:|:---:|
| [network_interfaces](variables.tf#L39) | Network interfaces configuration. | <code title="list&#40;object&#40;&#123;&#10; routes &#61; optional&#40;list&#40;string&#41;&#41;&#10;&#125;&#41;&#41;">list&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | ✓ | |
| [network_interfaces](variables.tf#L54) | Network interfaces configuration. | <code title="list&#40;object&#40;&#123;&#10; routes &#61; optional&#40;list&#40;string&#41;&#41;&#10; enable_masquerading &#61; optional&#40;bool, false&#41;&#10; non_masq_cidrs &#61; optional&#40;list&#40;string&#41;&#41;&#10;&#125;&#41;&#41;">list&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | ✓ | |
| [cloud_config](variables.tf#L17) | Cloud config template path. If null default will be used. | <code>string</code> | | <code>null</code> |
| [enable_health_checks](variables.tf#L23) | Configures routing to enable responses to health check probes. | <code>bool</code> | | <code>false</code> |
| [files](variables.tf#L29) | Map of extra files to create on the instance, path as key. Owner and permissions will use defaults if null. | <code title="map&#40;object&#40;&#123;&#10; content &#61; string&#10; owner &#61; string&#10; permissions &#61; string&#10;&#125;&#41;&#41;">map&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | | <code>&#123;&#125;</code> |
| [frr_config](variables.tf#L39) | FRR configuration for container running on the NVA. | <code title="object&#40;&#123;&#10; daemons_enabled &#61; optional&#40;list&#40;string&#41;&#41;&#10; config_file &#61; string&#10;&#125;&#41;">object&#40;&#123;&#8230;&#125;&#41;</code> | | <code>null</code> |
| [optional_run_cmds](variables.tf#L63) | Optional Cloud Init run commands to execute. | <code>list&#40;string&#41;</code> | | <code>&#91;&#93;</code> |

## Outputs

Expand Down
14 changes: 12 additions & 2 deletions modules/cloud-config-container/simple-nva/cloud-config.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#cloud-config

# Copyright 2022 Google LLC
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
Expand All @@ -22,6 +22,7 @@ write_files:
content: |
${indent(6, data.content)}
%{ endfor }

- path: /etc/systemd/system/routing.service
permissions: 0644
owner: root
Expand All @@ -34,6 +35,7 @@ write_files:
Wants=network-online.target
[Service]
ExecStart=/bin/sh -c "/var/run/nva/start-routing.sh"

- path: /var/run/nva/start-routing.sh
permissions: 0744
owner: root
Expand All @@ -43,6 +45,12 @@ write_files:
%{ if enable_health_checks ~}
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
/var/run/nva/policy_based_routing.sh ${interface.name}
%{ endif ~}
%{ if interface.enable_masquerading ~}
%{ for cidr in interface.non_masq_cidrs ~}
iptables -t nat -A POSTROUTING -o ${interface.name} -d ${cidr} -j ACCEPT
%{ endfor ~}
iptables -t nat -A POSTROUTING -o ${interface.name} -j MASQUERADE
%{ endif ~}
%{ for route in interface.routes ~}
ip route add ${route} via `curl http://metadata.google.internal/computeMetadata/v1/instance/network-interfaces/${interface.number}/gateway -H "Metadata-Flavor:Google"` dev ${interface.name}
%{ endfor ~}
Expand All @@ -55,4 +63,6 @@ runcmd:
- systemctl daemon-reload
- systemctl enable routing
- systemctl start routing

%{ for cmd in optional_run_cmds ~}
- ${cmd}
%{ endfor ~}
66 changes: 66 additions & 0 deletions modules/cloud-config-container/simple-nva/files/frr/daemons
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

zebra=${zebra_enabled}
bgpd=${bgpd_enabled}
ospfd=${ospfd_enabled}
ospf6d=${ospf6d_enabled}
ripd=${ripd_enabled}
ripngd=${ripngd_enabled}
isisd=${isisd_enabled}
pimd=${pimd_enabled}
ldpd=${ldpd_enabled}
nhrpd=${nhrpd_enabled}
eigrpd=${eigrpd_enabled}
babeld=${babeld_enabled}
sharpd=${sharpd_enabled}
staticd=${staticd_enabled}
pbrd=${pbrd_enabled}
bfdd=${bfdd_enabled}
fabricd=${fabricd_enabled}

#
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
# If this option is set the /etc/init.d/frr script automatically loads
# the config via "vtysh -b" when the servers are started.
# Check /etc/pam.d/frr if you intend to use "vtysh"!
#
LucaPrete marked this conversation as resolved.
Show resolved Hide resolved
vtysh_enable=yes
zebra_options=" -A 127.0.0.1 -s 90000000"
bgpd_options=" -A 127.0.0.1"
ospfd_options=" --daemon -A 127.0.0.1"
ospf6d_options=" --daemon -A ::1"
ripd_options=" --daemon -A 127.0.0.1"
ripngd_options=" --daemon -A ::1"
isisd_options=" --daemon -A 127.0.0.1"
pimd_options=" --daemon -A 127.0.0.1"
ldpd_options=" --daemon -A 127.0.0.1"
nhrpd_options=" --daemon -A 127.0.0.1"
eigrpd_options=" --daemon -A 127.0.0.1"
babeld_options=" --daemon -A 127.0.0.1"
sharpd_options=" --daemon -A 127.0.0.1"
staticd_options=" --daemon -A 127.0.0.1"
pbrd_options=" --daemon -A 127.0.0.1"
bfdd_options=" --daemon -A 127.0.0.1"
fabricd_options=" --daemon -A 127.0.0.1"

#MAX_FDS=1024
# The list of daemons to watch is automatically generated by the init script.
#watchfrr_options=""

# for debugging purposes, you can specify a "wrap" command to start instead
# of starting the daemon directly, e.g. to use valgrind on ospfd:
# ospfd_wrap="/usr/bin/valgrind"
# or you can use "all_wrap" for all daemons, e.g. to use perf record:
# all_wrap="/usr/bin/perf record --call-graph -"
# the normal daemon command is added to this at the end.
27 changes: 27 additions & 0 deletions modules/cloud-config-container/simple-nva/files/frr/frr.service
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

[Unit]
Description=Start FRR container
After=gcr-online.target docker.socket
Wants=gcr-online.target docker.socket docker-events-collector.service
[Service]
Environment="HOME=/home/frr"
ExecStart=/usr/bin/docker run --rm --name=frr \
--privileged \
--network host \
-v /etc/frr:/etc/frr \
frrouting/frr
ExecStop=/usr/bin/docker stop frr
ExecStopPost=/usr/bin/docker rm frr
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/bin/bash

# Copyright 2022 Google LLC
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/bin/bash

# Copyright 2022 Google LLC
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
Expand Down
Loading