Custom IG Image
The IG configuration provided in the CDK canonical configuration profile is an example, and is not meant for use in production. Remove this configuration and replace it with your own routes before using IG in your environment.
See the IG Deployment Guide for configuring routes.
Prerequisites
Before starting to build and deploy your custom IG image, initialize a new configuration profile and set up your local environment to write Docker images:
-
Initialize a new configuration profile by copying the canonical CDK configuration:
$ cd /path/to/forgeops/config/7.0 $ cp -r cdk my-ig
-
Configure your environment to write to your Docker registry:
Minikube
Set up your local environment to execute docker commands on Minikube’s Docker engine:
-
Run the docker-env command in your shell:
$ eval $(minikube docker-env)
-
Stop Skaffold from pushing Docker images to a remote Docker registry:
$ skaffold config set --kube-context minikube local-cluster true set value local-cluster to true for context minikube
GKE shared cluster
To set up your local computer to push Docker images:
-
If it’s not already running, start Docker on your local computer. For more information, see the Docker documentation.
-
Set up a Docker credential helper:
$ gcloud auth configure-docker
-
Run the kubectx command to obtain the Kubernetes context.
-
Configure Skaffold with the Docker registry location you obtained from your cluster administrator and the Kubernetes context you obtained in Context for the Shared Cluster:
$ skaffold config set default-repo my-docker-registry --kube-context my-kubernetes-context
EKS shared cluster
Set up your local computer to push Docker images to Amazon ECR:
-
If it’s not already running, start Docker on your local computer. For more information, see the Docker documentation.
-
Log in to Amazon ECR. Use the Docker registry location you obtained from your cluster administrator:
$ aws ecr get-login-password | \ docker login --username AWS --password-stdin my-docker-registry stdin my-docker-registry Login Succeeded
ECR login sessions expire after 12 hours. Because of this, you’ll need to perform these steps again whenever your login session expires.
-
Run the kubectx command to obtain the Kubernetes context.
-
Configure Skaffold with the Docker registry location and the Kubernetes context:
$ skaffold config set default-repo my-docker-registry --kube-context my-kubernetes-context
AKS shared cluster
Set up your local computer to push Docker images to Azure container registry:
-
If it’s not already running, start Docker on your local computer. For more information, see the Docker documentation.
-
Install the ACR Docker Credential Helper.
-
Run the kubectx command to obtain the Kubernetes context.
-
Configure Skaffold with the Docker registry location you obtained from your cluster administrator and the Kubernetes context you obtained in Context for the Shared Cluster:
$ skaffold config set default-repo my-docker-registry --kube-context my-kubernetes-context
-
Build a Custom IG Image and Deploy IG
-
Verify that the CDK is up and running.
-
Configure IG by creating, modifying, or deleting rules in /path/to/forgeops/config/my-ig/ig/config/routes-service directory.
-
Copy your customized IG configuration to the staging area:
$ cd /path/to/forgeops/config/7.0/my-ig $ cp -r ./ig /path/to/forgeops/docker/7.0
-
Build a new IG image that includes your custom configuration:
$ /path/to/forgeops/bin/cdk build ig Generating tags… - ig → ig:0a27bdfea Checking cache… - ig: Not found. Building Starting build… Found [minikube] context, using local docker daemon. Building [ig]… Sending build context to Docker daemon 55.81kB Step 1/5 : FROM us-docker.pkg.dev/forgeops-public/images/ig:2023.11.0 --→ ba6f8150204e Step 2/5 : ARG CONFIG_PROFILE=cdk . . . Step 5/5 : COPY --chown=forgerock:root . /var/ig --→ c173995218a3 Successfully built c173995218a3 Successfully tagged ig:0a27bdfea Updated the image_defaulter with your new image for ig: "ig:c173995218a3c55dbca76fff08588153db0693a51ff0904e6adee34b7163340a"
-
Uninstall the previously deployed IG from your CDK:
-
Set the active namespace in your local Kubernetes context to the namespace in which you have deployed the IG.
-
Delete IG:
$ /path/to/forgeops/bin/cdk delete ig Uninstalling component(s): ['ig'] OK to delete these components? [Y/N] y secret "openig-secrets-env" deleted service "ig" deleted deployment.apps "ig" deleted
-
-
Deploy your customized IG image:
$ /path/to/forgeops/bin/cdk install ig Checking secret-agent operator and related CRDs: secret-agent CRD found in cluster. Checking ds-operator and related CRDs: ds-operator CRD found in cluster. Installing component(s): ['ig'] secret/openig-secrets-env created service/ig created deployment.apps/ig created Enjoy your deployment!
-
Run the kubectl get pods command to check the status of the IG pod. Wait until the IG pod is ready before proceeding to the next step.
-
Verify that your IG routes work.