Kubernetes
9 minute read
Kubernetes
Issues
See Troubleshooting
Kubectl
You can see from the Troubleshooting link above that the default secruity setup for kubectl is to have sudo rights to run and then to specify the kubeconfig=/etc/kubernetes/admin.conf as an additional parameter to kubectl. Also, by default, this only works on the Control Plane nodes. To have it work on Worker nodes or any node in the cluster do the following. Make sure it complies with your Security strategy:
# Control Plane node - Option 2 from link above...
mkdir -p $HOME/.kube
sudo cp /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
Once kubectl is working as desired from a non-root user, you can simply:
- Copy the ./kube/configfile from the Control Plane node
- Create the ./kubedirectory in the non-root user's home directory and then paste theconfigfile copied in #1
- Do this for any node you want to access kubectlon for a given cluster
Supported CNI plugins
LambdaStack supports following CNI plugins:
Flannel is a default setting in LambdaStack configuration.
NOTE
Calico is not supported on Azure. To have an ability to use network policies, choose Canal.
Use the following configuration to set up an appropriate CNI plugin:
 kind: configuration/kubernetes-master
 name: default
 specification:
   advanced:
     networking:
       plugin: flannel
Kubernetes applications - overview
Currently, LambdaStack provides the following predefined applications which may be deployed with lambdastack:
- ignite
- rabbitmq
- auth-service (Keycloak)
- pgpool
- pgbouncer
- istio
All of them have
default configuration.
The common parameters are: name, enabled, namespace, image_path and use_local_image_registry.
If you set use_local_image_registry to false in configuration manifest, you have to provide a valid docker image
path in image_path. Kubernetes will try to pull image from image_path value externally.
To see what version of the application image is in local image registry please refer
to components list.
Note: The above link points to develop branch. Please choose the right branch that suits to LambdaStackphany version you are using.
How to expose service through HA Proxy load balancer
- 
Create NodePortservice type for your application in Kubernetes.
- 
Make sure your service has statically assigned nodePort(a number between 30000-32767), for example 31234. More info here.
- 
Add configuration document for load_balancer/HAProxyto your main config file.kind: configuration/haproxy title: "HAProxy" name: haproxy specification: frontend: - name: https_front port: 443 https: yes backend: - http_back1 backend: - name: http_back1 server_groups: - kubernetes_node port: 31234 provider: <your-provider-here-replace-it>
- 
Run lambdastack apply.
How to do Kubernetes RBAC
Kubernetes that comes with LambdaStack has an admin account created, you should consider creating more roles and accounts - especially when having many deployments running on different namespaces.
To know more about RBAC in Kubernetes use this link
How to run an example app
Here we will get a simple app to run using Docker through Kubernetes. We assume you are using Windows 10, have an LambdaStack cluster on Azure ready and have an Azure Container Registry ready (might not be created in early version LambdaStack clusters. If you don't have one you can skip to point no 11 and test the cluster using some public app from the original Docker Registry). Steps with asterisk can be skipped.
- 
Install Chocolatey 
- 
Use Chocolatey to install: - Docker-for-windows (choco install docker-for-windows, requires Hyper-V)
- Azure-cli (choco install azure-cli)
 
- Docker-for-windows (
- 
Make sure Docker for Windows is running (run as admin, might require a restart) 
- 
Run docker build -t sample-app:v1 .in examples/dotnet/lambdastack-web-app.
- 
*For test purposes, run your image locally with docker run -d -p 8080:80 --name myapp sample-app:v1and head tolocalhost:8080to check if it's working.
- 
*Stop your local docker container with: docker stop myappand rundocker rm myappto delete the container.
- 
*Now that you have a working docker image we can proceed to the deployment of the app on the LambdaStack Kubernetes cluster. 
- 
Run docker login myregistry.azurecr.io -u myUsername -p myPasswordto login into your Azure Container Registry. Credentials are in theAccess keystab in your registry.
- 
Tag your image with: docker tag sample-app:v1 myregistry.azurecr.io/samples/sample-app:v1
- 
Push your image to the repo: docker push myregistry.azurecr.io/samples/sample-app:v1
- 
SSH into your LambdaStack clusters master node. 
- 
*Run kubectl cluster-infoandkubectl config viewto check if everything is okay.
- 
Run kubectl create secret docker-registry myregistry --docker-server myregistry.azurecr.io --docker-username myusername --docker-password mypasswordto create k8s secret with your registry data.
- 
Create sample-app.yamlfile with contents:apiVersion: apps/v1 kind: Deployment metadata: name: sample-app spec: selector: matchLabels: app: sample-app replicas: 2 template: metadata: labels: app: sample-app spec: containers: - name: sample-app image: myregistry.azurecr.io/samples/sample-app:v1 ports: - containerPort: 80 resources: requests: cpu: 100m memory: 64Mi limits: memory: 128Mi imagePullSecrets: - name: myregistry
- 
Run kubectl apply -f sample-app.yaml, and after a minute runkubectl get podsto see if it works.
- 
Run kubectl expose deployment sample-app --type=NodePort --name=sample-app-nodeport, then runkubectl get svc sample-app-nodeportand note the second port.
- 
Run kubectl get pods -o wideand check on which node is the app running.
- 
Access the app through [AZURE_NODE_VM_IP]:[PORT] from the two previous points - firewall changes might be needed. 
How to set resource requests and limits for Containers
When Kubernetes schedules a Pod, it’s important that the Containers have enough resources to actually run. If you schedule a large application on a node with limited resources, it is possible for the node to run out of memory or CPU resources and for things to stop working! It’s also possible for applications to take up more resources than they should.
When you specify a Pod, it is strongly recommended to specify how much CPU and memory (RAM) each Container needs. Requests are what the Container is guaranteed to get. If a Container requests a resource, Kubernetes will only schedule it on a node that can give it that resource. Limits make sure a Container never goes above a certain value. For more details about the difference between requests and limits, see Resource QoS.
For more information, see the links below:
How to run CronJobs
NOTE: Examples have been moved to their own repo but they are not visible at the moment.
- 
Follow the previous point using examples/dotnet/LambdaStack.SampleApps/LambdaStack.SampleApps.CronApp 
- 
Create cronjob.yamlfile with contents:apiVersion: batch/v1beta1 kind: CronJob metadata: name: sample-cron-job spec: schedule: "*/1 * * * *" # Run once a minute failedJobsHistoryLimit: 5 jobTemplate: spec: template: spec: containers: - name: sample-cron-job image: myregistry.azurecr.io/samples/sample-cron-app:v1 restartPolicy: OnFailure imagePullSecrets: - name: myregistrysecret
- 
Run kubectl apply -f cronjob.yaml, and after a minute runkubectl get podsto see if it works.
- 
Run kubectl get cronjob sample-cron-jobto get status of our cron job.
- 
Run kubectl get jobs --watchto see job scheduled by the “sample-cron-job” cron job.
How to test the monitoring features
Prerequisites: LambdaStack cluster on Azure with at least a single VM with prometheus and grafana roles enabled.
- 
Copy ansible inventory from build/lambdastack/*/inventory/toexamples/monitoring/
- 
Run ansible-playbook -i NAME_OF_THE_INVENTORY_FILE grafana.ymlinexamples/monitoring
- 
In the inventory file find the IP adress of the node of the machine that has grafana installed and head over to https://NODE_IP:3000- you might have to head over to Portal Azure and allow traffic to that port in the firewall, also ignore the possible certificate error in your browser.
- 
Head to Dashboards/Manageon the side panel and selectKubernetes Deployment metrics- here you can see a sample kubernetes monitoring dashboard.
- 
Head to http://NODE_IP:9090to see Prometheus UI - there in the dropdown you have all of the metrics you can monitor with Prometheus/Grafana.
How to run chaos on LambdaStack Kubernetes cluster and monitor it with Grafana
- 
SSH into the Kubernetes master. 
- 
Copy over chaos-sample.yamlfile from the example folder and run it withkubectl apply -f chaos-sample.yaml- it takes code fromgithub.com/linki/chaoskubeso normal security concerns apply.
- 
Run kubectl create clusterrolebinding chaos --clusterrole=cluster-admin --user=system:serviceaccount:default:defaultto start the chaos - random pods will be terminated with 5s ferquency, configurable inside the yaml file.
- 
Head over to Grafana at https://NODE_IP:3000, open a new dashboard, add a panel, set Prometheus as a data source and putkubelet_running_pod_countin the query field - now you can see how Kubernetes is replacing killed pods and balancing them between the nodes.
- 
Run kubectl get svc nginx-serviceand note the second port. You can access the nginx page via[ANY_CLUSTER_VM_IP]:[PORT]- it is accessible even though random pods carrying it are constantly killed at random, unless you have more vms in your cluster than deployed nginx instances and choose IP of one not carrying it.
How to test the central logging features
Prerequisites: LambdaStack cluster on Azure with at least a single VM with elasticsearch, kibana and filebeat roles enabled.
- 
Connect to kubectl using kubectl proxy or directly from Kubernetes master server 
- 
Apply from LambdaStack repository extras/kubernetes/pod-counterpod-counter.yamlwith command:kubectl apply -f yourpath_to_pod_counter/pod-counter.yamlPaths are system dependend so please be aware of applying correct separator for your operatins system. 
- 
In the inventory file find the IP adress of the node of the machine that has kibana installed and head over to http://NODE_IP:5601- you might have to head over to Portal Azure and allow traffic to that port in the firewall.
- 
You can right now search for data from logs in Discover section in Kibana after creating filebeat-* index pattern. To create index pattern click Discover, then in Step 1: Define index pattern as filebeat-*. Then click Next step. In Step 2: Configure settings click Create index pattern. Right now you can go to Discover section and look at output from your logs. 
- 
You can verify if CounterPod is sending messages correctly and filebeat is gathering them correctly querying for CounterPodin search field in Discover section.
- 
For more informations refer to documentation: https://www.elastic.co/guide/en/kibana/current/index.html 
How to tunnel Kubernetes Dashboard from remote kubectl to your PC
- 
SSH into server, and forward port 8001 to your machine ssh -i ls_keys/id_rsa operations@40.67.255.155 -L 8001:localhost:8001NOTE: substitute IP with your cluster master's IP.
- 
On remote host: get admin token bearer: kubectl describe secret $(kubectl get secrets --namespace=kube-system | grep admin-user | awk '{print $1}') --namespace=kube-system | grep -E '^token' | awk '{print $2}' | head -1NOTE: save this token for next points.
- 
On remote host, open proxy to the dashboard kubectl proxy
- 
Now on your local machine navigate to http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/
- 
When prompted to put in credentials, use admin token from the previous point. 
How to run Keycloak on Kubernetes
- Enable Kubernetes master & node, repository and postgresql components in initial configuration manifest (yaml) by encreasing countvalue.
kind: lambdastack-cluster
title: LambdaStack Cluster Config
provider: azure
name: default
build_path: '' # Dynamically built
specification:
 components:
    repository:
      count: 1
    kubernetes_master:
      count: 1
    kubernetes_node:
      count: 2
    postgresql:
      count: 2
- Enable applicationsin feature-mapping in initial configuration manifest.
---
kind: configuration/feature-mapping
title: Feature mapping to roles
name: default
specification:
  available_roles:
  - _merge: true
  - name: applications
    enabled: true
- Enable required applications by setting enabled: trueand adjust other parameters inconfiguration/applicationskind.
The default applications configuration available here
Note: To get working with Pgbouncer, Keycloak requires Pgbouncer configuration parametr POOL_MODE set to session, see Installing Pgbouncer and Pgpool section. The reason is that Keycloak uses SET SQL statements. For details see SQL feature map for pooling modes.
---
kind: configuration/applications
title: Kubernetes Applications Config
name: default
specification:
  applications:
  - _merge: true
  - name: auth-service
    enabled: true
    image_path: lambdastack/keycloak:14.0.0
    use_local_image_registry: true
    service:
      name: as-testauthdb
      port: 30104
      replicas: 2
      namespace: namespace-for-auth
      admin_user: auth-service-username
      admin_password: PASSWORD_TO_CHANGE
    database:
      name: auth-database-name
      user: auth-db-user
      password: PASSWORD_TO_CHANGE
To set specific database host IP address for Keyclock you have to provide additional parameter address:
    database:
      address: 10.0.0.2
Note: If database address is not specified, lambdastack assumes that database instance doesn't exist and will create it.
By default, if database address is not specified and if Postgres is HA mode, Keycloak uses PGBouncer ClusterIP service name as database address.
If Postgres is in standalone mode, and database address is not specified, then it uses first Postgres host address from inventory.
- 
Run lambdastack applyon your configuration manifest.
- 
Log into GUI 
Note: Accessing the Keycloak GUI depends on your configuration.
By default, LambdaStack provides the following K8s Services for Keycloak: Headless and NodePort.
The simplest way for reaching GUI is to use ssh tunnel with forwarding NodePort.
Example:
ssh -L 30104:localhost:30104 user@target_host -i ssh_key
If you need your GUI accesible outside, you would have to change your firewall rules.
GUI should be reachable at: https://localhost:30104/auth
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.