DEV Community

Cover image for Multi-Tenancy In EKS Cluster Using Vcluster

Multi-Tenancy In EKS Cluster Using Vcluster

Abstract

  • Why should we consider using Vcluster? Our requirement is to establish multiple environments for developers to facilitate development, testing, as well as regression and performance tests.
  • The crucial aspect is ensuring that these environments closely mimic the structure of our staging and production environments, which are based on Kubernetes. Instead of relying on Kubernetes namespaces to create these environments, We opt to offer developers a solution that provides them with an environment that closely resembles a real Kubernetes cluster. This is where Vcluster comes into play.

  • Watch Demo: https://www.youtube.com/watch?v=vWNkGyLajJE

  • Source code: https://github.com/vumdao/multi-tenancy-using-vcluster-in-eks/tree/master

Table Of Contents


๐Ÿš€ vcluster overview

๐Ÿš€ Solution overview

๐Ÿš€ Bootstrap EKS cluster using CDK EKS Blueprints

    new VpcCniAddOn(),
    new MetricsServerAddOn(),
    new KarpenterAddOn(),
    new AwsLoadBalancerControllerAddOn(),
    new EbsCsiDriverAddOn(),
Enter fullscreen mode Exit fullscreen mode
  • Cluster provider
    • Fargate to deploy Karpenter
    • Karpenter simplifies Kubernetes infrastructure with the right nodes at the right time.

๐Ÿš€ Create vcluster

  • Create two vclusters with namepsace app1 and app2
  $ ./demo/create-vcl.sh app1
  $ ./demo/create-vcl.sh app2
Enter fullscreen mode Exit fullscreen mode

๐Ÿš€ Expose vcluster using Network Laoad Balancer

  • Create NLB service
  โœ— k apply -f demo/app1/service.yaml
  service/app1-lb created

  โœ— k apply -f demo/app2/service.yaml
  service/app2-lb created

  โœ— k get svc -n app1 app1-lb
  NAME      TYPE           CLUSTER-IP       EXTERNAL-IP                                                                    PORT(S)         AGE
  app1-lb   LoadBalancer   172.20.150.105   k8s-app1-app1lb-bb32c11098-3381306256798df4.elb.ap-southeast-1.amazonaws.com   443:32392/TCP   30h

  โœ— k get svc -n app2 app2-lb
  NAME      TYPE           CLUSTER-IP      EXTERNAL-IP                                                                    PORT(S)         AGE
  app2-lb   LoadBalancer   172.20.78.127   k8s-app2-app2lb-4690ffbcfe-bfb88a1245728e8a.elb.ap-southeast-1.amazonaws.com   443:31510/TCP   49s
Enter fullscreen mode Exit fullscreen mode
  • Create CName record point to the NLB DNS
  โžœ  multi-tenancy-in-eks-using-vcluster git:(master) โœ— ./demo/r53-record.sh create app2
  โžœ  multi-tenancy-in-eks-using-vcluster git:(master) โœ— ping app2-eks.simflexcloud.com
  PING k8s-app2-app2lb-4690ffbcfe-bfb88a1245728e8a.elb.ap-southeast-1.amazonaws.com (13.250.162.120): 56 data bytes
Enter fullscreen mode Exit fullscreen mode
  • Now we can connect to the vcluster app1 and app2 using their expose endpoint

    โœ— vcluster connect app2 -n app2 --server=https://app2-eks.simflexcloud.com --update-current=false
    done โˆš Virtual cluster kube config written to: ./kubeconfig.yaml
    - Use `kubectl --kubeconfig ./kubeconfig.yaml get namespaces` to access the vcluster
    

๐Ÿš€ Deploy applications on vcluster

  • Deploy echo and guestbook project
  โœ— ka2 apply -f demo/app2/vcluster
  ingress.networking.k8s.io/echo created
  deployment.apps/echo created
  service/echo created
  ingress.networking.k8s.io/guestbook created
  service/redis-leader created
  deployment.apps/redis-leader created
  service/redis-follower created
  deployment.apps/redis-follower created
  service/frontend created
  deployment.apps/frontend created
Enter fullscreen mode Exit fullscreen mode
  • Get ALB DNS and point to the Web app endpoint

    โœ— ka2 get ingress
    NAME        CLASS   HOSTS   ADDRESS                                                          PORTS   AGE
    echo        alb     *       k8s-app2-dbb948e3be-939359744.ap-southeast-1.elb.amazonaws.com   80      10s
    guestbook   alb     *       k8s-app2-dbb948e3be-939359744.ap-southeast-1.elb.amazonaws.com   80      10s
    โœ— ./demo/r53-record.sh create app2 k8s-app2-dbb948e3be-939359744.ap-southeast-1.elb.amazonaws.com
    

๐Ÿš€ Cleanup

  • Delete vcluster
  โœ— vcluster delete dev -n dev
  info   Delete vcluster dev...
  done โˆš Successfully deleted virtual cluster dev in namespace dev
  done โˆš Successfully deleted virtual cluster pvc data-dev-0 in namespace dev
Enter fullscreen mode Exit fullscreen mode
  • Destroy all AWS resources within this project

Top comments (0)