Gloo Edge setup on Kubernetes
data:image/s3,"s3://crabby-images/d0ec2/d0ec2d3ec788af2082f9b707ca164ff0551cfabe" alt="Gloo Edge setup on Kubernetes"
Gloo Edge
Gloo Edge is a modern Kubernetes-native API Gateway that provides all of the functionality from within Kubernetes. Gloo Edge help us to solve how we manage API and Web traffic at scale across our Enterprise.
data:image/s3,"s3://crabby-images/084b6/084b6e2578bcc2cb7b598c865644ff8c6e2897db" alt=""
Setup Gloo Edge Open-Source in Minikube
Gloo Edge Open-Source runs in 3 different modes
- Run Gloo Edge in
gateway
mode to function as an API Gateway. - Run Gloo Edge in
ingress
mode to act as a standard Kubernetes Ingress controller. - Gloo Edge Enterprise
There are two primary ways to install the Gloo Edge in production
- Install Gloo Edge on Kubernetes
- Run Gloo Edge on a HashiCorp Nomad Cluster, using Consul for configuration and Vault for secret storage.
Kubernetes Cluster Setup & Gloo Edge Install
We are going to install Gloo Edge in Kubernetes
In this Demo, Let us install Gloo Edge in Minikube Kubernetes Cluster environmentSteps:
- Install Colima
- Install Minikube
- Install Gloo Edge
- Install Gloo Gateway
- Deploy sample Application
- Verify the Upstream for the sample Application
- Configure Routing
- Verify Virtual Service
- Test the Application
To Install Colima & Minikube on Mac OS
Ref: https://blog.kubelancer.com/install-minikube-on-mac-os/
Install Gloo Edge
Run below command to install gloo control binary
$ curl -sL https://run.solo.io/gloo/install | sh
data:image/s3,"s3://crabby-images/6aba9/6aba9fa006ca061b77cd926268e14467048d7831" alt=""
Export binary PATH as OS env
$ export PATH=$HOME/.gloo/bin:$PATH
data:image/s3,"s3://crabby-images/0b9eb/0b9eb797a006dfeab45099c9e773d240cdc555c1" alt=""
Install Gloo Gateway
$ glooctl install gateway
data:image/s3,"s3://crabby-images/6ed31/6ed318ad2e2042fa75530ced0a03ba3c67ed119b" alt=""
Verify Gloo Gateway installation Status
data:image/s3,"s3://crabby-images/afd27/afd27203e1c607a339b407e0eb5094111dd91db3" alt=""
Look at LoadBalancer is Pending..To assign LoadBalancer IP Address, Creates a network tunnel to expose services of type LoadBalancer
to your local loopback IP address 127.0.0.1 / localhost.
Run in separate Terminal window
$ minikube tunnel
data:image/s3,"s3://crabby-images/b2975/b2975d53036f08b1d5e3816f654e675da12b40e7" alt=""
Verify LoadBalancer
$ kubectl get svc -n gloo-system
data:image/s3,"s3://crabby-images/b9f2f/b9f2fbe712ab683fca9c356461d10a12613f97bc" alt=""
Let us Deploy a sample Application on dev namespace
$ git clone https://github.com/kubelancer/kubelancer-lab-sample-deployment.git
$ cd kubelancer-lab-sample-deployment
$ kubectl apply -f deployment.yaml
data:image/s3,"s3://crabby-images/d9e5d/d9e5d9058d5f7b0dd64348e27e0c6a7da0d00e58" alt=""
Verify the Upstream for the sample Application
$ glooctl get upstreams
data:image/s3,"s3://crabby-images/a60d9/a60d9956e63854672ff1479a6c9bd2dab8f32d49" alt=""
Configure Route
Now we Configure Route to create traffic rules to expose the Application public Access
$ glooctl add route --path-prefix=/ --dest-name dev-kubeapp-80
--dest-name dev-kubeapp is the upstream
data:image/s3,"s3://crabby-images/a3254/a3254166012ee40227e3b2f369f83cf0721c1469" alt=""
Verify Virtual Service
$ glooctl get virtualservice
data:image/s3,"s3://crabby-images/51159/5115984bdc9298a278de3a899520febf875d75dd" alt=""
Test the Application
Run http://localhost
Output
data:image/s3,"s3://crabby-images/1c7ae/1c7ae00a2d78defab724778ed31576296dfe4ab2" alt=""
To Uninstall sample application, Gloo Edge, Minikube and Colima
$ kubectl delete -f deployment.yaml
$ glooctl uninstall --all
$ minikube stop
$ colima stop