From ff14967282c43e847a55ea1f35bae2384ac8b8de Mon Sep 17 00:00:00 2001 From: log1cb0mb Date: Sun, 12 Sep 2021 20:26:29 +0300 Subject: [PATCH] Dell FTOS10v Support --- README.md | 1 + clab/config.go | 1 + docs/index.md | 1 + docs/manual/kinds/vr-ftosv.md | 43 ++++++++++++++++++ docs/manual/vrnetlab.md | 3 ++ mkdocs.yml | 1 + nodes/all/all.go | 1 + nodes/node.go | 2 + nodes/vr_ftosv/vr-ftosv.go | 83 +++++++++++++++++++++++++++++++++++ schemas/clab.schema.json | 1 + 10 files changed, 137 insertions(+) create mode 100644 docs/manual/kinds/vr-ftosv.md create mode 100644 nodes/vr_ftosv/vr-ftosv.go diff --git a/README.md b/README.md index e069587f8..d9d124f2a 100644 --- a/README.md +++ b/README.md @@ -30,6 +30,7 @@ In addition to native containerized NOSes, containerlab can launch traditional v * [Cisco IOS XRv9k](https://containerlab.srlinux.dev/manual/kinds/vr-xrv9k/) * [Cisco Nexus 9000v](https://containerlab.srlinux.dev/manual/kinds/vr-n9kv) * [Cisco CSR 1000v](https://containerlab.srlinux.dev/manual/kinds/vr-csr) +* [Dell FTOS10v](https://containerlab.srlinux.dev/manual/kinds/vr-ftosv) * [Arista vEOS](https://containerlab.srlinux.dev/manual/kinds/vr-veos) * [Palo Alto PAN](https://containerlab.srlinux.dev/manual/kinds/vr-pan) diff --git a/clab/config.go b/clab/config.go index af753d741..f2e4e19ed 100644 --- a/clab/config.go +++ b/clab/config.go @@ -54,6 +54,7 @@ var kinds = []string{ "ceos", "crpd", "sonic-vs", + "vr-ftosv", "vr-n9kv", "vr-sros", "vr-vmx", diff --git a/docs/index.md b/docs/index.md index 1e93e8541..dd2d73328 100644 --- a/docs/index.md +++ b/docs/index.md @@ -27,6 +27,7 @@ In addition to native containerized NOSes, containerlab can launch traditional v * [Juniper vMX](manual/kinds/vr-vmx.md) * [Cisco IOS XRv9k](manual/kinds/vr-xrv9k.md) * [Cisco Nexus 9000v](manual/kinds/vr-n9kv.md) +* [Dell FTOS10v](manual/kinds/vr-ftosv.md) * [Cisco CSR 1000v](manual/kinds/vr-csr.md) * [Arista vEOS](manual/kinds/vr-veos.md) * [Palo Alto PAN](manual/kinds/vr-pan.md) diff --git a/docs/manual/kinds/vr-ftosv.md b/docs/manual/kinds/vr-ftosv.md new file mode 100644 index 000000000..ec084fbb1 --- /dev/null +++ b/docs/manual/kinds/vr-ftosv.md @@ -0,0 +1,43 @@ +# Dell FTOSv (OS10) / ftosv + +Dell FTOSv (OS10) virtualized router/switch is identified with `vr-ftosv` kind in the [topology file](../topo-def-file.md). It is built using [vrnetlab](../vrnetlab.md) project and essentially is a Qemu VM packaged in a docker container format. + +vr-ftosv nodes launched with containerlab comes up pre-provisioned with SSH and SNMP services enabled. + +## Managing vr-ftosv nodes + +!!!note + Containers with FTOS10v inside will take ~2-4min to fully boot. + You can monitor the progress with `docker logs -f `. + +Dell FTOS10v node launched with containerlab can be managed via the following interfaces: + +=== "bash" + to connect to a `bash` shell of a running vr-ftosv container: + ```bash + docker exec -it bash + ``` +=== "CLI" + to connect to the Dell FTOSv CLI + ```bash + ssh admin@ + ``` + +!!!info + Default user credentials: `admin:admin` + +## Interfaces mapping +vr-ftosv container can have different number of available interfaces which depends on platform used under FTOS10 virtualization .qcow2 disk and container image built using [vrnetlab](../vrnetlab.md) project. Interfaces uses the following mapping rules (in topology file): + +* `eth0` - management interface connected to the containerlab management network +* `eth1` - first data interface, mapped to first data port of FTOS10v line card +* `eth2+` - second and subsequent data interface + +When containerlab launches vr-ftosv node, it will assign IPv4/6 address to the `eth0` interface. These addresses can be used to reach management plane of the router. + +Data interfaces `eth1+` needs to be configured with IP addressing manually using CLI/management protocols. + + +## Features and options +### Node configuration +vr-ftosv nodes come up with a basic configuration where only `admin` user and management interfaces such as SSH provisioned. diff --git a/docs/manual/vrnetlab.md b/docs/manual/vrnetlab.md index ea2acc547..85dd8c74f 100644 --- a/docs/manual/vrnetlab.md +++ b/docs/manual/vrnetlab.md @@ -69,6 +69,9 @@ The images that work with containerlab will appear in the supported list gradual | MikroTik RouterOS | [vr-ros](kinds/vr-ros.md) | | | | Palo Alto PAN | [vr-pan](kinds/vr-pan.md) | | | | Cisco Nexus 9000v | [vr-n9kv](kinds/vr-n9kv.md) | | | +| Dell FTOS10v | [vr-ftosv](kinds/vr-ftosv.md) | | | + + ### Connection modes diff --git a/mkdocs.yml b/mkdocs.yml index 7e051b91b..b56986cff 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -19,6 +19,7 @@ nav: - vr-xrv - Cisco XRv: manual/kinds/vr-xrv.md - vr-csr - Cisco CSR1000v: manual/kinds/vr-csr.md - vr-n9kv - Cisco Nexus 9000v: manual/kinds/vr-n9kv.md + - vr-ftosv - Dell FTOS10v: manual/kinds/vr-ftosv.md - vr-veos - Arista vEOS: manual/kinds/vr-veos.md - vr-ros - MikroTik RouterOS: manual/kinds/vr-ros.md - vr-pan - Palo Alto PAN: manual/kinds/vr-pan.md diff --git a/nodes/all/all.go b/nodes/all/all.go index b69c9fa4f..8acca3d85 100644 --- a/nodes/all/all.go +++ b/nodes/all/all.go @@ -19,6 +19,7 @@ import ( _ "github.com/srl-labs/containerlab/nodes/vr_nxos" _ "github.com/srl-labs/containerlab/nodes/vr_pan" _ "github.com/srl-labs/containerlab/nodes/vr_n9kv" + _ "github.com/srl-labs/containerlab/nodes/vr_ftosv" _ "github.com/srl-labs/containerlab/nodes/vr_ros" _ "github.com/srl-labs/containerlab/nodes/vr_sros" _ "github.com/srl-labs/containerlab/nodes/vr_veos" diff --git a/nodes/node.go b/nodes/node.go index 19c7a66e1..7cb7f4dfe 100644 --- a/nodes/node.go +++ b/nodes/node.go @@ -36,6 +36,7 @@ const ( NodeKindVrCSR = "vr-csr" NodeKindVrPAN = "vr-pan" NodeKindVrN9KV = "vr-n9kv" + NodeKindVrFTOSV = "vr-ftosv" NodeKindVrROS = "vr-ros" NodeKindVrSROS = "vr-sros" NodeKindVrVEOS = "vr-veos" @@ -99,6 +100,7 @@ var DefaultCredentials = map[string][]string{ "srl": {"admin", "admin"}, "vr-pan": {"admin", "Admin@123"}, "vr-n9kv": {"admin", "admin"}, + "vr-ftosv": {"admin", "admin"}, "vr-sros": {"admin", "admin"}, "vr-vmx": {"admin", "admin@123"}, "vr-xrv9k": {"clab", "clab@123"}, diff --git a/nodes/vr_ftosv/vr-ftosv.go b/nodes/vr_ftosv/vr-ftosv.go new file mode 100644 index 000000000..45d2f05f3 --- /dev/null +++ b/nodes/vr_ftosv/vr-ftosv.go @@ -0,0 +1,83 @@ +// Copyright 2020 Nokia +// Licensed under the BSD 3-Clause License. +// SPDX-License-Identifier: BSD-3-Clause + +package vr_ftosv + +import ( + "context" + "fmt" + + "github.com/srl-labs/containerlab/nodes" + "github.com/srl-labs/containerlab/runtime" + "github.com/srl-labs/containerlab/types" + "github.com/srl-labs/containerlab/utils" +) + +func init() { + nodes.Register(nodes.NodeKindVrFTOSV, func() nodes.Node { + return new(vrFtosv) + }) +} + +type vrFtosv struct { + cfg *types.NodeConfig + mgmt *types.MgmtNet + runtime runtime.ContainerRuntime +} + +func (s *vrFtosv) Init(cfg *types.NodeConfig, opts ...nodes.NodeOption) error { + s.cfg = cfg + for _, o := range opts { + o(s) + } + // env vars are used to set launch.py arguments in vrnetlab container + defEnv := map[string]string{ + "CONNECTION_MODE": nodes.VrDefConnMode, + "USERNAME": "admin", + "PASSWORD": "admin", + "DOCKER_NET_V4_ADDR": s.mgmt.IPv4Subnet, + "DOCKER_NET_V6_ADDR": s.mgmt.IPv6Subnet, + } + s.cfg.Env = utils.MergeStringMaps(defEnv, s.cfg.Env) + + if s.cfg.Env["CONNECTION_MODE"] == "macvtap" { + // mount dev dir to enable macvtap + s.cfg.Binds = append(s.cfg.Binds, "/dev:/dev") + } + + s.cfg.Cmd = fmt.Sprintf("--username %s --password %s --hostname %s --connection-mode %s --trace", + s.cfg.Env["USERNAME"], s.cfg.Env["PASSWORD"], s.cfg.ShortName, s.cfg.Env["CONNECTION_MODE"]) + return nil +} +func (s *vrFtosv) Config() *types.NodeConfig { return s.cfg } +func (s *vrFtosv) PreDeploy(configName, labCADir, labCARoot string) error { + utils.CreateDirectory(s.cfg.LabDir, 0777) + return nil +} +func (s *vrFtosv) Deploy(ctx context.Context) error { + _, err := s.runtime.CreateContainer(ctx, s.cfg) + return err +} +func (s *vrFtosv) PostDeploy(ctx context.Context, ns map[string]nodes.Node) error { + return nil +} + +func (s *vrFtosv) GetImages() map[string]string { + return map[string]string{ + nodes.ImageKey: s.cfg.Image, + } +} + +func (s *vrFtosv) Destroy(ctx context.Context) error { return nil } +func (s *vrFtosv) WithMgmtNet(mgmt *types.MgmtNet) { s.mgmt = mgmt } +func (s *vrFtosv) WithRuntime(r runtime.ContainerRuntime) { s.runtime = r } +func (s *vrFtosv) GetRuntime() runtime.ContainerRuntime { return s.runtime } + +func (s *vrFtosv) Delete(ctx context.Context) error { + return s.runtime.DeleteContainer(ctx, s.Config().LongName) +} + +func (s *vrFtosv) SaveConfig(ctx context.Context) error { + return nil +} diff --git a/schemas/clab.schema.json b/schemas/clab.schema.json index ee5f8d532..78c466042 100644 --- a/schemas/clab.schema.json +++ b/schemas/clab.schema.json @@ -32,6 +32,7 @@ "vr-pan", "vr-ros", "vr-n9kv", + "vr-ftosv", "linux", "bridge", "ovs-bridge",