Uweheuerbackend

From Wiki RB4

Documentation[edit]

  1. https://miro.com/app/board/uXjVPuAgvI0=/
  2. C:\Uwes\owncloud\documents\Software_Development\MyDevelopments\uweheuer.drawio

Architecture and Implementation[edit]

Environment Variables[edit]

Environment variables are used to set application properties of this Spring Boot application:

  • on a local Windows development laptop they are set as user specific environment variables (see SetLocalEnv.bat).
  • for running from Ecplise they are set in run configuration

ToDo[edit]

APIs[edit]

Local Dev[edit]

Local Docker[edit]

Raspberry Docker via IP[edit]

Raspberry Docker via uweheuer.spdns.de[edit]

By Windows Powershell[edit]

curl.exe -X POST localhost:8080/menus -H “Content-type:application/json” -d '{ \"name\": \"test by curl\" }'

By Linux Command Shell[edit]

curl https://uweheuer.spdns.de/fwdtest/backend/admin/import

Installation[edit]

Raspberry[edit]

  • Git installation
  • Maven installation
  • Java installation
  • Login via gh auth login
  • Clone repositories
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace $ git clone https://github.com/UweHeuer/uweheuer-backend.git
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace $ gh repo clone UweHeuer/uweheuer-frontend
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace $ git clone https://github.com/UweHeuer/hostinterface.git

Build[edit]

  • build by Maven
  • setup on computer see here
  • steering of target environments by profiles in pom.xml:
    • local_dev (default)
    • heroku

Development Laptop[edit]

  • jar-file
C:\Uwes\SoftwareProjects\eclipse-workspace\uweheuer-backend>mvn -DskipTests package

Raspberry[edit]

  • get updates from repository
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace/uweheuer-backend $ git pull
  • jar-file
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace/uweheuer-backend $ mvn -DskipTests package
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace/hostinterface $ mvn -DskipTests package

Docker[edit]

  • build image on all computers
<PROJECT_PATH> docker build --tag uweheuerbackend .

Test[edit]

Local from Command Line[edit]

C:\Uwes\SoftwareProjects\eclipse-workspace\uweheuer-backend>mvn test

Local from Eclipse[edit]

Run[edit]

Local from Command Line[edit]

Uses the local environment variables (see here)

  1. run MySQL
  2. start backend from command line
C:\Uwes\SoftwareProjects\eclipse-workspace\uweheuer-backend>mvn spring-boot:run 

Additional settings could be set via adding -Dspring-boot.run.arguments="--spring.datasource.password=xyz"

Local from Eclipse[edit]

  1. run MySQL
  2. use Eclipse Run Configuration (picture outdated)
    1. this creates a file UweHeuerBackend Run SpringBoot Run Configuration.launch in C:\Uwes\SoftwareProjects\eclipse-workspace\.metadata\.plugins\org.eclipse.debug.core\.launches\
      1. if eclipse error occurs and run configuration is empty see here. Add the two missing lines with value of project name 'uweheuer-backend'.

Raspberry Hostinterface[edit]

export UWEHEUER_HOSTINTERFACE_UPDATESOFTWARE_SCRIPT=/home/uwe/SoftwareProjects/eclipse-workspace/uweheuer-backend/BuildAndRunRaspberry.sh
nohup mvn spring-boot:run & // check by ps -e

Docker Compose[edit]

  • configuration see docker-compose.yml and .compose.env

Local Windows Laptop[edit]

  1. start Docker Desktop
  2. run all containers
C:\Uwes\SoftwareProjects\eclipse-workspace\uweheuer-backend>docker compose --env-file .compose.env up -d
  • log files go to
CONTAINER_LOGS_FOLDER=C:/Uwes/ContainerLogs/uweheuerbackend (see .compose.env)
  • database goes to
MYSQL_DB_FOLDER=C:/Uwes/MySQLContainerData/uweheuerbackend  (see .compose.env)

Raspberry[edit]

uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace/uweheuer-backend $ docker compose --env-file .compose.env up -d // using an local env file, run in background
  • stop all containers
uwe@raspberrypi4:~/SoftwareProjects/eclipse-workspace/uweheuer-backend $ docker compose --env-file .compose.env down

Implementation[edit]

Spring Boot Standard Diagnosis Actuator[edit]

  • adding Spring Boot Actuator by adding to pom.xml:
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
  • adding to application.properties all endpoints
management.endpoints.web.exposure.include=*
  • add class ActuatorHttpExchangesConfiguration for HTTP request logging

Calling Host from Backend Container[edit]

  • add to pom.xml
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
  • implement using WebClient

Set Build Timestamp[edit]

  • see pom.xml below spring-boot-maven-plugin and
  • AdminController.java BuildProperties attribute

Logging[edit]

  • uses Logback
  • see /src/main/resource/log-back-spring.xml
    • log files go to /logs/ directory, which is in case of Docker mapped Docker Compose Configuration
    • pattern
      • %C{0} // print out without package name
      • %M // print out method name
  • in a Docker environment /logs/ is mapped via .compose.env to a local machine directory