Skip to content

Latest commit

 

History

History
472 lines (357 loc) · 13.1 KB

README.md

File metadata and controls

472 lines (357 loc) · 13.1 KB

PMon-5G

This project intends to proposed a monitoring system for virtualized radio functions allocation based on the PlaceRAN solution.

Repository Organization

Data

Here is disponible the collected Data from Enviroment.

Observability

Here is disponible the experiments.

Setting up the environment

To set up our environment we need to follow some initial steps.

Operational System

You will need an Ubuntu 18.04 LTS (Bionic Beaver).

Kernel Prerequisites

In order for us to run everything accordingly it is necessary that the kernel of your physical machine (dom0) be linux-image-5.4.0-81-lowlatency. If your kernel is not this one, install it using this command:

sudo apt install linux-headers-5.4.0-81-lowlatency linux-image-unsigned-5.4.0-81-lowlatency

Reboot your machine and, on the GRUB page, choose that you want to boot the system using the newly installed kernel. Check kernel version with uname -r

Xen Configuration

In this work we use the Xen hypervisor. To install it do:

sudo apt update
sudo apt install xen-hypervisor-4.6-amd64 xen-tools

Then, reboot your machine to load the hypervisor. For more specific details visit the Xen documentation page.

Another Requirements

Install the following dependencies to finish setting up the environment

sudo apt update
sudo apt install python net-tools unzip python-pip iproute2 openvswitch-switch openssh-server curl git
sudo pip install paramiko networkx

Cloning this repository

Clone this repository on your machine using:

git clone https://github.com/LABORA-INF-UFG/PMon-5G.git

Downloading the VMs images

Before starting the experiment, we must download the main image that serves as the source for the creation of the virtual machines that will be used. To do this, get inside the repository you've just cloned and inside XenVM directory give the following command:

sh VMDownloader.sh

Putting up the infrastructure

Let's take a broader view of what happens in this part of the experiment. For the desired topology to be raised, there must be a file with information about the virtual machines and the links. This file is simple_vran_infra.json. It is a customizable file that is passed as a parameter to start the experiment. Inside Scripts/Experiments use the following command:

sudo python emulation.py -e vran -i ../../DescriptionFiles/simple_vran_infra.json 

The -e parameter tells you what type of experiment, in this case a vRAN, and the -i tells you which file contains the topology information. This part will take at least 25 minutes to complete and at the end four virtual machines will be up with the desired configurations. To verify that your VM's exist, use the command:

sudo xl list

In the experiment that we are exemplifying, we used the following figure as a basis for the topology: ScreenShot

Configuring Kubernetes

Choose one of the instantiated machines to be the master node and connect via SSH. The password is necos. Once inside, follow the other steps.

Generate an SSH key

The first step to start a cluster is to generate an SSH key and copy it to all machines that will be used in the experiment.

ssh-keygen -q -t rsa -N '' -f ~/.ssh/id_rsa <<<y >/dev/null 2>&1
ssh-copy-id <ip_for_your_machine>

In our case we use four VM's we have the following commands, as an example:

ssh-copy-id 172.16.1.1
ssh-copy-id 172.16.2.2
ssh-copy-id 172.16.3.3
ssh-copy-id 172.16.4.4

Cloning and Configuring Kubespray

The second step is to clone and configure kubespray, a tool that helps deploy a kubernetes cluster.

git clone https://github.com/kubernetes-sigs/kubespray.git
  • After cloning, go into the kubespray directory and install all necessary dependencies with:
sudo pip3 install -r requirements.txt
  • Copy the sample file to create your own cluster:
cp -rfp inventory/sample inventory/mycluster
  • With the nano, change the version in kubernetes that will be used. In the kube_version parameter change from v1.22.2 to v1.21.5
nano inventory/mycluster/group_vars/k8s_cluster/k8s-cluster.yml
  • Now we declare the IP addresses and update the ansible inventory file with the inventory builder:
declare -a IPS=(172.16.1.1 172.16.2.2 172.16.3.3 172.16.4.4)
CONFIG_FILE=inventory/mycluster/hosts.yaml python3 contrib/inventory_builder/inventory.py ${IPS[@]}
  • Finally, with ansible, we start the cluster installation:
ansible-playbook -i inventory/mycluster/hosts.yaml  --become --become-user=root cluster.yml

This installation will take around 30 minutes. After installation, check the nodes using:

kubectl get nodes

MongoDB Deploy

Now let's deploy MongoDB so that we can store our data. Choose one of the nodes that have just been instantiated and install the database inside it. In this experiment we chose node 1.

Use the following commands:

wget -qO - https://www.mongodb.org/static/pgp/server-3.6.asc | sudo apt-key add -
echo "deb http://repo.mongodb.org/apt/debian stretch/mongodb-org/3.6 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.6.list
sudo apt update
sudo apt-get install -y mongodb-org
sudo systemctl start mongod

After that modify the Mongo configuration file. In the parameter bindIp add, separating with a comma, the address of the node where you are installing MongoDB.

nano /etc/mongod.conf 

Restart the service with:

sudo systemctl restart mongod

Chain Deploy

Starting the Core

Within the same node where MongoDB was installed, we will raise the RAN Core. To do this we will clone the OPlaceRAN project directory:

git clone https://github.com/my5G/OPlaceRAN.git
  • Let's get into OPlaceRAN/images/core and tell the Core configuration file which address the database is running on. So we changed the value parameter to the IP where Mongo is:
nano core-deployment.yaml
  • We then tag the node with the Core label:
kubectl label nodes node1 core=true
  • And finally we start a Core:
kubectl apply -f core-deployment.yaml

Recover some Mongo data

In order to have some amount of data for the process, we'll gonna use mongorestore to recover some previous information. Do it :

mongorestore dump/

Starting the Operator

The operator is responsible for placing our Virtualized Network Functions (VNF's). To start it, let's go into OPlaceRAN/scheduler-manager/k8s and proceed with:

kubectl apply -f deployment.yaml

That simple :)

Installing Dependencies

To upload the other components of the RAN we need to install some dependencies. The first one is the go. Go back to the root directory and follow the steps below to install it:

wget https://golang.org/dl/go1.14.15.linux-amd64.tar.gz
rm -rf /usr/local/go && tar -C /usr/local -xzf go1.14.15.linux-amd64.tar.gz
export PATH=$PATH:/usr/local/go/bin
source $HOME/.profile

The next dependency is kustomize. Install it with:

curl -s "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh"  | bash
mv kustomize /usr/bin/

Go inside OPlaceRAN/k8s-operator/ and:

make install && make deploy

By this time, you'll have both the Core and Operator running at full speed. So, let's go to the next part!

Starting the CU, DU and RU

With the following command, you can view your pods and also see the IP of the Core pod. Write it down somewhere, as it will be needed.

kubectl get pods -o wide

Now, inside OPlaceRAN/k8s-operator/ let's change the coreIP parameter to the address we copied in the previous step:

nano config/samples/ran_v1alpha1_randeployer.yaml

And finally start a complete chain with:

kubectl apply -f config/samples/ran_v1alpha1_randeployer.yaml

Monitoring metrics

With all the parts configured, let's now move on to collecting and viewing the metrics.

Prometheus Operator

Helm is a tool that will help us with managing our kubernetes cluster. To install and run it just:

curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3

chmod 700 get_helm.sh

./get_helm.sh

With the helm installed we can use it to add the Prometheus repository:

helm repo add prometheus-community https://prometheus-community.github.io/helm-charts

helm repo update

Now we create the namespace monitoring to organize our cluster and facilitate navigation:

kubectl create namespace monitoring

kubectl config set-context --current --namespace=monitoring

And we installed the Prometheus operator:

helm install prometheus prometheus-community/kube-prometheus-stack

To check if the services are up, use:

kubectl get services

Run this command to forward the port of Prometheus service to your localhost:

kubectl port-forward service/prometheus-kube-prometheus-prometheus 9090

And finally go to https://localhost:9090 to check if the service is really working.

Grafana

Grafana's service has already been installed with Prometheus, so we just need to forward its port, as we did before with Prometheus:

kubectl port-forward deployment/prometheus-grafana 3000

And go to htts://localhost:3000. To login, the user* is admin and the password is prom-operator.

Monitor Calico with Prometheus Operator

  • First, we switch to the kube-systemy namespace:
kubectl config set-context --current --namespace=kube-system

and change key FELIX_PROMETHEUSMETRICSENABLED to True in calico-node daemonset specs:

kubectl get daemonset calico-node -o json \
    | jq '.spec.template.spec.containers[0].env[16].value = "True"' \
    | kubectl replace -f -

Check the Calico's metrics with:

curl -s localhost:9091/metrics
  • Now we going to setup Prometheus to export Calico's metrics. Create an empty file called something like calico-felix-metrics-Service.yaml and past the content below inside. Note that since calico runs in the kube-system namespace, the service has to be created there too.
apiVersion: v1
kind: Service
metadata:
  name: calico-felix-metrics
  namespace: kube-system
  labels:
    monitoring: calico-felix
spec:
  clusterIP: None
  ports:
  - port: 9091
    protocol: TCP 
    name: metrics  
  selector:
    k8s-app: calico-node

After creating a file, create a service with file calico-felix-metrics-Service.yaml with this command:

kubectl apply -f calico-felix-metrics-Service.yaml

Now take a look at the new service created with this command:

kubectl get services --namespace=kube-system

Create a custom resource ServiceMonitor to configure a new endpoint to Prometheus scrape, in this case, to scrape calico. Create an empty file called something like calico-felix-metrics-ServiceMonitor.yaml and past the content below inside:

apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  name: calico-felix-metrics
  namespace: monitoring
  labels:
    release: prometheus
spec:
  selector:
    matchLabels:
      monitoring: calico-felix
  namespaceSelector:
    matchNames:
    - kube-system
  endpoints:
  - port: metrics
    relabelings:
    - sourceLabels:
      - __meta_kubernetes_endpoint_node_name
      targetLabel: instance

Now use this command to put up the service:

kubectl apply -f calico-felix-metrics-ServiceMonitor.yaml

and check it with:

kubectl get servicemonitor
  • Now we are goingo to check if everything is fine also in the WebUI. Make the port forwarding again:
kubectl port-forward service/prometheus-kube-prometheus-prometheus 9090

and acess https://locahost:9090

Don't forget to port foward the Grafana's port too.

Observability Stack

ScreenShot