Emulated RAN
gNBsim emulates a 5G RAN, generating (mostly) Control Plane traffic
that can be directed at SD-Core. This section describes how to
configure gNBsim to customize and scale the workload it generates. We
assume gNBsim runs in one or more servers, independent of the
server(s) that host SD-Core. These servers are specified in the
hosts.ini
file, as described in the Scale Cluster section. This blueprint assumes you start with a
variant of vars/main.yml
customized for running gNBsim. This is
easy to do:
$ cd vars
$ cp main-gnbsim.yml main.yml
Configure gNBsim
Two sets of parameters control gNBsim. The first set, found in the
gnbsim
section of vars/main.yml
, controls how gNBsim is
deployed: (1) the number of servers it runs on; (2) the number of
Docker containers running within each server; (3) what configuration
to run in each of those containers; and
(4) how those containers connect to SD-Core. For example, consider the
following variable definitions:
gnbsim:
docker:
container:
image: omecproject/5gc-gnbsim:main-PR_88-cc0d21b
prefix: gnbsim
count: 2
network:
macvlan:
name: gnbnet
router:
data_iface: ens18
macvlan:
iface: gnbaccess
subnet_prefix: "172.20"
servers:
0:
- "config/gnbsim-s1-p1.yaml"
- "config/gnbsim-s1-p2.yaml"
1:
- "config/gnbsim-s2-p1.yaml"
- "config/gnbsim-s2-p2.yaml"
The container.count
variable in the docker
block specifies how
many containers run in each server (2
in this example). The
router
block then gives the network specification needed for these
containers to connect to the SD-Core; all of these variables are
described in the Verify Network
section. Finally, the servers
block names the configuration files
that parameterize each container. In this example, there are two
servers with two containers running in each, with
config/gnbsim-s2-p1.yaml
parameterizing the first container on the
second server.
These config files then specify the second set of gNBsim parameters.
A detailed description of these parameters is outside the scope of
this guide (see https://github.com/omec-project/gnbsim for details),
but at a high-level, gNBsim defines a set of profiles, each of which
exercises a common usage scenario that the Core has to deal with. Each
of these sequences is represented by a profileType
in the config
file. gNBsim supports seven profiles, which we list here:
- profileType: register # UE Registration
- profileType: pdusessest # UE Initiated Session
- profileType: anrelease # Access Network (AN) Release
- profileType: uetriggservicereq # UE Initiated Service Request
- profileType: deregister # UE Initiated De-registration
- profileType: nwtriggeruedereg # Network Initiated De-registration
- profileType: uereqpdusessrelease # UE Initiated Session Release
The second profile (pdusettest
) is selected by default. It causes
the specified number of UEs to register with the Core, initiate a user
plane session, and then send a minimal data packet over that session.
Note that the rest of the per-profile parameters are highly redundant.
For example, they specify the IMSI- and PLMD-related information UEs
need to connect to the Core.
Finally, it is necessary to edit the core
section of
vars/main.yml
to indicate the address at which gNBsim can find the
AMF. For our running example, this would look like the following:
core:
amf: "10.76.28.113"
Install/Uninstall gNBsim
Once you have edited the parameters (and assuming you already have SD-Core running), you are ready to install gNBsim. This includes starting up all the containers and configuring the network so they can reach the Core. This is done from the main OnRamp server you've been using, where you type:
$ make gnbsim-docker-install
$ make aether-gnbsim-install
Note that the first step may not be necessary, depending on whether Docker is already installed on the server(s) you've designated to host gNBsim.
When you are finished, the following uninstalls everything:
$ make aether-gnbsim-uninstall
Run gNBsim
Once gNBsim is installed and the Docker containers instantiated, you can run the simulation by typing
$ make aether-gnbsim-run
This can be done multiple times without reinstalling. For each run, you can use Docker to view the results, which have been saved in each of the containers. To do so, ssh into one of the servers designated to to run gNBsim, and then type
$ docker exec -it gnbsim-1 cat summary.log
Note that container name gnbsim-1
is constructed from the
prefix
variable defined in the docker
section of
vars/main.yml
, with -1
indicating the first container.
In addition to scaling up the workload you put on the Core, you can
also experiment with the emulation settings defined in any or all of
the config files in deps/gnbsim/config/
. Focusing on profile2
in particular (because it sends data packets after registering each
UE), variable defaultAs: "192.168.250.1"
specifies the target of
ICMP Echo Request packets. Changing the value to the IP address of a
real-world server (e.g., 8.8.8.8
) causes the emulated UE to
actually ping that server. Success is a good indication that your
Aether cluster is properly configured to support end-to-end
connectivity.
Yet another option is to configure a single instance of gNBsim to direct
multiple workloads at SD-Core. For example, editing vars/main.yml
to use config/gnbsim-all.yaml
in place of
config/gnbsim-default.yaml
causes gNBsim to activate all the
profiles.