1. Infra Setup
Quickstart Infra is recommended to jump start with minimal DIGIT services to get a sense of the various installation steps and system requirements.
Last updated
Quickstart Infra is recommended to jump start with minimal DIGIT services to get a sense of the various installation steps and system requirements.
Last updated
âAll content on this page by eGov Foundation is licensed under a Creative Commons Attribution 4.0 International License.
Depending on the H/W requirement of the machine that you want to try Quickstart DIGIT setup, choose the below options for the instructions.
Ensure that the docker is running and you have the admin privileges for the device. Run the following in the terminal/command prompt.
Note: Make sure the k3d is already installed as part of the pre-requisites.
Start with the setup of the lightweight Kubernetes cluster on your local machine/VM. Execute all the instructions as admin/root/sudoer to give the installer full access to provision the required system resources/folders etc.
First, Create "Kube" directory in any desired place (ensure you use the right dir path, if it is different from the example) and change permission. This will be used as k3d cluster persistent storage to store metadata and container logs.
If Linux/Mac
cd ~
mkdir kube
chmod 777 kube
cd kube
pwd #copy the path you get here. Provide an absolute path to below k3d cmd, by replacing "/home/<user_name>/kube" with your directory path
If Windows
cd D:\
mkdir kube
wsl chmod -R 777 kube
cd kube
pwd #copy the path you get here. Provide an absolute path to below k3d cmd, by replacing "/home/<user_name>/kube" with your directory path
Create a k3d cluster with a single master node and 2 agents (Worker Nodes) and mount the above created directory (for data persistence). Here's where it stores all the metadata and persists the logs of the workloads.
k3d cluster create --k3s-server-arg "--no-deploy=traefik" --agents 2 -v "/home/<user_name>/kube:/kube@agent[0,1]" -v "/home/<user_name>/kube:/kube@server[0]" --port "80:80@loadbalancer"
*NOTE: Update "/home/<user_name>/kube" this path in above cmd with your respective absolute path.
When cluster creation is successful, Get the kubeconfig file, which will allow you to connect the to the cluster.
k3d kubeconfig get k3s-default > myk3dconfig
kubectl config use-context k3d-k3s-default --kubeconfig=myk3dconfig
Verify the Cluster creation by running the following commands from your local machine where the kubectl is installed. It gives you the sample output as below if everything works fine.
kubectl cluster-info
OutPut
Kubernetes control plane is running at https://0.0.0.0:33931
CoreDNS is running at https://0.0.0.0:33931/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
Metrics-server is running at https://0.0.0.0:33931/api/v1/namespaces/kube-system/services/https:metrics-server:/proxy
k3d cluster list
OutPut:
NAME SERVERS AGENTS LOADBALANCER
k3s-default 1/1 2/2 true
kubectl get nodes
OutPut:
NAME STATUS ROLES AGE VERSION
k3d-k3s-default-agent-0 Ready <none> 3d18h v1.21.1+k3s1
k3d-k3s-default-agent-1 Ready <none> 3d18h v1.21.1+k3s1
k3d-k3s-default-server-0 Ready control-plane,master 3d18h v1.21.1+k3s1
kubectl top nodes
OutPut:
W0625 07:56:24.588781 12810 top_node.go:119] Using json format to get metrics. Next release will switch to protocol-buffers, switch early by passing --use-protocol-buffers flag
NAME CPU(cores) CPU% MEMORY(bytes) MEMORY%
k3d-k3s-default-agent-0 547m 6% 1505Mi 9%
k3d-k3s-default-agent-1 40m 0% 2175Mi 13%
k3d-k3s-default-server-0 59m 0% 2286Mi 14%
Know what is terraform: https://youtu.be/h970ZBgKINg
Install terraform for the Infra-as-code (IaC) to provision cloud resources as code and with desired resource graph and also it helps to destroy the cluster at one go. The desired terraform version is 0.14.10.
If you already have a different version of the terraform version running install tfswitch that would allow you to have multiple terraform versions in the same machine and toggle between the desired versions.
If you are not using the eGov AWS account. In that case, you have to open 80, 22, and 6550 ports in a default security group
Clone the following DIGIT Devops GitRepo, you may need to install git and then run git clone it to your machine.
git clone -b quickstart https://github.com/egovernments/DIGIT-DevOps
After cloning the repo CD into the folder DIGIT-DevOps and type the "code ." command that will open the visual editor and opens all the files from the repo DIGIT-DevOps
cd DIGIT-DevOps/infra-as-code/terraform/quickstart-aws-ec2
code .
Generate ssh key
The following main.tf will create ec2 instance.
provider "aws" {
region = "${var.region}"
}
module "ssh_key" {
source = "../modules/instance/aws-ec2"
key_name = "${var.key_name}"
public_key = "${var.public_key}"
}
resource "aws_instance" "digit-quickstart-vm" {
ami = "${var.ami_name_value}"
instance_type = "${var.instance_type}"
key_name = module.ssh_key.ssh_key_name
monitoring = false
associate_public_ip_address = true
availability_zone = "ap-south-1b"
tags = {
Name = "${var.tag}"
}
}
5. Update variables.tf
variable "region" {
default = "ap-south-1"
}
variable "ami_name_value" {
default = "ami-0bb9e2d19522c61d4"
}
variable "instance_type" {
default = "c5.2xlarge"
}
## The VM capacity may depend on the H/W requirement of the number of DIGIT modules that you may try for the POC
## Eg:
variable "tag" {
default = "digit-quickstart-vm" ## change tag name eg. digit-quickstart-vm_your-name_name
}
## change ssh public_key with your public ssh key
variable "public_key" {
default = "ssh-rsa <asfas>/Gy6w0PPSnnfl/AWXO7ckFtEXQbdz9Y15zeUFKgUsbklXxmC6D37BkPGu+IjCZSOttPV+PRM0Dnf0jQLvMV0UhEkguD9ALC5xikqNlFyPH5bGetWDxtLbn61tnoOIYG6lXAdk2Oe35yWWt3ZgcccWtYuRwDo0ofBwY9jWOkEcCefDyYg+S7h1VzNsbB9DsFv0vPcaxHcZK8bLdyhnz1+9rXy/flbiS5kE0O97aZ4zm4wAmqiivN2wWhUez18k2Mcs= demo@demo"
description = "ssh key"
}
variable "key_name" {
default = "digit-quickstart-vm" ## change ssh key_name eg.digit-quickstart-vm-your_name
description = "ssh key name"
}
6. Export AWS Profile.
export AWS_PROFILE=digit-quickstart-poc
6. Terraform Execution:
cd DIGIT-DevOps/infra-as-code/terraform/quickstart-aws-ec2
terraform init
terraform plan
terraform apply
7. The terraform apply command displays the results of creating the resource defined in your configuration files.
Note: Copy the "Public IP" from the outputs.
module.ssh_key.aws_key_pair.ssh_key: Creating...
module.ssh_key.aws_key_pair.ssh_key: Creation complete after 0s [id=digit-quickstart-vm]
aws_instance.digit-quickstart-poc: Creating...
aws_instance.digit-quickstart-poc: Still creating... [10s elapsed]
aws_instance.digit-quickstart-poc: Creation complete after 12s [id=i-05764e3b780d836dd]
Apply complete! Resources: 2 added, 0 changed, 0 destroyed.
Outputs:
public_ip = "<some_public_ip>"
8. terraform out provided you with vm/instance public IP use same to login.
ssh -i <path_to_ssh_private_key> ubuntu@<your_vm_public_ip>
NOTE: replace IP <your_vm_public_ip> with your respective public IP
After logging into the newly provisioned AWS ec2 instance perform the below steps
The VM Has most of the above mentioned pre-requisites, you can directly execute the below commands, incase you are trying on any other VM of your choice, ensure that you install all the mentioned softwares/tools and you have the admin access to your machine.
As a first step, Let's setup the lightweight kubernetes cluster on your VM. You must execute all the instructions as admin/root/sudoer to give the installer full access to provision the required system resources/folders etc.
Notes:
Update "/home/<your_user_name>/kube" this path in below cmd with your respective absolute path
To route the traffic to the above created cluster to be able to connect to the cluster from your local machine/laptop using kubeconfig file
Update <VM_Private_IP> with VM Private IP, use below command on VM terminal to get private IP.
ip a | grep "inet " | grep -v "127.0.0.1" | awk -F " " '{print $2}'|awk -F "/" '{print $1}'|head -n1
Update <VM_Public_IP> with VM's Public IP which you used to ssh into VM.
Copy myk3dconfig to your local machine/laptop
Replace the clusters.cluster.server Private IP with Public Ip from your myk3dconfig
.
For reference observe the below kubeconfig
apiVersion: v1
clusters:
- cluster:
certificate-authority-data:
server: https://<VM_Private_IP>:6550 //replace <VM_Private_IP> with <VM_Public_IP>
name: k3d-k3s-default
contexts:
- context:
cluster: k3d-k3s-default
user: admin@k3d-k3s-default
name: k3d-k3s-default
current-context: k3d-k3s-default
kind: Config
preferences: {}
users:
- name: admin@k3d-k3s-default
user:
client-certificate-data:
client-key-data:
3. Setup kubeconfig
export KUBECONFIG=<path-to-your-kube_config>
4. To check the nodes from local run the below command
kubectl get nodes --kubeconfig=<path-to-your-kube_config>
Now you can start with the Deployment.
Once you are done with the Quickstart setup, Destroy the terraform resources.
cd DIGIT-DevOps/infra-as-code/terraform/digit-quickstart-aws
terraform destroy
If the above steps are completed successfully, your cluster is now up and running ready to proceed with the DIGIT Deployment.
âAll content on this page by eGov Foundation is licensed under a Creative Commons Attribution 4.0 International License.