Overview
With the evolution of IoT and Edge Computing use cases, multi-access becomes a growing requirement to enable resilient connectivity and improve user experience for the newly emerging applications such as Autonomous Mobile Robots (AMRs), AR/VR, and Smart Cities applications.
This Reference Implementation (RI) provides a software-defined multi-access solution that is agnostic to the connectivity technologies and the underlying protocols. This solution is tested with Smart Edge Private Wireless Experience Kit (PWEK) considering Cellular and Wi-Fi* connectivity for private 5G.
To run the reference implementation, you will need to first download and install the Intel® Smart Edge Private Wireless Experience Kit.
Once you have installed the Intel® Smart Edge Private Wireless Experience Kit, select Configure & Download to download the reference implementation and then follow the steps below to install it.
- Time to Complete: 120 - 150 minutes
- Programming Language: Python*
- Software: Intel® Smart Edge 22.04.01 PWEK Release (Currently tested but the Reference Implementation is forward compatible with PWEK releases).
Target System Requirements
Edge Controller
-
One of the following processors:
-
Intel® Xeon® Scalable processor.
-
Intel® Xeon® Processor D.
-
-
At least 64 GB RAM.
-
At least 256 GB hard drive.
-
An Internet connection.
-
CentOS* 7.9.2009.
Edge Nodes
-
One of the following processors:
-
Intel® Xeon® Scalable processor.
-
Intel® Xeon® Processor D.
-
-
At least 64 GB RAM.
-
At least 256 GB hard drive.
-
An Internet connection.
-
CentOS* 7.9.2009.
-
User Equipment: HUAWEI* Mate30 pro
Client Device
-
Laptop supporting Wi-Fi and cellular (or Wi-Fi + cellular/USB tethering) Sample: Lenovo* ThinkBook* 13s G2 ITL
-
Ubuntu* 20.04
-
Wi-Fi Access Point
How It Works
The solution has a client software part (running at the PC/UE/IoT device side) and a server software part (running at the Edge Server). The Generic Multi-Access (GMA) client software connects to the GMA server software over cellular and Wi-Fi connectivity.
Figure 1: How It Works
At the very beginning, the client has only one connection established (e.g., cellular) and will try to establish the second connection. After both connections are established, the client will then establish a websocket-based secure connection between the client and the server to exchange messages. A new protocol layer is introduced by GMA to handle all multi-path related operations.
Figure 2: Architecture Diagram for GMA with Intel® Smart Edge
Get Started
Prerequisites
To run the reference implementation, you will need to first download and install the Intel® Smart Edge Private Wireless Experience Kit.
Ensure that the following conditions are met properly to have a smooth installation process for the reference implementation with Intel® Smart Edge Private Wireless Experience Kit.
-
Hardware Requirements
Make sure you have a fresh CentOS* 7.9.2009 installation with the Hardware specified in the Target System Requirements section.
-
Network connections
-
Laptop connected to Wi-Fi through Wi-Fi access point, which is connected to 100GbE Intel® Ethernet Network Adapter E810.
-
Laptop connected to cellular network through cellular tethering.
-
Step 1: Install the Reference Implementation
NOTE: The following sections may use
<Controller_IP>
in a URL or command. Make note of your Edge Controller’s IP address and substitute it in these instructions.
Select Configure & Download to download the reference implementation and then follow the steps below to install it.
-
Make sure that the Target System Requirements are met properly before proceeding further.
-
If you are behind a proxy network, be sure that proxy addresses are configured in the system:
-
Under the user deploy PWEK, for example smartedge-open, download the GMA RI package:
-
Open a new terminal and move the downloaded .zip package to the
/home/smartedge-open
folder: -
Go to the
/home/smartedge-open
directory using the following command and unzip the RI: -
Go to the
multi-access-with-private-5g/
directory:Three files will be generated: server.key, server.csr and server.crt.
-
Apply the Network Attachment Definition and network policy:
-
Change permissions of the executable edgesoftware file to enable execution:
-
Run the command below to install the Reference Implementation:
NOTE: Installation logs are available at path:
/var/log/esb-cli/Multi-access-with-private-5g_<version>/<Component_Name>/install.log
-
When the installation is complete, you see the message “Installation of package complete” and the installation status for each module.
Figure 3: Successful Installation
NOTE: If the pods have a status of “ContainerCreating”, please wait for some time, since Kubernetes* will pull the images from the registry and then deploy them. This happens only the first time the containers are deployed, and the wait time will depend upon the network bandwidth available.
-
Check the GMA pods with the command:
Figure 4: Status of pods
-
Get the Container ID of gmaserver with the command:
-
Copy the SSL certificate to the GMA container:
NOTE: Run the command on Kubernetes node.
-
Run the gmaserver application:
NOTE: Run the command on Kubernetes node.
-
Install test tools of gmaserver:
NOTE: Run the command on Kubernetes node.
Step 2: Check the Application
-
Set up GMA client on the GMA client device, which is the laptop:
Change client key to generated key. Use
server.csr
which was generated in Step 1.Copy the contents of
client.crt
topath/to/gma/client/root_certificates.hpp
to replace std::string const cert content.Compile the GMA client:
Install the GMA client:
Configure the GMA client using the command below, where:
wlan0
: network interface for Wi-Fiwwan0
: network interface for cellulargmaserver.apps.local
: local DNS name for GMA service running at Edgea.b.c.d
: GMA service IP address at the edge node via LTEStart the GMA client:
-
Ping the GMA server. You will do tun setup after connection setup.
-
Run Demo Tests. Install test tools in server and log in to GMA Docker*.
Step 3: Check Seamless Access Across Cellular and Wi-Fi
-
Run demo test tools on the GMA client device:
Figure 5: Start Demo Test Tools
-
Disconnect the Wi-Fi path:
Now the flow is transferred from Wi-Fi to cellular:
Figure 6: Disconnect the Wi-Fi Path
-
Reconnect the Wi-Fi path:
Now the flow is transferred to Wi-Fi again:
Figure 7: Reconnect the Wi-Fi Path
Step 4: Check Uplink Simultaneous Access (Cellular and Wi-Fi)
-
GMA Controller Command:
Traffic Steering Command tsc [clientIndex] [RTtsc] [NRTtsc] [NRTk1] [NRTk2] [NRTl] clientIndex: the last two bytes of the client IP address RTtsc: traffic steering command for RT flow 0: default (DL & UL over Wi-Fi for RT flow) 1: DL-over-LTE for RT flow 2: UL-over-LTE for RT flow 3: UL & DL-over-LTE for RT flow 4: no update for RT flow NRTtsc: traffic steering command for NRT flow 0: disable dynamic DL splitting for NRT flow 1: enable dynamic DL splitting for NRT flow 16: no update for NRT flow NRTk1: the Wi-Fi burst size (pkts), e.g. 16 NRTK2: the LTE burst size, e.g. 16 NRTl: the splitting cycle (pkts), e.g. 32 Traffic Flow Configuration (for uplink only) tfc [clientIndex] [flowId] [protoType] [portStart] [portend] clientIndex: the last two bytes of the client IP address flowId: 1: high-reliability (duplication) flow 2: real-time flow 3: non real-time flow (default) protoType: 0: disable UL QoS flow classification (default) 1: tcp 2: udp 3: icmp portStart: the lower bound of (UDP or TCP) destination port (not used if "icmp") portEnd: the upper bound of (UDP or TCP) destination port (not used if "icmp")
-
Run demo test. Install test tools on the GMA client device:
-
Set the packet loss rate to 50% for both Wi-Fi and cellular:
Figure 8: Packet Loss Rate on Speedometer Output
Figure 9: Packet Loss Rate on iperf Output
-
Run GMA controller and enable uplink redundancy:
Now the packet loss rate of tun is decreased from 50% to about 25%:
Figure 10: Real Time Transmission Status on Speedometer
Figure 11: Packet Loss Rate on iperf Output
-
Disable Uplink Simultaneous Access:
Now the packet loss rate of tun is increased to 50% again:
Figure 12: Packet Loss Rate on iperf Output
Figure 13: Real Time Transmission Status on Speedometer
Step 5: Uninstall the Application
-
Check installed modules with the following command:
Figure 14: Installed Modules List
-
Run the command below to uninstall all the modules:
-
Run the command below to uninstall the reference implementation:
Figure 15: Uninstalled Modules
Local Build Instructions
After you have installed Intel® Smart Edge Private Wireless Experience Kit, you can build your own Multi-Access with Private 5G image using the following instructions. You can proceed with the steps presented using either edgesoftware sources or GitHub* sources.
Setup
Change the directory to repository path with one of the following options.
For Edgesoftware:
For GitHub:
Use your preferred text editor to make the following file updates.
In the next steps, the tag <REPOSITORY_PATH>
indicates the path to the repository.
In the Change examples, replace the line indicated by - with the line indicated by +
-
<REPOSITORY_PATH>/GMA/gmaserver/dockerbuild.sh
- update the tag and version for the image. -
<REPOSITORY_PATH>/GMA/deploy/gma/templates/deployment.yaml
- update image deployment tag.Change example: - image: "smartedge/{{ .Values.image.repository }}:{{ .Values.image.Version }}" + image: "<local_tag>/{{ .Values.image.repository }}:{{ .Values.image.Version }}"
-
<REPOSITORY_PATH>/GMA/deploy/gma/values.yaml
- update version.Change example: - Version: "1.0" + Version: "<version>"
Build and Install
Build the Docker image with the following commands:
Install Helm* with the following commands:
-
Apply the Network Attachment Definition:
-
Apply the network policy:
-
Run the following Helm installation command:
After step 3 completes, run the GMA client application on client machine to test the connectivity.
Summary and Next Steps
This RI demonstrates how a device can be simultaneously connected to multiple networks, for example, Wi-Fi, LTE, 5G, and DSL. Seamlessly combining the connectivity over these networks below the transport layer is shown to improve quality of experience for applications that do not have built-in multi-path capabilities. This RI demonstrates a new control protocol to manage traffic steering, splitting, and duplicating across multiple connections.
As a next step, you can experiment with traffic management provided by the Generic Multi-Access (GMA) RI to make edge client connections much more stable. You can also enable functions like seamless handover, simultaneous Wi-Fi and cellular during download, and uplink (downlink) redundancy to improve performance.
Learn More
To continue learning, see the following guides and software resources:
- Intel® Smart Edge Private Wireless Experience Kit
- UDP-based Generic Multi-Access (GMA) Control Protocol - IETF Draft
- Multi-access Traffic Management at the Edge - Blog Post
Troubleshooting
Setting packet loss rate of Wi-Fi and cellular interface
If the loss rate can't be added and you see this error:
Use the following command instead:
Support Forum
If you're unable to resolve your issues, contact the Support Forum.