Deploy a Prebuilt Container Image
This guide walks you through deploying a prebuilt container image to OpenChoreo. This is useful when you have existing container images built by external CI/CD pipelines and want to deploy them without using OpenChoreo's Build Plane.
Overviewβ
OpenChoreo supports deploying applications from prebuilt container images, commonly referred to as "Bring Your Own Image" (BYOI). You can deploy images from:
- Public registries - No additional configuration needed
- Private registries - Requires setting up image pull credentials
Prerequisitesβ
Before you begin, ensure you have:
- OpenChoreo installed in your Kubernetes cluster
- kubectl configured to access your cluster
- A container image to deploy
Deploy from a Public Registryβ
Deploying an image from a public registry is straightforward - simply create the Component and Workload resources.
Exampleβ
kubectl apply -f - <<EOF
---
apiVersion: openchoreo.dev/v1alpha1
kind: Component
metadata:
name: my-app
namespace: default
spec:
autoDeploy: true
componentType: deployment/service
owner:
projectName: default
parameters:
exposed: true
port: 80
replicas: 1
resources:
limits:
cpu: 500m
memory: 512Mi
requests:
cpu: 100m
memory: 256Mi
---
apiVersion: openchoreo.dev/v1alpha1
kind: Workload
metadata:
name: my-app-workload
namespace: default
spec:
owner:
componentName: my-app
projectName: default
containers:
main:
image: "nginx:latest"
EOF
Replace the following values with your own:
nginx:latest- Your image reference80- The port your application listens on- Add environment variables as needed by your application
Verify the Deploymentβ
Check that the component is created:
kubectl get component my-app
Check that the workload is created:
kubectl get workload my-app-workload
Check that pods are running:
kubectl get pods -A | grep my-app
Test Your Applicationβ
Once the deployment is ready, test your application:
curl http://development.openchoreoapis.localhost:19080/my-app/
Deploy from a Private Registryβ
In addition to creating the Component and Workload resources as shown above, pulling images from a private registry requires setting up authentication. You need to:
- Store your registry credentials in your secret store
- Add an ExternalSecret resource to your ComponentType to sync the credentials
- Add
imagePullSecretsto the Deployment in your ComponentType
Store Registry Credentialsβ
This example uses the default ClusterSecretStore included with the default OpenChoreo installation. For production environments, see Secret Management to configure a proper secret backend.
Here's an example using Docker Hub:
1. Generate the auth string (base64-encoded username:password):
echo -n "your-dockerhub-username:your-access-token" | base64
2. Create the Docker config JSON:
{
"auths": {
"https://index.docker.io/v1/": {
"auth": "<your-base64-auth-string>"
}
}
}
3. Store the credentials in the ClusterSecretStore:
kubectl patch clustersecretstore default --type='json' -p='[
{
"op": "add",
"path": "/spec/provider/fake/data/-",
"value": {
"key": "registry-credentials",
"value": "{\"auths\":{\"https://index.docker.io/v1/\":{\"auth\":\"<your-base64-auth-string>\"}}}"
}
}
]'
Replace <your-base64-auth-string> with the value generated in step 1.
Update Your ComponentTypeβ
Add an ExternalSecret resource to sync the registry credentials:
- id: registry-pull-secret
template:
apiVersion: external-secrets.io/v1
kind: ExternalSecret
metadata:
name: registry-pull-secret
namespace: ${metadata.namespace}
spec:
refreshInterval: 15s
secretStoreRef:
name: ${dataplane.secretStore}
kind: ClusterSecretStore
target:
name: registry-pull-secret
creationPolicy: Owner
template:
type: kubernetes.io/dockerconfigjson
data:
- secretKey: .dockerconfigjson
remoteRef:
key: registry-credentials
Then add imagePullSecrets to your Deployment template:
- id: deployment
template:
apiVersion: apps/v1
kind: Deployment
metadata:
name: ${metadata.name}
namespace: ${metadata.namespace}
spec:
template:
spec:
imagePullSecrets:
- name: registry-pull-secret
containers:
- name: main
image: ${workload.containers.main.image}
# ... rest of container config
Summaryβ
You've learned how to deploy prebuilt container images using the OpenChoreo BYOI (Bring Your Own Image) flow from both public and private registries.
Next Stepsβ
- Configure API Management to secure your deployed APIs
- Set up Secret Management for automatic credential rotation
- Explore more examples of deploying applications