Install CCX on a Laptop
This guide explains how to install Docker Desktop, enable Kubernetes, configure AWS credentials for deploying CCX's datastore in AWS, and deploy CCX on the Kubernetes cluster.
Prerequisites
- System requirements: a laptop/desktop with atleast 4 cores and 8GB of RAM, 20GB of free storage.
- Docker Desktop, download Docker Desktop from the official Docker website.
- kubectl installed and on the PATH, get kubectl here.
- AWS CLI, see the AWS installation guide.
- AWS credentials, allowing you to create VMs, volumes, security groups, networks, S3, etc..
- Helm installed on your system. If not, follow the Helm installation guide.
Step 1: Enable Kubernetes in Docker Desktop
- Open Docker Desktop and navigate to Settings > Kubernetes.
- Check the box Enable Kubernetes and click Apply & Restart. We have tested these instructions with Kubernetes v1.30.5.
-
Wait for Kubernetes to initialize. It may take some time for Kubernetes to be Started. You can verify this by running:
The output of this command should look something like this:kubectl cluster-info
Kubernetes control plane is running at https://127.0.0.1:6443 CoreDNS is running at https://127.0.0.1:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
-
Ensure that the
docker-desktop
context is selected:kubectl config use-context docker-desktop
Step 2: Create and Switch to a Namespace
-
Create a new namespace for CCX:
kubectl create namespace ccx
-
Switch your context to use this namespace:
kubectl config set-context --current --namespace=ccx
Step 3: Configure AWS Credentials
CCX uses AWS credentials to deploy its datastore in the AWS cloud. These credentials need to be securely provided to Kubernetes as a secret.
-
Run the following command to configure your AWS credentials:
aws configure
Provide the following details:
- AWS Access Key ID
- AWS Secret Access Key
- Default Region
-
Create a Kubernetes secret for the AWS credentials using the following command:
Verify the secret is available:kubectl create secret generic aws \ --from-literal=AWS_ACCESS_KEY_ID=$(awk 'tolower($0) ~ /aws_access_key_id/ {print $NF; exit}' ~/.aws/credentials) \ --from-literal=AWS_SECRET_ACCESS_KEY=$(awk 'tolower($0) ~ /aws_secret_access_key/ {print $NF; exit}' ~/.aws/credentials)
The output of this command should look something like this:kubectl get secrets aws
NAME TYPE DATA AGE aws Opaque 2 24s
Step 4: Deploy CCX Using Helm
-
Add the required Helm repository:
and you will see:helm repo add s9s https://severalnines.github.io/helm-charts/ helm repo update
"s9s" has been added to your repositories Hang tight while we grab the latest from your chart repositories... ...Successfully got an update from the "s9s" chart repository Update Complete. ⎈Happy Helming!⎈
-
Deploy CCXDEPS using the following command:
helm upgrade --install ccxdeps s9s/ccxdeps --debug --wait --set ingressController.enabled=true
-
Deploy CCX:
Danger
This setup is only for demo and development purposes and the installtion will only work for the specified CIDR or 0.0.0.0/0 if no CIDR is set. For production and testing we recommend to follow the installation guide and overriding the values.yaml with your settings. If you set the CIDR below then CCX will only be able to access the datastores from this CIDR.
Using the CIDR 0.0.0.0/0 (access is allowed from everywhere, which might be a security risk):
helm upgrade --install ccx s9s/ccx \
--debug --wait \
--set 'ccx.cloudSecrets[0]=aws'
Using a custom CIDR N.N.N.N/32 (access is allowed only from this CIDR):
curl ifconfig.me
# Replace the N.N.N.N below with the output (not includingt the %) of the curl ifconfig.me command.
helm upgrade --install ccx s9s/ccx \
--debug --wait \
--set 'ccx.cloudSecrets[0]=aws' \
--set 'ccx.cidr=N.N.N.N/32'
Note
If you move the laptop/computer where the installation is made to another location, then you must login to the AWS Console and add that network to the security group.
Verification
- Once the deployment is complete, verify the CCX installation by accessing
https://ccx.localhost
in your web browser. -
Use the following command to confirm that all pods are running successfully:
kubectl get pods
Accessing the frontends
CCX frontend
The CCX frontend is the end-user interface and allows the end-user to create and manage datastores. The necessary infrastructure (VMs, volumes, etc) are created and managed by CCX.
- Navigate to
https://ccx.localhost
in your web browser. - Register a new user. In this configuration, no confirmation email will be sent and you will need to go back to
https://ccx.localhost
(you can press Back in the browser) and login with your email address and password.
CC frontend
The CC frontend is an administrative interface and allows the CCX administrator to manage datastores.
- Navigate to
https://cc.localhost
in your web browser. -
Login with the CC credentials, which are stored in Kubernets secrets:
kubectl get secret cmon-credentials -o jsonpath='{.data.cmon-user}' | base64 -d kubectl get secret cmon-credentials -o jsonpath='{.data.cmon-password}' | base64 -d
Danger
Do not use this UI to delete clusters or add and remove nodes. Please see the Troubleshooting guide.
Troubleshooting
- If you experience sudden glitches or pod failures, you can try allocate more resoures too Docker Desktop. You can allocated more resources under
Settings->Resources->Advanced
. - If you experience issues deploying, reset the environment (Settings->Kubernetes, Reset Kubernetes Cluster), increase resources, and try again.
- Troubleshooting guide.
- Problems? Create a GitHub issue.
Limitations
- Backups are not supported. A license to CMON is required. Please contact [email protected].
Next steps
- Installation guide.
- Visit Severalnines.com for more information about Severalnines, and CCX in general.
This document provides step-by-step instructions to set up Docker Desktop, Kubernetes, and CCX with a datastore deployed in AWS. For further details, refer to the official CCX documentation.