Naksha can be run in container as well. So far, only locally build image can be used.
To get Naksha container running, one must do the following:
-
CD into the root project directory (we need this because build context needs to access files that don't belong to
docker
directory).cd ..
-
Build the fat jar:
./gradlew shadowJar
-
Build the local image:
If your host's architecture is arm64 (ie you're using MacOS with Apple Silicon chip):docker build -t local-naksha-app -f docker/Dockerfile .
For other architectures, you can specify
ARCHITECTURE
build argument that corresponds to different base image repository. For example, when running on amd64 chips (ie MacOS with Intel processors):docker build -t local-naksha-app -f docker/Dockerfile --build-arg ARCHITECTURE=amd64 .
Other possible architectures that are supported can be found on these Docker official images docs. For more details, refer to docs of our base image (Eclipse Temurin).
-
Run the container for the first time:
There are optional environment variables that one can specify when running Naksha container.NAKSHA_CONFIG_ID
: id of naksha configaration to use,test-config
by defaultNAKSHA_ADMIN_DB_URL
: url of database for Naksha app to use,jdbc:postgresql://host.docker.internal:5432/postgres?user=postgres&password=password&schema=naksha&app=naksha_local&id=naksha_admin_db
by defaultNAKSHA_EXTENSION_S3_BUCKET
: S3 bucket name or S3 bucket access point.The default value isnaksha-pvt-releases
.NAKSHA_JWT_PVT_KEY
: Naksha JWT private key.NAKSHA_JWT_PUB_KEY
: Naksha JWT public key.NAKSHA_JWT_PUB_KEY_2
: Additional Naksha JWT public key, if needed to validate the JWT signed by some other application's PVT key.JAVA_OPTS
: Any custom java options like-Xms1024m -Xmx2048m
When connecting Naksha app to database, one has to consider container networking - if your database is running locally, then when specifying its host you should use
host.docker.internal
(see default URL above) instead oflocalhost
/127.0.0.1
(docker's default network mode is isolatedbridge
so thelocalhost
for container and host are 2 different things) .
Putting it all together the typical command you would use is:docker run \ --name=naksha-app \ -p 8080:8080 \ local-naksha-app
or with custom config / admin db URL:
docker run \ --name=naksha-app \ --env NAKSHA_CONFIG_ID=<your Naksha config id> \ --env NAKSHA_ADMIN_DB_URL=<your DB uri that Naksha should use> \ -p 8080:8080 \ local-naksha-app
or with all the environment variables:
docker run \ --name=naksha-app \ --env NAKSHA_CONFIG_ID=<your Naksha config id> \ --env NAKSHA_ADMIN_DB_URL=<your DB uri that Naksha should use> \ --env NAKSHA_EXTENSION_S3_BUCKET=<your s3 bucket name or access point> \ --env NAKSHA_JWT_PVT_KEY=<your naksha JWT private key with '\n' for new lines> \ --env NAKSHA_JWT_PUB_KEY=<your naksha JWT public key with '\n' for new lines> \ --env NAKSHA_JWT_PUB_KEY_2=<some other application's JWT public key with '\n' for new lines> \ --env JAVA_OPTS="-Xms1024m -Xmx2048m" \ -p 8080:8080 \ local-naksha-app
-
Verify your instance is up and running by accessing local Swagger: http://localhost:8080/hub/swagger/index.html
Starting the container as in the sample above will hijack your terminal. To avoid this pass -d
flag (as in "detached")
> docker run --name=naksha-app -p 8080:8080 -d local-naksha-app
If you want to tail logs of your running container (ie when you detached it before), you can use docker logs as in the sample:
docker logs -f --tail 10 naksha-app
The command above will start tailing logs from container with the name naksha-app
and also print last 10
lines.
To stop the running container simply run:
docker stop naksha-app
Stopping is graceful, meaning - it sends SIGTERM
to the process so the app will have some time to
perform the cleanup.
If you need to stop the container immediately, use docker kill naksha-app
- the main difference
is that instead of SIGTERM
the process will receive SIGKILL
.
If your run configuration (ports, environments etc - basically all args that you passed to the run
command) hasn't changed and you just want to respawn Naksha, use start
:
docker start naksha-app
This will bring your container back to life in detached mode. To get live logs again, refer to tailing logs.
If you stop/kill your container and then run
(nod start
!) it again, it might happen that you'll see the following error:
Error: creating container storage: the container name "naksha-app" is already in use by <id>.
You have to remove that container to be able to reuse that name: that name is already in use
That means that your container engine (like docker / podman) has some uncleared data associated with given container name. The quickest fix is to remove it and then run again.
docker rm naksha-app
If you ever need to clean the image, use one of the below (the latter is simply the alias of the former).
> docker image rm local-naksha-app
> docker rmi local-naksha-app