Skip to content

Latest commit

 

History

History

pyvolt-dpsim-demo

Pyvolt DPsim Demo

Preliminaries

Follow the instructions here to get started: https://sogno-platform.github.io/docs/getting-started/

Clone this repo:

git clone https://github.com/sogno-platform/example-deployments.git
cd example-deployments/pyvolt-dpsim-demo

Helm Repos

Ensure that the following Helm Chart Repos are set up or add them locally:

helm repo add sogno https://sogno-platform.github.io/helm-charts

helm repo add bitnami https://charts.bitnami.com/bitnami
helm repo add influxdata https://influxdata.github.io/helm-charts
helm repo add grafana https://grafana.github.io/helm-charts
helm repo update

HugePages

The current setup requires HugePages support for the real-time simulator. This can be checked and activated (temporarily) as follows:

# Verify HugePages
cat /proc/meminfo | grep Huge

AnonHugePages:    104448 kB
ShmemHugePages:        0 kB
FileHugePages:         0 kB
HugePages_Total:       0		<-- we require a minimum of 1024
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
Hugetlb:               0 kB

# Increase No of HPgs
echo 1024 | sudo tee /proc/sys/vm/nr_hugepages

# Check it worked
cat /proc/meminfo | grep Huge

AnonHugePages:    104448 kB
ShmemHugePages:        0 kB
FileHugePages:         0 kB
HugePages_Total:    1024
HugePages_Free:     1024
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
Hugetlb:         2097152 kB

If you don't see 1024 next to HugePages_Total, you may need to restart your system and try again with a fresh boot.

# Restart k3s service to apply changes
sudo systemctl restart k3s

# Ensure the KUBECONFIG env is still set correctly
export KUBECONFIG=/etc/rancher/k3s/k3s.yaml

If this still does not work add

vm.nr_hugepages = 1024

at the top of /etc/sysctl.conf

Manual Chart Installation

Databus

helm install rabbitmq bitnami/rabbitmq -f databus/rabbitmq_values.yaml

Database

helm install influxdb influxdata/influxdb -f database/influxdb-helm-values.yaml

Database Adapter

helm install telegraf influxdata/telegraf -f ts-adapter/telegraf-values.yaml

Visualization

The following installation will deploy a Grafana instance that is available at the nodePort specified in the grafana_values.yaml file. Per defautl at port 31230: http://localhost:31230

helm install grafana grafana/grafana -f visualization/grafana_values.yaml
kubectl apply -f visualization/dashboard-configmap.yaml

The configmap contains a demo dashboard and should automatically be recognized by the grafana instance. Username and password for Grafana are set to "demo".

CIM Editor Pintura

The following installation will deploy a Pintura instance that is available at the nodePort specified in the pintura_values.yaml file. Per default at port 31234: http://localhost:31234/ (it may take a few moments to launch and become available)

helm install pintura sogno/pintura -f cim-editor/pintura_values.yaml

DPsim Simulation

helm install dpsim-demo sogno/dpsim-demo

State-Estimation

helm install pyvolt-demo sogno/pyvolt-service -f state-estimation/se_values.yaml

Automated Chart Installation

We also prepared two scripts for automatically setting up the demo. They simply run the all helm installs and uninstalls in a bash script.

# demo setup
./demo-setup.sh

# clean-up
./demo-teardown.sh