Ouroboros Tutorial 04: Difference between revisions
No edit summary |
No edit summary |
||
Line 25: | Line 25: | ||
Save these configurations as a file on each machine - we chose to save them at /etc/ouroboros/tut04.conf - and start an IRMd on each machine with that config file. | Save these configurations as a file on each machine - we chose to save them at /etc/ouroboros/tut04.conf - and start an IRMd on each machine with that config file. | ||
The IRMd will log the use of the configuration file, create the service name for oping-server | The IRMd will log the use of the configuration file, on the raspberry pi it will create the service name for oping-server: | ||
dstaesse@raspberrypi:~ $ sudo irmd --stdout --config /etc/ouroboros/tut04.conf | dstaesse@raspberrypi:~ $ sudo irmd --stdout --config /etc/ouroboros/tut04.conf | ||
Line 33: | Line 33: | ||
==28267== irmd(II): Created new name: oping-server. | ==28267== irmd(II): Created new name: oping-server. | ||
==28267== irmd(II): Bound program /usr/bin/oping to name oping-server. | ==28267== irmd(II): Bound program /usr/bin/oping to name oping-server. | ||
The IRMd then bootstraps the IPCP | The IRMd then bootstraps the IPCP (this happens on both machines): | ||
==28267== irmd/configuration(DB): Found IPCP wifi1 in configuration file. | |||
==28267== irmd(II): Created IPCP 28279. | ==28267== irmd(II): Created IPCP 28279. | ||
==28267== irmd/configuration(DB): No hash specified, using default. | ==28267== irmd/configuration(DB): No hash specified, using default. | ||
Line 47: | Line 47: | ||
==28267== irmd(II): Bootstrapped IPCP 28279 in layer wifi-network. | ==28267== irmd(II): Bootstrapped IPCP 28279 in layer wifi-network. | ||
The ipcpd-eth-* detects the device MTU (which is usually 1500 bytes, but can be lower on virtual machine guests, or higher, for instance the loopback interface). The ipcpd-eth-* Layer MTU will be set to the device MTU, or to [[Ouroboros Build Parameters|IPCP_ETH_LO_MTU]] when using the loopback adapter. We will probably make the Layer MTU a runtime configuration parameter in the future, so it can be configured in the configuration file. The Raspberry Pi is using Linux, which defaults to a raw socket device for interfacing with Ethernet devices. Other options for interfacing with Ethernet are Berkeley Packet Filter (BPF) (for *BSD and OS X) or netmap (if installed). Our IPCP will process all packets on a specified Ethertype. The default value is 0xA000. | |||
The IRMd on the raspberry Pi will make the oping service available on the Ethernet 0-Layer: | |||
==28267== irmd/configuration(DB): Registering oping-server in 28279 | ==28267== irmd/configuration(DB): Registering oping-server in 28279 | ||
Line 54: | Line 56: | ||
==28279== ipcpd/ipcp(II): Finished registering f6c93ff2 : 0. | ==28279== ipcpd/ipcp(II): Finished registering f6c93ff2 : 0. | ||
==28267== irmd(II): Registered oping-server with IPCP 28279 as f6c93ff2. | ==28267== irmd(II): Registered oping-server with IPCP 28279 as f6c93ff2. | ||
With the IRMd started on both machines, we can start the oping server. We use the --quiet (-Q) option to reduce output in the example (oping -l -Q). | |||
In addition to demonstrating the use of the ipcpd-eth-dix, we will also show the use of ''encrypted flows''. To make this more visible, we dump the traffic on the Raspberry Pi's wlan0 device for ethertype 0xA000 using ''tcpdump''. | |||
When we ping (one ping only) from the desktop (oping -n oping-server -c 1), we see the following traffic on the wlan: | |||
<syntaxhighlight> | |||
dstaesse@raspberrypi:~ $ sudo tcpdump -i wlan0 ether proto 0xa000 | |||
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode | |||
listening on wlan0, link-type EN10MB (Ethernet), snapshot length 262144 bytes | |||
09:57:08.998005 c8:cb:9e:d0:04:08 (oui Unknown) > d8:3a:dd:39:0a:b5 (oui Unknown), ethertype Unknown (0xa000), length 88: | |||
0x0000: 0000 0046 0040 0000 0000 0001 0000 0000 ...F.@.......... | |||
0x0010: 0000 0000 0000 0001 ffff ffff ffff ffff ................ | |||
0x0020: 0001 d4c0 0000 0000 0000 f6c9 3ff2 3bd9 ............?.;. | |||
0x0030: 1094 3a77 8e7b 3faf 7bff ec03 796d b676 ..:w.{?.{...ym.v | |||
0x0040: 1bfa 5f70 758f 9ee2 e6fa .._pu..... | |||
09:57:09.000685 d8:3a:dd:39:0a:b5 (oui Unknown) > c8:cb:9e:d0:04:08 (oui Unknown), ethertype Unknown (0xa000), length 56: | |||
0x0000: 0000 0026 0040 0040 0000 0000 0000 0000 ...&.@.@........ | |||
0x0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................ | |||
0x0020: 0000 0000 0000 0001 0000 .......... | |||
09:57:10.020082 c8:cb:9e:d0:04:08 (oui Unknown) > d8:3a:dd:39:0a:b5 (oui Unknown), ethertype Unknown (0xa000), length 82: | |||
0x0000: 0040 0040 0000 0000 0000 0000 e307 0000 .@.@............ | |||
0x0010: 0000 0000 aa02 f70d 0000 0000 0000 0000 ................ | |||
0x0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................ | |||
0x0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................ | |||
0x0040: 0000 0000 .... | |||
09:57:10.020890 d8:3a:dd:39:0a:b5 (oui Unknown) > c8:cb:9e:d0:04:08 (oui Unknown), ethertype Unknown (0xa000), length 82: | |||
0x0000: 0040 0040 0000 0001 0000 0000 e307 0000 .@.@............ | |||
0x0010: 0000 0000 aa02 f70d 0000 0000 0000 0000 ................ | |||
0x0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................ | |||
0x0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................ | |||
0x0040: 0000 0000 | |||
</syntaxhighlight> |
Revision as of 09:52, 12 November 2023
In this tutorial, we show how to run oping between two machines connected to the same Ethernet LAN.
For the second machine, we use a Raspberry Pi Model 4B+ (ARM64, 32-bit Raspbian 11) connected to the same WiFi LAN as my desktop (Intel 13900KF, ArchLinux).
We chose the Ethernet DIX option, because our LLC packets sometimes get dropped on wireless LANs (protocol ossification at work). To use the LLC Ethernet 0-Layer, all that is needed is to change eth-dix to eth-llc in (both) the configuration files in this tutorial (left to the reader).
We run the server on the raspberry pi. The O7s config file for the Raspberry Pi connects to the wlan0 device and registers the "oping-server" application with the Ethernet 0-Layer:
[name."oping-server"] prog=["/usr/bin/oping"] args=["-l"]
[eth-dix.wifi1] bootstrap="wifi-network" dev="wlan0" reg=["oping-server"]
The configuration for the desktop machine (O7s client) is quite simple:
[eth-dix.wifi1] bootstrap="wifi-network" dev="wlan0"
Save these configurations as a file on each machine - we chose to save them at /etc/ouroboros/tut04.conf - and start an IRMd on each machine with that config file. The IRMd will log the use of the configuration file, on the raspberry pi it will create the service name for oping-server:
dstaesse@raspberrypi:~ $ sudo irmd --stdout --config /etc/ouroboros/tut04.conf ==28267== irmd(II): Ouroboros IPC Resource Manager daemon started... ==28267== irmd/configuration(II): Reading configuration from file /etc/ouroboros/tut04.conf ==28267== irmd/configuration(DB): Found service name oping-server in configuration file. ==28267== irmd(II): Created new name: oping-server. ==28267== irmd(II): Bound program /usr/bin/oping to name oping-server.
The IRMd then bootstraps the IPCP (this happens on both machines):
==28267== irmd/configuration(DB): Found IPCP wifi1 in configuration file. ==28267== irmd(II): Created IPCP 28279. ==28267== irmd/configuration(DB): No hash specified, using default. ==28279== ipcpd/ipcp(II): Bootstrapping... ==28279== ipcpd/eth-dix(DB): Device MTU is 1500. ==28279== ipcpd/eth-dix(DB): Layer MTU is 1500. ==28279== ipcpd/eth-dix(II): Using raw socket device. ==28279== ipcpd/eth-dix(DB): Bootstrapped IPCP over DIX Ethernet with pid 28279 and Ethertype 0xA000. ==28279== ipcpd/ipcp(II): Finished bootstrapping: 0. ==28267== irmd(II): Bootstrapped IPCP 28279 in layer wifi-network.
The ipcpd-eth-* detects the device MTU (which is usually 1500 bytes, but can be lower on virtual machine guests, or higher, for instance the loopback interface). The ipcpd-eth-* Layer MTU will be set to the device MTU, or to IPCP_ETH_LO_MTU when using the loopback adapter. We will probably make the Layer MTU a runtime configuration parameter in the future, so it can be configured in the configuration file. The Raspberry Pi is using Linux, which defaults to a raw socket device for interfacing with Ethernet devices. Other options for interfacing with Ethernet are Berkeley Packet Filter (BPF) (for *BSD and OS X) or netmap (if installed). Our IPCP will process all packets on a specified Ethertype. The default value is 0xA000.
The IRMd on the raspberry Pi will make the oping service available on the Ethernet 0-Layer:
==28267== irmd/configuration(DB): Registering oping-server in 28279 ==28267== irmd(WW): Name oping-server already exists. ==28279== ipcpd/ipcp(II): Registering f6c93ff2... ==28279== ipcpd/ipcp(II): Finished registering f6c93ff2 : 0. ==28267== irmd(II): Registered oping-server with IPCP 28279 as f6c93ff2.
With the IRMd started on both machines, we can start the oping server. We use the --quiet (-Q) option to reduce output in the example (oping -l -Q).
In addition to demonstrating the use of the ipcpd-eth-dix, we will also show the use of encrypted flows. To make this more visible, we dump the traffic on the Raspberry Pi's wlan0 device for ethertype 0xA000 using tcpdump.
When we ping (one ping only) from the desktop (oping -n oping-server -c 1), we see the following traffic on the wlan:
dstaesse@raspberrypi:~ $ sudo tcpdump -i wlan0 ether proto 0xa000
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode
listening on wlan0, link-type EN10MB (Ethernet), snapshot length 262144 bytes
09:57:08.998005 c8:cb:9e:d0:04:08 (oui Unknown) > d8:3a:dd:39:0a:b5 (oui Unknown), ethertype Unknown (0xa000), length 88:
0x0000: 0000 0046 0040 0000 0000 0001 0000 0000 ...F.@..........
0x0010: 0000 0000 0000 0001 ffff ffff ffff ffff ................
0x0020: 0001 d4c0 0000 0000 0000 f6c9 3ff2 3bd9 ............?.;.
0x0030: 1094 3a77 8e7b 3faf 7bff ec03 796d b676 ..:w.{?.{...ym.v
0x0040: 1bfa 5f70 758f 9ee2 e6fa .._pu.....
09:57:09.000685 d8:3a:dd:39:0a:b5 (oui Unknown) > c8:cb:9e:d0:04:08 (oui Unknown), ethertype Unknown (0xa000), length 56:
0x0000: 0000 0026 0040 0040 0000 0000 0000 0000 ...&.@.@........
0x0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0x0020: 0000 0000 0000 0001 0000 ..........
09:57:10.020082 c8:cb:9e:d0:04:08 (oui Unknown) > d8:3a:dd:39:0a:b5 (oui Unknown), ethertype Unknown (0xa000), length 82:
0x0000: 0040 0040 0000 0000 0000 0000 e307 0000 .@.@............
0x0010: 0000 0000 aa02 f70d 0000 0000 0000 0000 ................
0x0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0x0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0x0040: 0000 0000 ....
09:57:10.020890 d8:3a:dd:39:0a:b5 (oui Unknown) > c8:cb:9e:d0:04:08 (oui Unknown), ethertype Unknown (0xa000), length 82:
0x0000: 0040 0040 0000 0001 0000 0000 e307 0000 .@.@............
0x0010: 0000 0000 aa02 f70d 0000 0000 0000 0000 ................
0x0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0x0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0x0040: 0000 0000