Redundant ECSP Services HowTo

This document describes how to configure the ECSP services in a redundant train setup. The consists are depicted in Figure 1.

The result of the inauguration will be a network where ETBN1 in consist 1 has ETBN-ID 1, the IP-address 10.128.0.1 (based on the ETBN-ID and since the network is configured as TCMS). ETBN1 in consist 2 will attain ETBN-ID 2 and IP 10.128.0.2. ETBN2 in consist 2 will attain ETBN-ID 3 and IP 10.128.0.3. CN1 in consist 1 will attain the network IP 10.128.64.0/18, and CN1 in consist 2 IP 10.128.128.0/18.

        .-------.    .------------------------.
       /  cst1   \  /           cst2           \
       '---------'  '--------------------------'
        .-------.      .-------.    .-------.
      --+       +------+       +----+       +--      dir1 = (ethX5, ethX6)
  <-dir1| ETBN1 |      | ETBN1 |    | ETBN2 |dir2->  dir2 = (ethX7, ethX8)
      --+       +------+       +----+       +--
        '---+---'      '---+---'    '---+---'
            |              |            |
            |          --+-+------------+---- cst2-cn1 vlan10 (ethX3)
            |            |
            |          ECSC2
            |
          --+---+----- cst1-cn1 vlan10 (ethX3)
            |
          ECSC1

Figure 1: Acceessing ECSP in a redundant consist setup.

Note

In order to get two ETB nodes to manage a single consist net, they both need to have the exact same configuration with respect to uuid, node, In this example we also have the same ecn configuration. Also, the ETBN must have different local-id.

Note

Both nodes in consist 2 need to have VRRP configured and enabled on the CN side.

Configuration

The first configuration example shows how to configure ETBN1 in consist 1.

etbn1cst1:#> configure
etbn1cst1:/config/#> vlan 10
Creating new VLAN vid:10 with name: vlan10
etbn1cst1:/config/vlan-10/#> untagged ethX3
etbn1cst1:/config/vlan-10/#> end
etbn1cst1:/config/#> iface vlan10
etbn1cst1:/config/iface-vlan10/#> no inet
etbn1cst1:/config/iface-vlan10/#> inet static 10.0.0.10/18
etbn1cst1:/config/iface-vlan10/inet-static-10.0.0.10/#> end
etbn1cst1:/config/iface-vlan10/#> end
etbn1cst1:/config/#> ttdp
Activating TTDP with default settings.
etbn1cst1:/config/ttdp/#> uuid 11111111-1111-1111-1111-111111111111
etbn1cst1:/config/ttdp/#> node 1 ecn 1
etbn1cst1:/config/ttdp/#> ecn 1 vlan10
etbn1cst1:/config/ttdp/#> dir1 ethX5,ethX6
Remember to manually set mdi/mdi-x mode
 in port settings for all agg ports.
etbn1cst1:/config/ttdp/#> dir2 ethX7,ethX8
Remember to manually set mdi/mdi-x mode
 in port settings for all agg ports.
etbn1cst1:/config/ttdp/#> local-id 1
etbn1cst1:/config/ttdp/#> ecsp-iface vlan10
etbn1cst1:/config/ttdp/#> ecsp-addr 10.0.0.10
etbn1cst1:/config/ttdp/#> ecsc-addr 10.0.0.42
etbn1cst1:/config/ttdp/#> end
TTDP: Created VLAN 492. Note that this VLAN will not be deleted automatically
  if TTDP is deactivated.
etbn1cst1:/config/#> vlan 2
Creating new VLAN vid:2 with name: vlan2
etbn1cst1:/config/vlan-2/#> no multicast-snooping
etbn1cst1:/config/vlan-2/#> untagged lag-dir1,lag-dir2
etbn1cst1:/config/vlan-2/#> end

Continue by configuring the ports.

etbn1cst1:/config/#> port ethX5
etbn1cst1:/config/port-ethX5/#> speed-duplex 100-full
etbn1cst1:/config/port-ethX5/#> no auto-negotiate
etbn1cst1:/config/port-ethX5/#> fastlink
etbn1cst1:/config/port-ethX5/#> mdix-mode mdi
etbn1cst1:/config/port-ethX5/#> end
etbn1cst1:/config/#> port ethX6
etbn1cst1:/config/port-ethX6/#> speed-duplex 100-full
etbn1cst1:/config/port-ethX6/#> no auto-negotiate
etbn1cst1:/config/port-ethX6/#> fastlink
etbn1cst1:/config/port-ethX6/#> mdix-mode mdi
etbn1cst1:/config/port-ethX6/#> end
etbn1cst1:/config/#> port ethX7
etbn1cst1:/config/port-ethX7/#> speed-duplex 100-full
etbn1cst1:/config/port-ethX7/#> no auto-negotiate
etbn1cst1:/config/port-ethX7/#> fastlink
etbn1cst1:/config/port-ethX7/#> mdix-mode mdi
etbn1cst1:/config/port-ethX7/#> end
etbn1cst1:/config/#> port ethX8
etbn1cst1:/config/port-ethX8/#> speed-duplex 100-full
etbn1cst1:/config/port-ethX8/#> no auto-negotiate
etbn1cst1:/config/port-ethX8/#> fastlink
etbn1cst1:/config/port-ethX8/#> mdix-mode mdi
etbn1cst1:/config/port-ethX8/#> end
etbn1cst1:/config/#> end
Applying configuration.
Configuration activated.
Remember "copy run start" to save to flash (NVRAM).
etbn1cst1:/#>

Next, configure the ETBNs for consist 2. It contains of one consist network managed by two nodes.

Start with ETBN1 in consist 2 and configure vlans and the TTDP part.

etbn1cst2:#> configure
etbn1cst2:/config/#> vlan 10
Creating new VLAN vid:10 with name: vlan10
etbn1cst2:/config/vlan-10/#> untagged ethX3
etbn1cst2:/config/vlan-10/#> end
etbn1cst2:/config/#> iface vlan10
etbn1cst2:/config/iface-vlan10/#> no inet
etbn1cst2:/config/iface-vlan10/#> inet static 10.0.0.10/18
etbn1cst2:/config/iface-vlan10/inet-static-10.0.0.10/#> end
etbn1cst2:/config/iface-vlan10/#> end
etbn1cst2:/config/#> ttdp
Activating TTDP with default settings.
etbn1cst2:/config/ttdp/#> uuid 22222222-2222-2222-2222-222222222222
etbn1cst2:/config/ttdp/#> node 1 ecn 1
etbn1cst2:/config/ttdp/#> node 2 ecn 1
etbn1cst2:/config/ttdp/#> ecn 1 vlan10
etbn1cst2:/config/ttdp/#> dir1 ethX5,ethX6
Remember to manually set mdi/mdi-x mode
  in port settings for all agg ports.
etbn1cst2:/config/ttdp/#> dir2 ethX7,ethX8
Remember to manually set mdi/mdi-x mode
  in port settings for all agg ports.
etbn1cst2:/config/ttdp/#> local-id 1
etbn1cst2:/config/ttdp/#> ecsp-iface vlan10
etbn1cst2:/config/ttdp/#> ecsp-addr 10.0.0.10
etbn1cst2:/config/ttdp/#> ecsp-leader-addr 10.0.0.100
etbn1cst2:/config/ttdp/#> ecsc-addr 10.0.0.52
etbn1cst2:/config/ttdp/#> end
TTDP: Created VLAN 492. Note that this VLAN will not be deleted automatically
  if TTDP is deactivated.
etbn1cst2:/config/#> vlan 2
Creating new VLAN vid:2 with name: vlan2
etbn1cst2:/config/vlan-2/#> no multicast-snooping
etbn1cst2:/config/vlan-2/#> untagged lag-dir1,lag-dir2
etbn1cst2:/config/vlan-2/#> end

Continue by configuring the ports.

etbn1cst2:/config/#> port ethX5
etbn1cst2:/config/port-ethX5/#> speed-duplex 100-full
etbn1cst2:/config/port-ethX5/#> no auto-negotiate
etbn1cst2:/config/port-ethX5/#> fastlink
etbn1cst2:/config/port-ethX5/#> mdix-mode mdi
etbn1cst2:/config/port-ethX5/#> end
etbn1cst2:/config/#> port ethX6
etbn1cst2:/config/port-ethX6/#> speed-duplex 100-full
etbn1cst2:/config/port-ethX6/#> no auto-negotiate
etbn1cst2:/config/port-ethX6/#> fastlink
etbn1cst2:/config/port-ethX6/#> mdix-mode mdi
etbn1cst2:/config/port-ethX6/#> end
etbn1cst2:/config/#> port ethX7
etbn1cst2:/config/port-ethX7/#> speed-duplex 100-full
etbn1cst2:/config/port-ethX7/#> no auto-negotiate
etbn1cst2:/config/port-ethX7/#> fastlink
etbn1cst2:/config/port-ethX7/#> mdix-mode mdi
etbn1cst2:/config/port-ethX7/#> end
etbn1cst2:/config/#> port ethX8
etbn1cst2:/config/port-ethX8/#> speed-duplex 100-full
etbn1cst2:/config/port-ethX8/#> no auto-negotiate
etbn1cst2:/config/port-ethX8/#> fastlink
etbn1cst2:/config/port-ethX8/#> mdix-mode mdi
etbn1cst2:/config/port-ethX8/#> end

The next step is to configure VRRP on each node in the redundant consist, i.e., consist 2. Start with ETBN1 which will have the MASTER role. The MASTER role is gained by setting the priority for the VRRP instance higher than on ETBN2 (see VRRP).

etbn1cst2:/config/#> router
etbn1cst2:/config/router/#> vrrp cn1
Creating new VRRP instance: cn1
Invalid settings: Interface not set.
etbn1cst2:/config/router/vrrp-cn1/#> iface vlan1
Warning: No ports have been added to the configured VLAN.
VRRP will not work as expected with this configuration.
Invalid settings: Invalid IPv4 address.
etbn1cst2:/config/router/vrrp-cn1/#> address 10.0.0.100
Invalid settings: VRID invalid. Valid values: 1 to 255.
etbn1cst2:/config/router/vrrp-cn1/#> vrid 132
etbn1cst2:/config/router/vrrp-cn1/#> version 3
etbn1cst2:/config/router/vrrp-cn1/#> priority 150
etbn1cst2:/config/router/vrrp-cn1/#> interval 1
etbn1cst2:/config/router/vrrp-cn1/#> preempt delay 1
etbn1cst2:/config/router/vrrp-cn1/#> end
etbn1cst2:/config/router/#> end
etbn1cst2:/config/#> end
Applying configuration.
Configuration activated.
Remember "copy run start" to save to flash (NVRAM).
etbn1cst2:/#>

Now, repeat the exact steps above in the ETBN2 in consist 2.

etbn2cst2:#> configure
etbn2cst2:/config/#> vlan 10
Creating new VLAN vid:10 with name: vlan10
etbn2cst2:/config/vlan-10/#> untagged ethX3
etbn2cst2:/config/vlan-10/#> end
etbn2cst2:/config/#> iface vlan10
etbn2cst2:/config/iface-vlan10/#> no inet
etbn2cst2:/config/iface-vlan10/#> inet static 10.0.0.20/18
etbn2cst2:/config/iface-vlan10/inet-static-10.0.0.20/#> end
etbn2cst2:/config/iface-vlan10/#> end
etbn2cst2:/config/#> ttdp
Activating TTDP with default settings.
etbn2cst2:/config/ttdp/#> uuid 22222222-2222-2222-2222-222222222222
etbn2cst2:/config/ttdp/#> node 1 ecn 1
etbn2cst2:/config/ttdp/#> node 2 ecn 1
etbn2cst2:/config/ttdp/#> ecn 1 vlan10
etbn2cst2:/config/ttdp/#> dir1 ethX5,ethX6
Remember to manually set mdi/mdi-x mode
  in port settings for all agg ports.
etbn2cst2:/config/ttdp/#> dir2 ethX7,ethX8
Remember to manually set mdi/mdi-x mode
  in port settings for all agg ports.
etbn2cst2:/config/ttdp/#> local-id 2
etbn2cst2:/config/ttdp/#> ecsp-iface vlan10
etbn2cst2:/config/ttdp/#> ecsp-addr 10.0.0.10
etbn2cst2:/config/ttdp/#> ecsp-leader-addr 10.0.0.100
etbn2cst2:/config/ttdp/#> ecsc-addr 10.0.0.52
etbn2cst2:/config/ttdp/#> end
TTDP: Created VLAN 492. Note that this VLAN will not be deleted automatically
  if TTDP is deactivated.
etbn2cst2:/config/#> vlan 2
Creating new VLAN vid:2 with name: vlan2
etbn2cst2:/config/vlan-2/#> no multicast-snooping
etbn2cst2:/config/vlan-2/#> untagged lag-dir1,lag-dir2
etbn2cst2:/config/vlan-2/#> end

Continue by configuring the ports.

etbn2cst2:/config/#> port ethX5
etbn2cst2:/config/port-ethX5/#> speed-duplex 100-full
etbn2cst2:/config/port-ethX5/#> no auto-negotiate
etbn2cst2:/config/port-ethX5/#> fastlink
etbn2cst2:/config/port-ethX5/#> mdix-mode mdi
etbn2cst2:/config/port-ethX5/#> end
etbn2cst2:/config/#> port ethX6
etbn2cst2:/config/port-ethX6/#> speed-duplex 100-full
etbn2cst2:/config/port-ethX6/#> no auto-negotiate
etbn2cst2:/config/port-ethX6/#> fastlink
etbn2cst2:/config/port-ethX6/#> mdix-mode mdi
etbn2cst2:/config/port-ethX6/#> end
etbn2cst2:/config/#> port ethX7
etbn2cst2:/config/port-ethX7/#> speed-duplex 100-full
etbn2cst2:/config/port-ethX7/#> no auto-negotiate
etbn2cst2:/config/port-ethX7/#> fastlink
etbn2cst2:/config/port-ethX7/#> mdix-mode mdi
etbn2cst2:/config/port-ethX7/#> end
etbn2cst2:/config/#> port ethX8
etbn2cst2:/config/port-ethX8/#> speed-duplex 100-full
etbn2cst2:/config/port-ethX8/#> no auto-negotiate
etbn2cst2:/config/port-ethX8/#> fastlink
etbn2cst2:/config/port-ethX8/#> mdix-mode mdi
etbn2cst2:/config/port-ethX8/#> end

Note

In this HowTo, it is assumed that the ETB uses crossover cabling. For this reason, all ETB ports on both ETBNs use the same MDI-X mode. If non-crossover cabling is used, these settings must be changed for two of the inward-facing ETB ports.

Repeat the same steps for ETBN2 with a lower priority to make it backup. In this example the priority for the instance on ETBN2 is set to 100.

etbn2cst2:/config/#> router
etbn2cst2:/config/router/#> vrrp cn1
Creating new VRRP instance: cn1
Invalid settings: Interface not set.
etbn2cst2:/config/router/vrrp-cn1/#> iface vlan1
Warning: No ports have been added to the configured VLAN.
VRRP will not work as expected with this configuration.
Invalid settings: Invalid IPv4 address.
etbn2cst2:/config/router/vrrp-cn1/#> address 10.0.0.100
Invalid settings: VRID invalid. Valid values: 1 to 255.
etbn2cst2:/config/router/vrrp-cn1/#> vrid 132
etbn2cst2:/config/router/vrrp-cn1/#> version 3
etbn2cst2:/config/router/vrrp-cn1/#> priority 100
etbn2cst2:/config/router/vrrp-cn1/#> interval 1
etbn2cst2:/config/router/vrrp-cn1/#> preempt delay 1
etbn2cst2:/config/router/vrrp-cn1/#> end
etbn2cst2:/config/router/#> end
etbn2cst2:/config/#> end
Applying configuration.
Configuration activated.
Remember "copy run start" to save to flash (NVRAM).
etbn2cst2:/#>

Communication Profile Configuration

Finally, for the ECSPs to function properly, a communication profile configuration is needed on each node.

cst1 communication profile configuration
cst2 communication profile configuration

Transfer the communication profile configuration file to /cfg/comm-profile.json on each device.

The cst1 configuration file to ETBN1 in consist 1. The cst2 configuration file to ETBN1 and ETBN2 in consist 2.

Note

Ensure the filenames are correct. That is, they should have the name comm-profile.json in /cfg/ on their respective device.

Note

In the redundant consist here (cst2), both communicatio profile configuration files must be identical in both nodes in the consist.

See SCP HowTo for instructions on how to transfer files to the device or use the upload function on the TCN web configuration page.

When the above configuration is complete, the ECSP in cst1 uses IP address 10.0.0.10 on iface vlan10, while the ECSP in cst2 uses IP address 10.0.0.100 on iface vlan10.

To use the ECSP services on cst1, an ECSC client needs to be running on a host with IP address 10.0.0.42, and to use the ECSP services on cst2, an ECSC client needs to be running on a host with IP address 10.0.0.52.

Inauguration Result

Using the show ttdp command we now verify that we have recevied the intended network configuration. Highlighted in orange are the values that are of interest.

etbn1cst1:/#> show ttdp
TTDP NODE                                                                     
backbone-id  : 0 (tcms)
etbn-id      : 1
etbn-ip      : 10.128.0.1
local-id     : 1
own-mac      : 0c:65:8c:93:00:00
uuid         : 11111111-1111-1111-1111-111111111111
connTableCnt : 0x1d491819
EtbTopoCnt   : 0x80ea82ac
Inauguration : INAUGURATED
Inhibition   : Self: Off,  Others: Off,  Train: Off

CST-NET  IFACE     IP              CONNECTED ETBNs                            
   1     vlan10    10.0.0.10/18    1

NODE ID      MAC ADDRESS            ORIENTATION                               
      1      0c:65:8c:93:00:00      Direct
      2      0c:7a:40:ee:00:00      Direct
      3      0c:c8:64:98:00:00      Direct

CONSIST                               NODES   DIRECTION  NETWORKS             
11111111-1111-1111-1111-111111111111  1       Direct     10.128.64.0/18

etbn1cst1:/#>
etbn1cst2:/#> show ttdp
TTDP NODE                                                                     
backbone-id  : 0 (tcms)
etbn-id      : 2
etbn-ip      : 10.128.0.2
local-id     : 1
own-mac      : 0c:7a:40:ee:00:00
uuid         : 22222222-2222-2222-2222-222222222222
connTableCnt : 0x1d491819
EtbTopoCnt   : 0xf4b2eb52
Inauguration : INAUGURATED
Inhibition   : Self: Off,  Others: Off,  Train: Off

CST-NET  IFACE     IP              CONNECTED ETBNs                            
   1     vlan10    10.0.0.10/18    2,3

NODE ID      MAC ADDRESS            ORIENTATION                               
      1      0c:65:8c:93:00:00      Direct
      2      0c:7a:40:ee:00:00      Direct
      3      0c:c8:64:98:00:00      Direct

CONSIST                               NODES   DIRECTION  NETWORKS             
11111111-1111-1111-1111-111111111111  1       Direct     10.128.64.0/18
22222222-2222-2222-2222-222222222222  2..3    Direct     10.128.128.0/18

etbn1cst2:/#>
etbn2cst2:/#> show  ttdp
TTDP NODE                                                                     
backbone-id  : 0 (tcms)
etbn-id      : 3
etbn-ip      : 10.128.0.3
local-id     : 2
own-mac      : 0c:c8:64:98:00:00
uuid         : 22222222-2222-2222-2222-222222222222
connTableCnt : 0x1d491819
EtbTopoCnt   : 0xf4b2eb52
Inauguration : INAUGURATED
Inhibition   : Self: Off,  Others: Off,  Train: Off

CST-NET  IFACE     IP              CONNECTED ETBNs                            
   1     vlan10    10.0.0.2/18     2,3

NODE ID      MAC ADDRESS            ORIENTATION                               
      1      0c:65:8c:93:00:00      Direct
      2      0c:7a:40:ee:00:00      Direct
      3      0c:c8:64:98:00:00      Direct

CONSIST                               NODES   DIRECTION  NETWORKS             
11111111-1111-1111-1111-111111111111  1       Direct     10.128.64.0/18
22222222-2222-2222-2222-222222222222  2..3    Direct     10.128.128.0/18

etbn2cst2:/#>

Additionally, we can use the nslookup command to verify that the communication profile configuration has been read. A set of URIs has been chosen to verify that the DNS entries has been created.

etbn1cst1:/#> nslookup devDCU2.anyVeh.lCst.lTrn
Server:    127.0.0.1
Address 1: 127.0.0.1 localhost

Name:      devDCU2.anyVeh.lCst.lTrn
Address 1: 10.0.0.111
etbn1cst1:/#> nslookup devHVAC.anyVeh.lCst.lTrn
Server:    127.0.0.1
Address 1: 127.0.0.1 localhost

Name:      devHVAC.anyVeh.lCst.lTrn
Address 1: 10.0.0.100
etbn1cst1:/#> nslookup devCCUO2.anyVeh.lCst.lTrn
Server:    127.0.0.1
Address 1: 127.0.0.1 localhost

Name:      devCCUO2.anyVeh.lCst.lTrn
Address 1: 10.0.0.11
etbn1cst1:/#>