-
Notifications
You must be signed in to change notification settings - Fork 159
FHIR Server on Rancher Desktop
Instead of using Docker you can use Rancher Desktop for locally deploying the LinuxForHealth FHIR Server image. This was tested with the 1.0.1 version of Rancher Desktop.
The following information is based on having completed the wiki guide Setting up for development, and you have a successful local maven
build of the LinuxForHealth FHIR Server.
After the installation of Rancher Desktop and supporting utility nerdctl
you can create the LinuxForHealth FHIR Server image using nerdctl
.
In a terminal session:
nerdctl build <local-base-directory>/git/FHIR/fhir-install -t linuxforhealth/fhir-server:test
You can then use nerdctl
to run the image with a bootstrapped derby DB.
nerdctl run -d --name fhirserver -p 9443:9443 -e BOOTSTRAP_DB=true -e FHIR_TRANSACTION_MANAGER_TIMEOUT=120s linuxforhealth/fhir-server-:test
This will get the image running with a created Derby db. you can access this FHIR Server locally at this URL https://localhost:9443/fhir-server/api/v4/metadata
.
You can also use the kubernetes part of Rancher Desktop and helm
to deploy an image of the FHIR Server using a postgresql database for persistence.
So instead of creating the image in the default namespace you need to build the image into the image namespace for the local cluster.
nerdctl -n k8s.io build <local-base-directory>/git/FHIR/fhir-install -t linuxforhealth/fhir-server:test
You will also need the image for the FHIR Server schema tool. To build that image create a local script schema.sh
like the following:
#!/usr/bin/env bash
# set some work variables
WORKSPACE=<local-base-directory>/git/FHIR
BUILD_ID=main
cd ${WORKSPACE}/fhir-install/src/main/docker/fhir-schematool/
# Copy the files over
mkdir -p target/
cp ${WORKSPACE}/fhir-persistence-schema/target/fhir-persistence-schema-*cli.jar target/
cp ${WORKSPACE}/LICENSE target/
# build image into proper name space
nerdctl -n k8s.io build --build-arg FHIR_VERSION=${BUILD_ID} -t linuxforhealth/fhir-schematool:latest .
# EOF
Then run schema.sh
script to create the fhir-schematool
image into the proper namespace for the local cluster.
Then create a local values-file.yaml
file that looks like this:
image:
repository: linuxforhealth/fhir-server
tag: test
replicaCount: 1
schemaMigration:
enabled: true
image:
repository: linuxforhealth/fhir-schematool
tag: latest
pullPolicy: Never
postgresql:
postgresqlPassword: <your-password-here>
After you have created the fhir-server
and fhir-schematool
images in the correct namespace for the local Rancher Desktop kubernetes cluster you can use our helm charts to deploy the FHIR Server locally.
Issue this helm command to use the LinuxForHealth FHIR Server helm charts:
helm repo add alvearie https://alvearie.io/alvearie-helm
Run following command to make sure the added repo is up to date:
helm repo update
Then using the above created values-file.yaml
you can issue this command to use helm to deploy to the local kubernetes cluster:
helm upgrade --install testserver alvearie/ibm-fhir-server -f values-file.yaml --render-subchart-notes --set fhirAdminPassword=$(openssl rand -hex 20)
After the helm upgrade is successful, you should be able to view your local cluster up and running
> kubectl get all
NAME READY STATUS RESTARTS AGE
pod/testserver-postgresql-0 1/1 Running 0 67m
pod/testserver-ibm-fhir-server-6fc75d5c74-tlk2b 1/1 Running 0 67m
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/kubernetes ClusterIP 10.43.0.1 <none> 443/TCP 46h
service/testserver-postgresql-headless ClusterIP None <none> 5432/TCP 67m
service/testserver-postgresql ClusterIP 10.43.196.161 <none> 5432/TCP 67m
service/testserver-ibm-fhir-server ClusterIP 10.43.35.170 <none> 9443/TCP 67m
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/testserver-ibm-fhir-server 1/1 1 1 67m
NAME DESIRED CURRENT READY AGE
replicaset.apps/testserver-ibm-fhir-server-6fc75d5c74 1 1 1 67m
NAME READY AGE
statefulset.apps/testserver-postgresql 1/1 67m
To run against your local FHIR Server you can do a port forward to access the server:
kubectl port-forward service/testserver-ibm-fhir-server 9443:9443 -n default
FHIR® is the registered trademark of HL7 and is used with the permission of HL7. Use of the FHIR trademark does not constitute endorsement of this product by HL7.
IBM and the IBM logo are trademarks of International Business Machines Corporation, registered in many jurisdictions worldwide. Other product and service names might be trademarks of IBM or other companies. A current list of IBM trademarks is available on ibm.com/trademark.