Skip to content

Some scripts that help to deploy instances of the free5gc project

License

Notifications You must be signed in to change notification settings

oliveiraleo/free5gc-auto-deploy

Repository files navigation

free5GC-auto-deploy

This repository comprises a collection of scripts designed to facilitate the deployment of instances of the free5GC project.

The comprehensive documentation available on the project's official website is highly advisable for individuals new to free5GC to familiarize themselves with. The underlying processes are to be carefully studied, as the scripts are designed to replicate the steps outlined in the "Build free5GC from scratch" guide in an automated manner.

Notice

The scripts available on this repository have been based on free5GC's advanced setup instructions. However, instead of having two separate interfaces (one for remote/admin access and other for general use), they have been designed considering an environment where the 5GC machine will use only one network interface as its data network interface. To configure other network interfaces, please, refer to the free5GC configuration guide or to Ubuntu Server networks docs

Motivation

In the course of my research, I've been utilizing the free5GC project. During the experimentation with this 5G Core (5GC) advanced setup and its associated Network Functions (NFs), I discovered an opportunity to streamline the installation process. By automating various installation tasks, I significantly reduced deployment time, optimizing efficiency and enabling a more agile research environment.

During the process of seeking a similar tool, I've found 301 repositories hosted on Github that had the word "free5gc" on them. As I took a deeper look, I noted that:

However the focus of my scripts were to (semi-)automatically deploy free5GC, and I couldn't find any projects that would fit this purpose.

Entering into the spirit of FSFE's (FSF Europe) campaign "Public Money? Public Code!" and given that my research is currently being funded by public administration entities (namely CAPES and RNP) I decided to share my code with the community as it may help others in the future.

Requirements

The scripts were tested within an environment that possessed the following characteristics:

Software

  • Bash shell 5.0.17 (or later)
  • Ubuntu Server 20.04.6 LTS
  • Linux Kernel 5.4.x (tested on 5.4.0-200-generic)

Hardware (minimum)

  • 20GB HDD
  • 2GB RAM
  • 1x i5 processor CPU core

Hardware (recommended)

  • 40GB HDD
  • 4GB RAM
  • 2x i5 processor CPU core

For more information see this FAQ

Usage

On free5GC machine:

Download the scripts (stable version)

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/v1.3.0/install-go.sh
curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/v1.3.0/deploy-free5gc.sh
chmod +x deploy-free5gc.sh install-go.sh # gives execution permission

Tip: Swap main with the desired version while using other curl commands in this README

Note: Check the releases page for newer versions or use the latest stable

Download the scripts (nightly version)

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/install-go.sh
curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/deploy-free5gc.sh
chmod +x deploy-free5gc.sh install-go.sh # gives execution permission

Tip: Use -LOSs instead of -LO to suppress curl's output messages (for more information see this page)

Install Go and reload the environment vars

./install-go.sh && source ~/.bashrc

Then install free5gc

./deploy-free5gc.sh

Note: Unless otherwise specified, the script will automatically install the stable version defined by the FREE5GC_VERSION variable, without making any changes to the N3IWF configuration

Script parameters

Currently, deploy-free5gc.sh script accepts these parameters:

  • -nightly: Clones free5GC nightly version set by FREE5GC_NIGHTLY_COMMIT variable instead of the stable one
  • -n3iwf: Prepares N3IWF's configuration file during the installation
  • -n3iwf-nightly: Prepares N3IWF's configuration file and installs its nightly version
  • -tngf: Prepares TNGF's configuration file during the installation
  • -reset-firewall: Removes all the rules from iptables and reconfigure them during the installation

Example usage:

./deploy-free5gc.sh -nightly -n3iwf

On UERANSIM machine:

Download the script

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/deploy-UERANSIM.sh
chmod +x deploy-UERANSIM.sh # gives execution permission

Then install UERANSIM

./deploy-UERANSIM.sh -stable

Script parameters

Currently, deploy-UERANSIM.sh script accepts these parameters:

  • -stable: Clones UERANSIM stable version
  • -nightly33: Clones UERANSIM nightly version compatible with free5GC v3.3.0 or below
  • -nightly: Clones UERANSIM nightly version compatible with free5GC v3.4.0 or above
  • -keep-hostname: Disables changing the machine hostname during the deploy

Example usage:

./deploy-UERANSIM.sh -nightly

Note: This script requires a "version related" parameter to work. Please select one from the list provided above that is compatible with your environment

Add new 5G UE to free5GC

Please, follow the instructions from this page

UERANSIM basic usage

To deploy the gNB:

cd ~/UERANSIM
build/nr-gnb -c config/free5gc-gnb.yaml

To deploy the UE:

cd ~/UERANSIM
sudo build/nr-ue -c config/free5gc-ue.yaml # for multiple-UEs, use -n and -t for number and delay

On N3IWUE machine:

Download the scripts

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/install-go.sh
curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/deploy-n3iwue.sh
chmod +x deploy-n3iwue.sh install-go.sh # gives execution permission

Install Go and reload the environment vars

./install-go.sh && source ~/.bashrc

Then install N3IWUE

./deploy-n3iwue.sh

Script parameters

Currently, deploy-n3iwue.sh script accepts these parameters:

  • -stable: Clones N3IWUE stable version
  • -stable341: Clones N3IWUE stable version compatible with free5GC v3.4.1
  • -nightly: Clones N3IWUE nightly version
  • -keep-hostname: Disables changing the machine hostname during the deploy

Example usage:

./deploy-n3iwue.sh -keep-hostname -stable

Add new N3IWUE to free5GC

Please, follow the instructions from this page

N3IWUE basic usage

To deploy the N3IWUE:

cd ~/n3iwue
./run.sh

How to deploy both UERANSIM and N3IWUE

On a new machine, download the script

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/deploy-both-UEs.sh

Then execute it using an interactive shell

bash -i deploy-both-UEs.sh

Note: By default shells invoked by a script are non-interactive, running this script in a non-interactive shell will cause bash environment reload to fail after Go installation. For more information see this page

On TNGFUE machine:

Download the script

curl -LO https://github.com/oliveiraleo/free5gc-auto-deploy/raw/main/deploy-tngfue.sh
chmod +x deploy-tngfue.sh # gives execution permission

Then install TNGFUE

./deploy-tngfue.sh

Script parameters

Currently, deploy-tngfue.sh script accepts these parameters:

  • -stable: Clones TNGFUE stable version
  • -nightly: Clones TNGFUE nightly version
  • -keep-hostname: Disables changing the machine hostname during the deploy

Example usage:

./deploy-tngfue.sh -nightly -keep-hostname

Note: This script requires a "version related" parameter to work. Please select one from the list provided above that is compatible with your environment

Add new TNGFUE to free5GC

Please, follow the instructions from this page

TNGFUE basic usage

To deploy the TNGFUE:

cd ~/tngfue/
./run.sh

Contributing

The community is encouraged to contribute to this project. If you identify any opportunities for improvement or areas that require updates due to upstream changes, please feel free to open an issue or pull request

All contributions to this repository are subject to its licensing terms. For more information, please see here and here.

License

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License version 3 as published by the Free Software Foundation.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.