# The DVA Code

# Still Growing Here!

Great things also grow from cabbage and turnips! The developer section is still under construction. Structure, content, and design are continuously being optimized.

This area is for internal use only until completion. A complete overhaul is in progress.

# Software Architecture

Deployment upon production start

# Servicecommunication

# Backend-Webservices:

# Hardware Architecture (structural recommendation)

Deployment upon production start

# Deployment, Operation, and Maintenance

# Data Server

The database server, called Data-Server (PU_VM_dva_data), stores, manages, organizes, and structures the data of the DVA.

The data server primarily relies on the interplay of the following applications:

  • Geoserver
    • Plugin: Geostyler
  • PostGIS

The Data-Server is accessible via:

Access credentials for the data server are stored under PU_VM_dva_data_PostGIS_DB in the password database. The data server is used in the following locations:

  1. Via the DVA Web App:

    • Frontend via WFS (embedded through the master portal code)

    ToDo

    Insert link:

    1. For the documentation of the FE code at the point where the WMS is integrated
    2. Access to WFS via Geoserver (it may be useful to create separate documentation for this)
    • Backend for calculations and simulations

    ToDo

    Insert link: To the BE code documentation and relevant interfaces to the PostgreSQL database

  2. Through other connections:

# Establishing a Database Connection via ArcGIS

Prerequisite: ArcGIS Pro (opens new window) must be available.

  1. After launching ArcGIS Pro, open the Catalog section.
  2. Right-click on Databases and select New Database Connection.
  3. In the dropdown under Database Platform, select PostgreSQL.
  4. In the Instance text field, enter the name or IP address of the database cluster on the server where PostgreSQL is installed.
  5. For Authentication Type, select Database authentication.
  6. Enter User Name and Password. Credentials are managed via the central password database under PU_VM_dva_data_PostGIS_DB.
  7. Depending on the project, the database may vary. Currently, there is only the dvan database, which contains various data on population and infrastructure for the Federal Republic of Germany. The data source is OSM data, and it does not reflect the official infrastructure situation.

ToDo

Insert link: To database documentation | If created, the second part of point 7 may be removed.

ArcGIS Pro Database Connection

Fig: Database connection inputs in ArcGIS, example of the DVAN DB on the DVA Data Server

Upon successful connection, the view should look like this:

# Database Connection via PGAdmin

Prerequisite: PGAdmin (opens new window) must be available.

  1. After launching pgAdmin, right-click on Servers in the object explorer.
  2. In the new window Register - Server, enter a name for the server under Name. It is preferable to call it DVA.
  3. Switch to the Connections tab in the same window.
  4. In the Host name/address text field, enter the name or IP address of the server where PostgreSQL is installed. Enter 5432 under Port.
  5. Enter Username and Password. Credentials are managed via the central password database under PU_VM_dva_data_PostGIS_DB.
  6. Depending on preference, the Save password? option can be enabled or disabled.
  7. Click Save.
  8. The database used may vary depending on the project. Currently, there is only the dvan database, which contains various data on population and infrastructure for the Federal Republic of Germany. The data source is based on OSM data, and it does not reflect the official infrastructure situation.

PGAdmin Connection

Fig: Database connection inputs in PGAdmin, example of the DVAN DB on the DVA Data Server

Upon successful connection, the view should look like this:

# Establishing a Database Connection via Geoserver

Prerequisite: Access to the DVA Data Server or the DVA Geoserver (opens new window) is required. Access credentials are managed via the central password database entry PU_VM_dva_data_Geoserver.

  1. After logging into the DVA Geoserver (opens new window), go to DataData Stores in the left navigation bar.
  2. Click Add Data Store.
  3. Under Vector Data Sources, select PostGIS to add a PostGIS database.
  4. In the Workspace dropdown, select dva_germany, for example.
  5. Assign a name to the data source (currently dvan).
  6. Under Host, enter the IP address of the data server and under Port, enter 5432 for the PostGIS database.
  7. The Database is dvan, and the Schema is public by default.
  8. Enter User and Password. Credentials are available via the central password database under PU_VM_dva_data_PostGIS_DB.
  9. Additional settings can be configured if needed. For initial operation, the default values are sufficient.

Geoserver Connection

Fig: Database connection inputs in Geoserver, example of the DVAN DB on the DVA Data Server

In the left navigation bar under DataLayers, the layers of the dva_germany workspace can be viewed and published.

Geoserver View

Fig: Upon successful connection, the view should look like this


# Geostyler Plugin for Geoserver

To install the Geostyler plugin, ensure that GeoServer is properly installed and running.

  1. Navigate to the GeoServer installation directory and then to /WEB-INF/lib/.
    • This folder manages and installs plugins.
    • In this example, access is made via WinSCP:
/var/lib/tomcat9/webapps/geoserver/WEB-INF/lib/
  1. Download the .jar file gs-geostyler (opens new window).

  2. Copy the file (e.g., using WinSCP) to the directory from step 1 (the actual path may vary).

  3. Restart the GeoServer instance.


# Publishing Layers in GeoServer

Access to the DVA Data Server or the DVA GeoServer (opens new window) is required. Login credentials are available through the central password database under PU_VM_dva_data_Geoserver.

  1. After logging in to the DVA GeoServer (opens new window), navigate to DataLayers in the left navigation pane.
  2. Click Add Layer.
  3. If not already done, add a new data source under Vector Data SourcesPostGIS.
  4. Select the desired data store from the dropdown, e.g., dva_germany.
  5. A list of the layers contained will be displayed (for the data source dva_germany, this is the connection to the PostGIS tables).
  6. Select the desired layer and click Publish.
  7. Under the Data tab:
  • Set a Name and Title.
  • Keep the coordinate reference system if no changes are needed.
  • Calculate the bounding box:
    • Click Calculate from the coordinate reference system bounds.
    • Click Calculate from the native bounds.
  1. Click Save.

The layer is now published in GeoServer.

  • Under DataLayers, all published layers can be viewed.
  • Under DataLayer Preview, the layers can be viewed as an OpenLayers preview.

More information on styling a layer can be found in the section Styling Layers (with Geostyler).

# Styling Layers (with Geostyler)

# Styles for facilities:

# DVA Database and Tables

# Schema Documentation

This section provides an overview of the database schema, including tables, columns, data types, and other relevant constraints.

# Population Tables

# Table: population_full

A table for storing nationwide population data with geometry and age distributions in 10-year intervals. This schema describes the population_full table, which contains resident population data based on the 2011 census and spatial data (in the form of a polygon with a 100m x 100m grid).

# Table: population_standard

A table for storing nationwide population data with geometry and age distributions. It differs from population_full in the classification of age groups, which here are divided into life-biographical age groups. This schema describes the population_standard table, which contains resident population data based on the 2011 census and spatial data (in the form of a polygon with a 100m x 100m grid).

# Infrastructure Tables

# Table: facilities_[Name]

Tables for storing nationwide infrastructure data of various types with geometry data (Point), including a weighting factor that provides information about the capacity limits of the infrastructure. In the absence of nationwide capacity information, these data are simulated. Depending on the data owner, they can be replaced by real data. Data source: OSM data

The following infrastructure types are stored in this format:

The table schema is as follows:

# Management Tables

# Table: users

This table governs external users' access to the DVA frontend. Access is only possible after contacting the responsible persons at TU Dresden.

# Services

This section provides an overview of the services that are in use for the operation of the DVA.

# WMS of the GeoServer

# Useful Console Statements

# Docker

Docker is used in the DVA application landscape to deploy services (including frontend and databases). For deployment, operation, and maintenance, it is essential to start and reload containers. Frequently used statements are listed below:

# Show running containers and VM load:

# Display running containers and VM utilisation:

sudo docker stats

# Stop running containers

sudo docker compose stop

# Start container (in the folder directory in which the Docker-compose.yml is also stored)

sudo docker compose up -d --build

# Show logs

sudo docker logs "containername" -f

# No more memory and Docker won't start?

This shows the free storage space on all file systems:

df -h

# Clean up temporary Docker data on the VM

Docker stores a lot of temporary data such as images, containers, volumes and networks. This data can be cleaned up to free up storage spac

sudo docker system prune -a

# Display the port configuration of the running containers:

sudo docker container ls --format "table {{.ID}}\t{{.Names}}\t{{.Ports}}" -a 

# Restart-Optionen of docker-compose.yml

Among other things, the Dockercompose file regulates the behaviour when a Docker container is not currently active. This can be the case when server maintenance is due and the virtual machines are restarted. The following alternatives are available:

# GIT

The entire DVA code is managed in several GIT repositories. The following statements and notes are useful for trying out interim statuses or newer developments:

Retrieve all updates of all remotes without integrating them into local branches:

git fetch --all

Show all remote branches:

git branch -r

Show all remote and local branches:

git branch -a

To switch between different local branches:

git checkout <branch-name>

Example:
git checkout main

Display remote branch in local environment (check out local branch):

git checkout -b <lokaler-branch-name> origin/<remote-branch-name>

Example:
git checkout -b feature-branch origin/feature-branch

Alternativ (ab Git V2.23)
git switch <branch-name>
Last Updated: 2/20/2025, 1:51:47 PM