#kubernetes (2019-06)
Archive: https://archive.sweetops.com/kubernetes/
2019-06-03
2019-06-04
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
Intresting tool that checks K8s best practices https://github.com/reactiveops/polaris
Validation of best practices in your Kubernetes clusters - reactiveops/polaris
data:image/s3,"s3://crabby-images/01210/012102949171c6b302f3222b8a94f55ff5b4d8d3" alt="hlesta avatar"
Thanks
Validation of best practices in your Kubernetes clusters - reactiveops/polaris
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
It’s pretty nice .. for now it points out things like if you have set resource limits and it’s pretty basic, but I think this can be useful the more they add to it.
2019-06-05
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
what are you guy’s strategy for memory requests? for example looking at my historical data, my api pods use about 700Mi memory on average. I believe it’s better to set that memory request down to around that number, which will allow for more excess memory in the pool. I have it currently overallocated (1000Mi per api pod) and it adds up how much memory is being reserved but unusable by others that may need it.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Other considerations to take into account is (a) how much memory volatility there is… perhaps 30% variance is a bit high (b) disruptions - how bad is it if the service is evicted to another node?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I would suspect the more pods of a given service you run, the more insulated you are from disruptions of pod evictions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
which means you can get by with a a 5-10% limit. make sure you monitor pod restarts.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so long as that number stays at or near 0, you’re good.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
how are you all connecting kubectl into the k8s cluster these days?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
via teleport
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
teleport supports both ssh and kubectl
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
SAML authentication
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what they call proxy is ~ a bastion, for a centralized entry point
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Make it easy for users to securely access infrastructure, while meeting the toughest compliance requirements.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Interesting ty
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
thanks @Erik Osterman (Cloud Posse) i think i can get away with closer to 5-10%. dont have that much memory volatility looking at my metrics
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
hi
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
Alex Co, [Jun 6, 2019 at 143 PM]: i’m having an issue while looping the helm template
env: {{- range .Values.app.configParams }} - name: {{ . | title }} valueFrom: secretKeyRef: name: “{{ .Values.app.secretName }}” key: {{ . | title }} {{- end }}
this is my code in the template to generate the environment var from the values.yaml
but when i ran the helm lint, it complaints like this
executing “uiza-api-v4/templates/deployment.yaml” at <.Values.app.secretName>: can’t evaluate field Values in type interface {}
i guess that helm template does not allow me to put the secretName value inside a loop
is there anyway to solve this ?
2019-06-06
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
nvm, it’s because i did not declare .Values.app.secretName
as global variable
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
I encountered an issue with eks ebs volume provisioning, with small worker groups (less than 3) the pv was created before the pod and in the wrong AZ.
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
is settting volumeBindingMode: WaitForFirstConsumer
enough on v1.12 to fix this problem?
data:image/s3,"s3://crabby-images/73029/73029a7e61c7e3bfc1ff4f8b1d44aa03b9f79940" alt="Pablo Costa avatar"
Yes @nutellinoit It works. But I would also suggest to set an affinity policy for one AZ only, to ensure in case of pod restart or eviction, the pod be scheduled on the same AZ of the PVC
2019-06-07
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Hi People , do you know of a best/sane way to install k8s on AWS. I see that there are multiple ways to do it. I am eyeing kops because terraform duh but before creating the cluster there’s still a lot of preparation to do like:
- creating vpc
- kops state bucket
- route53 record And than all of it has to be passed on to kops as a cli command. This is all fine but to me it looks like a bit too much. Is there any other way of doing it ?
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
I use EKS
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
with terraform
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
ok that’s a way
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
and how do you handle upgrades, i read somewhere that it’s a bit tricky with EKS
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
You mean master version upgrade ?
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
like k8s 1.2 -> 1.3 upgrade
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
Yeah, well its a pretty new cluster
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
right now my cluster is running on version 1.2
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
what are the challenges that you have heard of ?
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I don’t remember the details but I think Erik mentioned something about the upgrade in EKS is not as easy
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I might be wrong though
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
data:image/s3,"s3://crabby-images/79b50/79b500061c23fc95a2f581f07bdc06385328aeaf" alt="attachment image"
Kubernetes is rapidly evolving, with frequent feature releases, functionality updates, and bug fixes. Additionally, AWS periodically changes the way it configures Amazon Elastic Container Service for Kubernetes (Amazon EKS) to improve performance, support bug fixes, and enable new functionality. Previously, moving to a new Kubernetes version required you to re-create your cluster and migrate your […]
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
aws blog says its easy
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
:)))
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
fair enough
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
offcourse we have multiple environments
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
so we can upgrade the lower environment and check if it works
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
and proceed with upgrade
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
niice
data:image/s3,"s3://crabby-images/dc995/dc9953c18a05aabfac39bcf27ac7d61bef5390c6" alt="Tim Malone avatar"
they made it much easier recently - you can do it via the AWS console, just change the version
data:image/s3,"s3://crabby-images/dc995/dc9953c18a05aabfac39bcf27ac7d61bef5390c6" alt="Tim Malone avatar"
then upgrade your worker nodes afterwards
data:image/s3,"s3://crabby-images/dc995/dc9953c18a05aabfac39bcf27ac7d61bef5390c6" alt="Tim Malone avatar"
(but yes you’ll want to do it in non-prod first just in case)
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
Terraform has a parameter for version
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
oh that sounds promising
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
version – (Optional) Desired Kubernetes master version. If you do not specify a value, the latest available version at resource creation is used and no upgrades will occur except those automatically triggered by EKS. The value must be configured and increased to upgrade the version when desired. Downgrades are not supported by EKS.
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
and what about installing it, EKS gives you the master nodes only, what about getting the other nodes in EC2, is it just a matter of using cloud-init ?
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
We do with with auto-scaling-group
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
You can follow this
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
data:image/s3,"s3://crabby-images/5030b/5030b45ac095466406d1d3401f04a408e6c70923" alt="attachment image"
A Terraform configuration based introduction to EKS.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Thanks a lot people
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I will try it out
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
i tried an upgrade with eks and terraform
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
from 1.11 to 1.12
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
is pretty smooth
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
control plane upgrades without downtime
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
to upgrade the workers the only thing to do is to update amis
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
and replace workers
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
and follow the directions on aws documentation to patch system deployment with new container versions
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
When a new Kubernetes version is available in Amazon EKS, you can update your cluster to the latest version. New Kubernetes versions introduce significant changes, so we recommend that you test the behavior of your applications against a new Kubernetes version before performing the update on your production clusters. You can achieve this by building a continuous integration workflow to test your application behavior end-to-end before moving to a new Kubernetes version.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
ok, so I guess there’s a posibility to automate replacing the instances in the AS somehow
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I will look into it
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Thanks for your support people!
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
You can simply terminate one old instance at time and wait for autoscaling group to launch replacements
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
arhg ye gute ole click-ops
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
we’ve developed a lambda with step functions that does the instance replacement, step functions serving as a waiter
data:image/s3,"s3://crabby-images/a9fa6/a9fa6c642c2cffbe20ec9a71522b08dac940c5da" alt="party_parrot"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
so it’s fire and forget
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
takes a while but it’s atomic
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
@Nikola Velkovski I’ve found the k8s upgrades to be a bit slow. it increases in time (by like 5~7 minutes per worker node) so upgrades can take a long time. For me, I wouldn’t be comfortable letting the upgrade for a production cluster run unattended (i.e. overnight while im sleeping) and naturally your production cluster probably has the most worker nodes. What I’ve found works for me pretty well is just using terraform to spin up a new cluster, deploy to the new cluster, and doing the cutover at the DNS level. food for thought
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think an elegant approach is to spin up an additional node pool
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-06-08
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
that sounds a lot like aws Elasticsearch @btai terraform apply usually times out when upgrading the ES cluster
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
thanks!
2019-06-09
data:image/s3,"s3://crabby-images/22e26/22e26dc8f62c4ec5ff1c87906cd738a1c2ae7d5b" alt="rj avatar"
@Nikola Velkovski give a try with rancher. It is the most easiest way to spin up k8s on multiple clouds as per our experience with the tool. https://rancher.com/
data:image/s3,"s3://crabby-images/bc306/bc3066642bbae14597353193ab733bb14a983b52" alt="attachment image"
Rancher, open source multi cluster management platform, makes it easy for operations teams to deploy, manage and secure Kubernetes everywhere. Request a demo!
2019-06-10
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
2019-06-11
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
Hey Guys Does anyone configured SMTP as a grafana config-map for kubernetes?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Don’t have first hand experience
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Let me know if you get it working though. We should setup the same in our helmfile.
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
Sure Erik
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
apiVersion: v1 kind: ConfigMap metadata: labels: app: grafana name: grafana-smtp-config-map namespace: monitoring data: grafana.ini: | enabled =true host=<host> user=<user> password=<password> skip_verify= false from_address=<email> from_name=Grafana welcome_email_on_sign_up=false
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
Ex: something like this
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
and adding this config map in kubernetes grafana deployment - configMap: defaultMode: 420 name: grafana-smtp-config-map name: grafana-smtp-config-map
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
i am trying using above methods to add smtp to grafana.ini
data:image/s3,"s3://crabby-images/63772/63772bd42802d90a514e678530b21a58e7625eb5" alt="Sandeep Kumar avatar"
but i am unable to add smtp to grafana.ini, is there any documentation/suggestions which can help me here?
data:image/s3,"s3://crabby-images/2dd60/2dd604fa6fff150f1b0f4c0d148234610a67081b" alt="timduhenchanter avatar"
Does anyone have any experience scaling with custom metrics from Datadog across namespaces (or the external metrics API in general)?
data:image/s3,"s3://crabby-images/2dd60/2dd604fa6fff150f1b0f4c0d148234610a67081b" alt="timduhenchanter avatar"
apiVersion: autoscaling/v2beta1
kind: HorizontalPodAutoscaler
metadata:
name: service-template
spec:
minReplicas: 1
maxReplicas: 3
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: service-template
metrics:
- type: External
external:
metricName: k8s.kong.default_service_template_80.request.count
metricSelector:
matchLabels:
app: kong
targetAverageValue: 5
data:image/s3,"s3://crabby-images/2dd60/2dd604fa6fff150f1b0f4c0d148234610a67081b" alt="timduhenchanter avatar"
Warning FailedGetExternalMetric 117s (x40 over 11m) horizontal-pod-autoscaler unable to get external metric default/k8s.kong.default_service_template_80.request.count/&LabelSelector{MatchLabels:map[string]string{app: service-template,},MatchExpressions:[],}: no metrics returned from external metrics API
data:image/s3,"s3://crabby-images/2dd60/2dd604fa6fff150f1b0f4c0d148234610a67081b" alt="timduhenchanter avatar"
^ perm issue with Datadog API in the cluster-agent
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
hi, anyone here is using Gloo Gateway on K8s ?
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
i’m having a problem that the virtual service stopped accepting traffic after awhile, and status on the ELB to gloo gateway proxy show that it ’s OutOfService
data:image/s3,"s3://crabby-images/908a7/908a7fb9c77ede12f3d96c3494d3de7ed5fa9dfa" alt="Alex Co avatar"
wonder if anyone here got the same problem
2019-06-12
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi all! Has someone faced this error before?
kernel:[22989972.720097] unregister_netdevice: waiting for eth0 to become free. Usage count = 1
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Public #office-hours starting now! Join us on Zoom if you have any questions. https://zoom.us/j/684901853
2019-06-13
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
what ingress controller are you guys using? it seems like alb-ingress-controller isnt quite robust enough for me. things that i feel like its missing:
- new ingress object = new ALB so there would be a one-to-one mapping of ALBs to services for me (multi-tenant cluster)
- provisioned resources don’t get cleaned up, at this point i feel like i might want to terraform the load balancer resources i need with the cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, the 1:1 mapping between ingress an ALB sucks!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Im using Ambassador.. a lot of features regarding routing of traffic based on any kind headers, regex matching, Jaeger tracing. Name it :)
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
@maarten does ambassador spin up cloud resources for u? (load balancers, security groups, etc)
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
i realized that might not be a feature i want as of now in k8s. since terraform is better at managing cloud resource state
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Can someone point me to best practices for setting up Traefik/Nginx-Proxy/etc as an ingress for Kubernetes running on 80? Everything is running but ClusterIP is internal and NodePort doesn’t allow ports below 30000. What am I missing?
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Service of type Loadbalancer. Then cloud provider gives you IP or use something like metallb on bare metal. Deployment nginx ingress or whatever. Can replicate per AZ.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
I was really excited about this post https://medium.com/localz-engineering/kubernetes-traefik-locally-with-a-wildcard-certificate-e15219e5255d
data:image/s3,"s3://crabby-images/2beda/2beda88bd9612903df6ff3538c8cdfc822cf918e" alt="attachment image"
As a passionate software engineer at Localz, I get to tinker with fancy new tools (in my own time) and then annoy my coworkers by…
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
but he’s using a LoadBalancer
w/ Docker for Mac Kubernetes which doesn’t make sense.
2019-06-16
2019-06-17
2019-06-18
data:image/s3,"s3://crabby-images/241b8/241b8520f51ffc83b21718b4544f644baba89fa8" alt="Hugo Lesta avatar"
Hello @davidvasandani thanks for the article that you’ve written. Could you please tell me the main capabilities that trafeik have as ingress-controller? Do you have any article with this capabilities?
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Hi @Hugo Lesta. Not my article but Traefik has many capabilities. https://docs.traefik.io/configuration/backends/kubernetes/
data:image/s3,"s3://crabby-images/241b8/241b8520f51ffc83b21718b4544f644baba89fa8" alt="Hugo Lesta avatar"
This previous article you sent me seems worthy for me, I’ll try to improve my knowledhe about traefik over k8s.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Its good and helped me out but its incomplete. The author mentions using LoadBalancer locally but doesn’t describe how. With a lot of additional work I’ve gotten it working with MetalLB locally. This was a very useful article: https://medium.com/@JockDaRock/kubernetes-metal-lb-for-docker-for-mac-windows-in-10-minutes-23e22f54d1c8
2019-06-19
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
anyone using this on their clusters? https://github.com/buzzfeed/sso
sso, aka S.S.Octopus, aka octoboi, is a single sign-on solution for securing internal services - buzzfeed/sso
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Looks interesting
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Doesn’t support websockets, so it was a deal breaker for us
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
things like the k8s dashboard or grafana require that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
bite the bullet. just deploy KeyCloak with Gatekeepers
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
havent heard of keycloak/gatekeeper
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I can give you a demo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it’s open source, by redhat
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have the helmfiles for it too
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
does it integrate w/google saml?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yup, that’s the beauty with keycloak
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it basically supports every saml provider
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
yeah it looks like
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and we use it with gsuite
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not only that, you an use it with https://github.com/mulesoft-labs/aws-keycloak
aws-vault like tool for Keycloak authentication. Contribute to mulesoft-labs/aws-keycloak development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
with aws
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it can become the central auth service for everything
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
nice
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use it with kubernetes, teleport, atlantis, grafana, etc
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
yeah super nice, fully integrated
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you can even integrate it with multiple auth providers at the same time
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
do helmfiles have a remote “helm chart” that is used as the base?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not sure, better to check in #helmfile
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
ah yeah it does
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
Comprehensive Distribution of Helmfiles. Works with helmfile.d
- cloudposse/helmfiles
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, “base” is a loaded term now
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
since helmfile
has the concept of bases
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is not a base in that sense
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
like uh
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
base docker image base
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
aha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, we use the community image
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but guess it would be more secure to run our own
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
given the role this plays
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
i guess im not being clear enough
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
i was curious if the helm chart is just abstracted out
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
for a helmfile
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for the gatekeeper, we’re doing something a bit unusual/clever
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we are defining an environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then using that to generate a release for each service in the environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the alternative is to use sidecars or automatic sidecar injetion
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A Kubernetes controller to inject an authentication proxy container to relevant pods - [✩Star] if you’re using it! - stakater/ProxyInjector
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
ah
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here’s what our environments file looks like
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
services:
- name: dashboard
portalName: "Kubernetes Dashboard - Staging"
host: dashboard.xx-xxxxx-2.staging.xxxxxx.io
useTLS: true
skipUpstreamTlsVerify: true
upstream: <https://kubernetes-dashboard.kube-system.svc.cluster.local>
rules:
- "uri=/*|roles=kube-admin,dashboard|require-any-role=true"
debug: false
replicas: 1
- name: forecastle
host: portal.xx-xxxx-2.xxxx.xxxx.io
useTLS: true
upstream: <http://forecastle.kube-system.svc.cluster.local>
rules:
- "uri=/*|roles=kube-admin,user,portal|require-any-role=true"
...
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
i see
2019-06-20
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Have you people seen this ? https://github.com/hjacobs/kubernetes-failure-stories
Compilation of public failure/horror stories related to Kubernetes - hjacobs/kubernetes-failure-stories
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it’s worth resharing
Compilation of public failure/horror stories related to Kubernetes - hjacobs/kubernetes-failure-stories
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I got to the spotify video, which is kinda cool, they admit their rookie mistakes around terraform
data:image/s3,"s3://crabby-images/ba9eb/ba9eb4caca5dd31c6b236ac2dc26b9a0c73bccd1" alt="Ribhararnus Pracutiar avatar"
Hi guys, how to connect vpn from inside pods? any recommendation out there? So basically, I have to connect client data on premise, only using 1 ip
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
is anyone here using aws-okta with EKS? I’m having trouble granting additional roles access to the cluster.
2019-06-23
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Hey @cabrinha I’d be interested in hearing anything you ran into with aws-okta and EKS. I’m going to be starting down that road this week.
2019-06-24
data:image/s3,"s3://crabby-images/b243a/b243a50328c5f70eecf85c0f14dac3ffa5531f6a" alt="Ayo Bami avatar"
HI guys, Please could someone help me . I just created an EKS cluster and its unable to apply some changes to the cluster. I keep getting that error log.. I am using the same user I used to create the cluster. I am also using auth account. So the Users are not exactly in that account they assume role. Am not sure what am missing here being trying this for days now.. Thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
How did you bring up the cluster? Are you using terraform?
data:image/s3,"s3://crabby-images/b243a/b243a50328c5f70eecf85c0f14dac3ffa5531f6a" alt="Ayo Bami avatar"
@Erik Osterman (Cloud Posse) with terraform
data:image/s3,"s3://crabby-images/b243a/b243a50328c5f70eecf85c0f14dac3ffa5531f6a" alt="Ayo Bami avatar"
Terraform module which creates EKS resources on AWS - howdio/terraform-aws-eks
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
The aws-auth ConfigMap is applied as part of the guide which provides a complete end-to-end walkthrough from creating an Amazon EKS cluster to deploying a sample Kubernetes application. It is initially created to allow your worker nodes to join your cluster, but you also use this ConfigMap to add RBAC access to IAM users and roles. If you have not launched worker nodes and applied the
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
point 3
data:image/s3,"s3://crabby-images/b243a/b243a50328c5f70eecf85c0f14dac3ffa5531f6a" alt="Ayo Bami avatar"
@nutellinoit Its a new cluster. If my user can’t access the cluster, not sure if it can run aws-auth on the cluster if it can’t access it
data:image/s3,"s3://crabby-images/b243a/b243a50328c5f70eecf85c0f14dac3ffa5531f6a" alt="Ayo Bami avatar"
We use Auth to manage IAM, The accounts are not directly in the cluster.
2019-06-25
2019-06-28
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Kubernetes community content. Contribute to kubernetes/community development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-06-30
data:image/s3,"s3://crabby-images/f2c45/f2c4512cb3a397ecdacf7b22486d9b535ffd1f5c" alt="abkshaw avatar"
I am stuck while installing Kubeadm in AWS on Amazon linux
Below is the error i get after running sudo install -y kubeadm
http://yum.kubernetes.io/repos/kubernetes-el7-x86_64/repodata/repomd.xml: [Errno -1] repomd.xml signature could not be verified for kubernetes
Please help me to get over it.
data:image/s3,"s3://crabby-images/da9a5/da9a569dbcc70a374dc9c95951279b0d26ee4ffd" alt="Glenn J. Mason avatar"
Hey @abkshaw, sounds a little similar to https://github.com/kubernetes/kubernetes/issues/60134
Is this a BUG REPORT or FEATURE REQUEST?: /kind bug What happened: I'm trying to install Kubernetes on Amazon Linux 2 as described here, but I get error: [[email protected] ~]$ sudo yum install …
data:image/s3,"s3://crabby-images/f2c45/f2c4512cb3a397ecdacf7b22486d9b535ffd1f5c" alt="abkshaw avatar"