An application continuum style example using Kotlin and Ktor that includes a single web application with two background workers.
- Basic web application
- Data analyzer
- Data collector
This codebase is written in a language called Kotlin that is able to run on the JVM with full Java compatibility. It uses the Ktor web framework, and runs on the Netty web server. HTML templates are written using Freemarker. The codebase is tested with JUnit and uses Gradle to build a jarfile. The pack cli is used to build a Docker container which is deployed to: Heroku Cloud on Heroku's Cloud Platform. Continuous Integration - GitHub Actions Continuous Deployment - Heroku Pipeline
Building a Docker container and running with Docker.
-
Install the pack CLI.
brew install buildpacks/tap/pack
-
Build using pack.
pack build ip-org-resolver --builder heroku/buildpacks:20
-
Run with docker.
docker run -e "PORT=8882" -e "APP=applications/basic-server/build/libs/basic-server-1.0-SNAPSHOT.jar" ip-org-resolver
The below steps walk through the environment setup necessary to run the application in both local and production environments.
-
Install PostgreSQL.
brew install postgresql brew services run postgres brew status (you should see postgres running)
-
Install Flyway.
brew install flyway
-
Create a PostgreSQL database.
createdb
-
Create the ip_test database.
psql -c "create database ip_test;" psql -c "create user dcp with password 'dcp';"
-
Migrate the database with Flyway.
flyway -cleanDisabled="false" -user=dcp -password=dcp -url="jdbc:postgresql://localhost:5432/ip_test" -locations=filesystem:databases/iporg clean migrate
-
Build a Java Archive (jar) file.
./gradlew clean build
-
Create the ip_development database.
psql -c "create database ip_development;"
-
Migrate the database with Flyway.
flyway -cleanDisabled="false" -user=dcp -password=dcp -url="jdbc:postgresql://localhost:5432/ip_development" -locations=filesystem:databases/iporg clean migrate
-
Configure the port that each server runs on.
export PORT=8881
Run the servers locally using the below examples.
java -jar applications/basic-server/build/libs/basic-server-1.0-SNAPSHOT.jar
java -jar applications/data-collector-server/build/libs/data-collector-server-1.0-SNAPSHOT.jar
java -jar applications/data-analyzer-server/build/libs/data-analyzer-server-1.0-SNAPSHOT.jar
run: ./gradlew tests
- components/endpoints/src/test/java/test.collective.ip.IpToOrgWebAPIResolverTest.java
- applications/basic-server/src/test/kotlin/test/collective/start/AppTest.kt
- applications/basic-server/src/test/kotlin/test/collective/start/AppTest.kt (fun testPostValidIPAddressFormat())
On every push a github action is triggered that runs the unit and the integration test. After that a docker image is created that is deployed to the heroku. The file .github/workflows/ci.yml can be changed to alter the deployment strategy accordingly. The docker file Dockerfile creates the heroku docker image.