AtlasMap Operator
A Kubernetes operator based on the Operator SDK which can manage AtlasMap on a cluster.
Custom Resource
apiVersion: atlasmap.io/v1alpha1
kind: AtlasMap
metadata:
name: example-atlasmap
spec:
# The number of desired replicas
replicas: 1
# The version of the AtlasMap to use. The default is 'latest'.
# The default image name and tag can be overridden by providing arguments to the AtlasMap operator container
# E.g: --atlasmap-image-name=docker.io/custom-namespace/custom-image --atlasmap-image-version=1.2.3
# Or through environment variables ATLASMAP_IMAGE_NAME & ATLASMAP_IMAGE_VERSION
version: latest
# The host name to use for the OpenShift route or Kubernetes Ingress. If not specified, this is generated automatically
routeHostName: example-atlasmap.192.168.42.115.nip.io
# The amount of CPU to request
requestCPU: 200m
# The amount of memory to request
requestMemory: 256Mi
# The amount of CPU to limit
limitCPU: 300m
# The amount of memory to limit
limitMemory: 512Mi
Features
The AtlasMap operator can:
Create
- AtlasMap deployment, route and service objects
Update
- Reconcile
replicas
count into the deployment
- Reconcile
version
for the container image tag into the deployment and override the default
- Reconcile resource requests for CPU and memory into the deployment
- Reconcile resource limits for CPU and memory into the deployment
Delete
- Remove AtlasMap deployment, route and service objects
Install
On OpenShift the AtlasMap operator can be installed via OperatorHub.
To manually install the required CRDs, roles, role binding & service account, and deploy the AtlasMap operator, run the following commands as a privileged user.
make install
make deploy
Verify that the operator is running:
$ kubectl get deployment atlasmap-operator
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
atlasmap-operator 1 1 1 1 1m
Test
When the operator is running you can deploy an example AtlasMap custom resource:
# Create example-atlasmap
$ kubectl create -f config/samples/atlasmap.io_v1alpha1_atlasmap.yaml
atlasmap.atlasmap.io/example-atlasmap created
# Verify example-atlasmap
$ kubectl get atlasmap example-atlasmap
NAME URL IMAGE PHASE
example-atlasmap https://example-atlasmap-atlasmap.192.168.42.115.nip.io docker.io/atlasmap/atlasmap:latest Deployed
# Scale example-atlasmap
$ kubectl patch atlasmap example-atlasmap --type='merge' -p '{"spec":{"replicas":3}}'
atlasmap.atlasmap.io/example-atlasmap patched
# Delete example-atlasmap
$ kubectl delete atlasmap example-atlasmap
atlasmap.atlasmap.io "example-atlasmap" deleted
Uninstall
To remove the AtlasMap operator from the cluster run:
$ make uninstall
Development
The AtlasMap operator can be run locally:
$ make run
INFO[0000] Running the operator locally.
The AtlasMap operator docker image can be built by running:
$ make build
INFO[0003] Building Docker image docker.io/atlasmap/operator:latest
Integration tests can be run by:
$ make test
INFO[0000] Testing operator locally.
Or to test a local operator build:
$ make test-local
To run lint checks. Install golangci-lint and run:
$ make lint