#kubernetes (2020-04)
Archive: https://archive.sweetops.com/kubernetes/
2020-04-01
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
Anyone found a more automated way to roll k8s nodes thru replacement with terraform other than spinning up another asg and cordon/drain thru the old nodes before running tf again to remove them?
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
That video represents a what a deployment pipeline looks like that pushes a whole kubernetes cluster out then installs airflow on it to then push pipelines that run data science jobs to the same cluster.
data:image/s3,"s3://crabby-images/2b794/2b794cbcc9a0fa2e9b443ded32f8f3609a846e7e" alt="wannafly37 avatar"
This..is..amazing.
2020-04-02
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Short script to get the latest version of minikube running on ubuntu 19.10: https://gist.github.com/zloeber/528bcce2e4b45465c940a08f10551ccb
2020-04-03
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
FleetOps -> https://thenextweb.com/growth-quarters/2020/04/03/devops-isnt-enough-your-team-needs-to-embrace-fleetops/ (pretty much another way of saying you should treat everything as if it were part of a PaaS I think).
data:image/s3,"s3://crabby-images/2d063/2d063a95f1cff837bad5f055a2ba9ce41e420c5b" alt="attachment image"
FleetOps is needed to run a fleet of hundreds (or thousands!) of websites and applications securely across your organization.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
and to follow that up, this nifty looking project from Rancher developed by a dude I follow on twitter: https://rancher.com/blog/2020/fleet-management-kubernetes/
data:image/s3,"s3://crabby-images/30d23/30d235a33be11d72fe165c1c396a976cc3677ea3" alt="attachment image"
Fleet is new open source project from the team at Rancher focused on managing fleets of Kubernetes clusters. Ever since Rancher 1.0, Rancher has provided a central control plane for managing multiple clusters. As pioneers of Kubernetes multi-cluster management, we have seen firsthand how users have consistently increased the number of clusters under management. We are already seeing interest from users who want to manage tens of thousands or even millions of clusters in the near future.
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
darn. I had at one point tried to build an internal cluster management tool and wanted to call it fleet. Because it was essentially managing a fleet of kube clusters (and keeping with the ocean/ship theme) never got around to buildint it out completely
data:image/s3,"s3://crabby-images/30d23/30d235a33be11d72fe165c1c396a976cc3677ea3" alt="attachment image"
Fleet is new open source project from the team at Rancher focused on managing fleets of Kubernetes clusters. Ever since Rancher 1.0, Rancher has provided a central control plane for managing multiple clusters. As pioneers of Kubernetes multi-cluster management, we have seen firsthand how users have consistently increased the number of clusters under management. We are already seeing interest from users who want to manage tens of thousands or even millions of clusters in the near future.
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
my proof
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
figures right? well fleet looks open source maybe you can use it anyway
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
what module do you use for Go log output anyway?
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
@Zachary Loeber i used https://github.com/sirupsen/logrus but i havent been doing a ton of Go development in the last few years so I’m prob not the best person to ask
Structured, pluggable logging for Go. Contribute to sirupsen/logrus development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Hi all, weird question for ya
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
EKS 1.14. 1 cluster. 2 namespaces. Opened up SG (for debugging). amazon-k8s-cni:v1.5.7
Deployed svc + deployment in both namespaces. I have a pod from both namespaces on the same ec2 instance. I have a VPN giving me access to the cluster.
I can curl 1 pod in 1 namespace. I can not curl the other pod in the other namespace. All the k8s specs for svc + deployment are the same. They’re both using secondary IPs.
I realize this is hyper specific, but just curious if this sounds familiar to anyone
(I’ve tried to isolate it down to just 2 identical pods in different namespaces)
Guessing it’s related to some hardcore networking issue in the CNI.. I’m able to hit the pods from within the same VPC with the same CIDR block without issue.. but when I leave the CIDR block, it causes trouble
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’ve encountered something that sounds similar when the subnets aren’t correctly configured with route tables or the wrong subnets are passed to EKS. In this case, pod(1) is on node A, pod (2) is on node B; node A and node B are on different subnets.
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
do you have network policies? that could be different for both namespaces?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Erik: same node, same subnet
Btai: no NACLs in AWS. But I’m guessing you’re referring to k8s network policies.. uhhh no clue, but I’ll look for it
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I want to try and look at CNI/SNAT failures or something.. but I trying to field for suggestions first before going down that rabbit hole
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
no network policies in k8s
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Unless you are doing unconventional things, I would look for more obvious, user error type problems. Just based on my own experiences, I am usually at fault 99% of the time.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
i agree. In this case.. I think i got wrapped around the axel in playing with Service Endpoints.. opposed to the service itself
I was hitting the endpoint defined here..
kubectl -n dev-1 describe svc my-svc-name | grep -i endpoints:
Instead of just making the service fully available where I need it
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
the technical issue still stands, but the need to solve it diminished.. since I’m just going to hit the service (as I should have all along)
2020-04-04
2020-04-05
2020-04-06
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
What happens when I type kubectl run? Contribute to jamiehannaford/what-happens-when-k8s development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
2020-04-07
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
AWS EKS -> ALB Target Group with CNI question…
So on EKS, we have CNI enabled so each pod has an IP address ni the VPC Subnet. We have an ALB going directly to the Pods’ IP addresses. So if we have 50 pods, there are 50 entries in the target group.
Question: Has anyone spent time fine tuning Deregistration Delay in coordination with aws-alb-ingress-controller (for large deployments; many pods)?
EDIT1:
!!!example - set the slow start duration to 5 seconds alb.ingress.kubernetes.io/target-group-attributes: slow_start.duration_seconds=5 - set the deregistration delay to 30 seconds alb.ingress.kubernetes.io/target-group-attributes: deregistration_delay.timeout_seconds=30
Hmm, this is suggesting 30s, but dunno if it’s battle tested
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Depends wildly on your app. What’s the terminationGracePeriodSeconds
set for that app? Think of it like this: pod is alive and ready and serving requests. Pod gets notified to stop work. How long does it serve requests? What happens to in-flight requests? How does that affect the app?
For starting time, it’s the same problem in reverse. How deep are your aliveness and more importantly your readiness checks? How do you know a pod is ready to serve requests? Does it serve requests in the first 10 minutes with super-high latency cause it’s still populating some caches?
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
More importantly, do your pods get replaced often? If not, you may not even need to stress about this
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
They get replaced a few times day (multiple deployments a day). There’s 100+ pods in the deployment.
terminationGracePeriodSeconds: 30
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
i guess i need to do my homework more on when the deregistration delay timer begins
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Yeah, sounds like you do need to worry about it
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
When a pod has to be replaced, the following flow happens:
• SIGTERM is sent to the pod. Apps should get that as “dude, I got a notice to stop work graciously so I will start doing that”. Finish in progress-work, try to clean up nicely, and so on. At this time the ALBs should be set so no new connections are sent to these podsw
• we wait for terminationGracePeriodSeconds
• SIGKILL is sent to the pod which kills all the containers inside by force
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Meanwhile, ALB Ingress Controller runs a loop every say 10s and checks for any new pods or any new LB changes and updates the ALBs accordingly
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
All of these have to make out and kiss in sync
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
It helps a lot to draw this out and mock scenarios
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
re: make out and kiss in sync
https://67.media.tumblr.com/668927139d282654dee7df5b1f715f93/tumblr_inline_o21a2aH9He1szrmgb_500.gif
data:image/s3,"s3://crabby-images/c4a5c/c4a5cfc788bc0cbd71e8e8156e61d68337c5cdb9" alt="attachment image"
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I’m on the same page with you with your analysis so far. The dark spot in my mind is how Deregistration Delay works after a pod is marked as terminating
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
(proc is killed by itself naturally by SIGTERM or forced by SIGKILL)
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html helps
Learn how to configure target groups for your Application Load Balancer.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
actually, I think the TG stops routing to a terminating/deregistering instance
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
but the deregistration delay keeps the current connections alive for up to XXseconds
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
If that’s the case, no big deal
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I think the most important thing is aws-alb-ingress-controller to update ASAP once a pod is marked as terminatng
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
so it can be marked as deregistering in the TG
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
When a pod is marked as Terminating, we’re in between that SIGTERM and SIGKILL limbo. We still have connections from client-ALB-pod.
Now, after Deregistration Delay the ALB forcefully kills all connections from the client to the pod.
That’s helpful if say your app cannot die gracefully if there are still active connections
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Or at least that’s how I understand it based on the above link
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
yeah
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
makes sense
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
terminating grace period length > deregistration delay length
Since there’s a lag waiting for AWS alb ingress controller to tell the TG that a target is deregistering
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
I think that is correct, yup.
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Also, don’t forget about the ALB Ingress Controller loop.
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
That happens every 10s I think. And if it ran just before your pod switched to Terminating…
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Again, drawing and testing all the situations( or the most important ones) helps a lot
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
yeah, I agree
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
➜ ~ kubectl get nodes | grep fargate
Interesting seeing Fargate EKS assigning ec2 instances?
fargate-ip-xxx-xxx-xxx-xxx.ec2.internal
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
I just assume that everything runs on ec2 instances
2020-04-08
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
What happened: kubectl diff modify my deployements. What you expected to happen: I expect the diff command to not change my deployments ! How to reproduce it (as minimally and precisely as possible…
2020-04-09
data:image/s3,"s3://crabby-images/5cadc/5cadc6bb730c85ab6ba16def493c7f1c82ab6445" alt="David Hubbell avatar"
Any opinions on kube-aws vs kops?
data:image/s3,"s3://crabby-images/5cadc/5cadc6bb730c85ab6ba16def493c7f1c82ab6445" alt="David Hubbell avatar"
(for provisioning in AWS)
data:image/s3,"s3://crabby-images/5cadc/5cadc6bb730c85ab6ba16def493c7f1c82ab6445" alt="David Hubbell avatar"
I created a cluster with kube-aws yesterday and it wasn’t too bad. Now getting recommendations to use kops from someone that used it 2 years ago
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I used kops like 2 years ago as well, it seemed ok but if you are going to deploy managed clusters and still use cli scripts to do so eksctl seems the way to go.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I question the longevity of a solution based on such scripts though.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
though kops can generate terraform configurations, cool beans - https://github.com/kubernetes/kops/blob/master/docs/terraform.md
Kubernetes Operations (kops) - Production Grade K8s Installation, Upgrades, and Management - kubernetes/kops
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I believe the time for kops
on AWS has come and gone. It’s moving slower and alternatives have caught up. Now with AWS supporting fully managed node pools, EKS is the way to go.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’ve switched over to deploying EKS for all new engagements.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Up until the managed node groups, I was on the fence as to the right way to go.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I’m curious if there are any workloads which you might recommend self-managed clusters for at this point?
data:image/s3,"s3://crabby-images/5cadc/5cadc6bb730c85ab6ba16def493c7f1c82ab6445" alt="David Hubbell avatar"
EKS is not FedRamp compliant (yet) and so the recommendation (from AWS) is to run K8s manually on EC2 until compliance is reached. As a result, eksctl is out as an option
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Also my Issue with EKS is that they lag super behind the k8s release cycle
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(so has kops
historically)
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Oh okay did not know. I am new to aws after all and never had to deal with unmanaged clusters
data:image/s3,"s3://crabby-images/4e974/4e974d93068ee751b98baad672079bb85f381e86" alt="Juan Soto avatar"
which version of k8s is running eks ?
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
1.15
data:image/s3,"s3://crabby-images/4e974/4e974d93068ee751b98baad672079bb85f381e86" alt="Juan Soto avatar"
ho that’s very old.
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Yep. It also only was just added in march
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
This is the issue regarding that: https://github.com/aws/containers-roadmap/issues/487
Tell us about your request Support for Kubernetes 1.16 Changelog Release Announcement Which service(s) is this request for? EKS Tell us about the problem you're trying to solve. What are you tr…
2020-04-10
2020-04-14
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Anyone have issues using
service.beta.kubernetes.io/aws-load-balancer-type: nlb
attached to their service.. for a bunch of services.. then all your security group rules get consumed on the EKS nodes SG?
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
no, but you’ve piqued my interest.
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
the SG rules for the NLB specifically are getting added to node-port-level? how were you specifying your SG rules for this NLB?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
service.beta.kubernetes.io/aws-load-balancer-type: nlb
service.beta.kubernetes.io/aws-load-balancer-backend-protocol: tcp
service.beta.kubernetes.io/aws-load-balancer-internal: true
service.beta.kubernetes.io/aws-load-balancer-security-groups: sg-00000000
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
these are the only annotations I use
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
i want to disable the sg rule addition somehow
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
this is what its doing to the SG for the EKS nodes
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
interesting. i had not stumbled upon this yet but i haven’t been using security groups on my (public) NLB. great to know though.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
these are private NLBs
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
hmm, i wonder if that makse a difference
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
All I can do is try
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
i suspect not. logically it makes sense to me though that if you’re applying a SG, it’s going to lock down the port on the node that’s frontending the service.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
here’s the problem tho, if you don’t specify an SG, it’ll grab one anyways
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
grab | create |
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Oh, the terminology is NodePort
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use the nlb
mode by default with that annotation. Haven’t been bothered by the rule additions. Why fight it?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
we maxed out on inbound security group rules
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
lol
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
only 60 rules per SG
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
each NLB’s nodeport is making 2 entries in there
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
https://github.com/kubernetes/kubernetes/pull/74692/files#diff-298a224837f7a3edc5b5f37ddb8fa47aR671
this looks kind of promising tho
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
app-1 LoadBalancer 172.20.179.5 00000000000000-00000000000000.elb.us-west-2.amazonaws.com 3000:32043/TCP 10d
SG rules get added for like.. port 32043
(even though I already have rules that don’t require this..)
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I guess the question is.. how can i stop these inbound rule additions on the SG used for the EKS nodes?
EDIT:
Solution.. just use classic LB
2020-04-16
data:image/s3,"s3://crabby-images/89018/89018ad8dde0ee3728e9eec41a81bc510865f9bb" alt="Marcin Brański avatar"
I’ve seen two ingresses using same DNS domain but different paths and different nginx-ingress
annotations.
Is that supported? Will one ingress be used or will somehow nginx-ingress
merge them?
I’m not sure how will nginx
resolve paths when they overlap, ex one ingress is using /v4
and second /v4/api_xxx
.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I don’t believe that will work. one of the two load-balancers that back the ingress would need to be hit first based on how DNS works (unless you have some upstream traffic routing mechanism)
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Anyone facing issue with Service name is not being picked up when deploying a helm chart on Kubernetes and service is getting created with random naming scheme??
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
what is random for you?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Here u go Pierre: https://github.com/helm/charts/issues/21973
charts/stable/grafana/values.yaml Line 115 in efd0f2c service: When using this Grafana Helm Cart for deploying into EKS Cluster, I did added a service name and somehow, then ma his not being picked…
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
This is what I am talking about
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
but it is indented for you ?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Yeah yea of course… Within my myvalues.yaml file its indented right
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
This is how the service name gets defined you need to set fullnameOverride
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Ok… SO the service name is defined with an override. In this case defining the “grafana.fullname” within service section should fix the issue…
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Am i saying it right?
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
no you can not set the service name on its own.
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
You can only override the name for all manifests
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
I am wondering why you would not just take the default?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Well, the reason why I dont want to take the defalut is, I am having an issue when I am setting the Ingress for the same (Grafana Service). I do see a name mismatch here cause I need to define the service name within the Ingress configuration before I deploy the service
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Why would you not enabled the ingress of the helm chart?
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
Curated applications for Kubernetes. Contribute to helm/charts development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
service:
name: svc-grafana
namespace: kube-system
type: ClusterIP
port: 80
targetPort: 3000
annotations: {}
labels: {}
portName: service
ingress: enabled: true annotations: kubernetes.io/ingress.class: alb alb.ingress.kubernetes.io/scheme: internet-facing alb.ingress.kubernetes.io/load-balancer-attributes: ‘routing.http2.enabled=true,idle_timeout.timeout_seconds=600,deletion_protection.enabled=true’ alb.ingress.kubernetes.io/certificate-arn: certname alb.ingress.kubernetes.io/listen-ports: ‘[{“HTTP”: 80}, {“HTTPS”:443}]’ alb.ingress.kubernetes.io/actions.ssl-redirect: ‘{“Type”: “redirect”, “RedirectConfig”: { “Protocol”: “HTTPS”, “Port”: “443”, “StatusCode”: “HTTP_301”}}’ name: grafana-ingress namespace: kube-system service: annotations: alb.ingress.kubernetes.io/target-type: ip labels: {} path: /* hosts: - grafana.company.com ## Extra paths to prepend to every host configuration. This is useful when working with annotation based services. extraPaths: - path: backend: serviceName: ssl-redirect servicePort: use-annotation - path: /* backend: serviceName: svc-grafana servicePort: 80
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
"service:
name: svc-grafana
namespace: kube-system
type: ClusterIP
port: 80
targetPort: 3000
annotations: {}
labels: {}
portName: service
ingress:
enabled: true
annotations:
[kubernetes.io/ingress.class](http://kubernetes.io/ingress.class): alb
[alb.ingress.kubernetes.io/scheme](http://alb.ingress.kubernetes.io/scheme): internet-facing
[alb.ingress.kubernetes.io/load-balancer-attributes](http://alb.ingress.kubernetes.io/load-balancer-attributes): 'routing.http2.enabled=true,idle_timeout.timeout_seconds=600,deletion_protection.enabled=true'
[alb.ingress.kubernetes.io/certificate-arn](http://alb.ingress.kubernetes.io/certificate-arn): certname
[alb.ingress.kubernetes.io/listen-ports](http://alb.ingress.kubernetes.io/listen-ports): '[{"HTTP": 80}, {"HTTPS":443}]'
[alb.ingress.kubernetes.io/actions.ssl-redirect](http://alb.ingress.kubernetes.io/actions.ssl-redirect): '{"Type": "redirect", "RedirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}'
name: grafana-ingress
namespace: kube-system
service:
annotations:
[alb.ingress.kubernetes.io/target-type](http://alb.ingress.kubernetes.io/target-type): ip
labels: {}
path: /*
hosts:
- [grafana.company.com](http://grafana.company.com)
## Extra paths to prepend to every host configuration. This is useful when working with annotation based services.
extraPaths:
- path:
backend:
serviceName: ssl-redirect
servicePort: use-annotation
- path: /*
backend:
serviceName: svc-grafana
servicePort: 80"
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
can you wrap that in
`
``
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
service:
name: svc-grafana
namespace: kube-system
type: ClusterIP
port: 80
targetPort: 3000
annotations: {}
labels: {}
portName: service
ingress:
enabled: true
annotations:
kubernetes.io/ingress.class: alb
alb.ingress.kubernetes.io/scheme: internet-facing
alb.ingress.kubernetes.io/load-balancer-attributes: 'routing.http2.enabled=true,idle_timeout.timeout_seconds=600,deletion_protection.enabled=true'
alb.ingress.kubernetes.io/certificate-arn: certname
alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]'
alb.ingress.kubernetes.io/actions.ssl-redirect: '{"Type": "redirect", "RedirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}'
name: grafana-ingress
namespace: kube-system
service:
annotations:
alb.ingress.kubernetes.io/target-type: ip
labels: {}
path: /*
hosts:
- grafana.company.com
## Extra paths to prepend to every host configuration. This is useful when working with annotation based services.
extraPaths:
- path:
backend:
serviceName: ssl-redirect
servicePort: use-annotation
- path: /*
backend:
serviceName: svc-grafana
servicePort: 80
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Sorry,, here u go
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
and where are you trying to reference the service name?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
If u look at the “name” under Service configuration and the “servicename” under Ingress configuration, the parameters are different and thats why I want to control the service name so that it can be set under the Ingress.
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I am trying to refer the servicename under:
service:
name: svc-grafana
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
you do not need to define the grafana path afaik
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
After I deploy the configuration, here is the error I am getting in the alb-ingress-configuration pod logs:
E0416 19:39:58.180001 1 controller.go:217] kubebuilder/controller "msg"="Reconciler error" "error"="failed to reconcile targetGroups due to failed to load serviceAnnotation due to no object matching key \"kube-system/svc-grafana\" in local store" "controller"="alb-ingress-controller" "request"={"Namespace":"kube-system","Name":"grafana-1587065956"}
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
You should be able to remove the grafana service declaration
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ho….
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
So, I am guessing to get rid of the whole section:
extraPaths:
- path:
backend:
serviceName: ssl-redirect
servicePort: use-annotation
- path: /*
backend:
serviceName: svc-grafana
servicePort: 80
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
no need for it then….
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
I am not sure why you have added it.
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
So it might be yes
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I was configuring it based on templates I got from github and AWS ALB Ingress sections, Pierre…
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Let me remove it and will see if it deploys
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
sure let me know. Happy to help.
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
This time, it throwed a new error:
I0416 20:00:22.317225 1 tags.go:43] kube-system/grafana-1587067180: modifying tags { ingress.k8s.aws/stack: "kube-system/grafana-1587067180", kubernetes.io/service-name: "grafana-1587067180", kubernetes.io/service-port: "80", ingress.k8s.aws/resource: "kube-system/grafana-1587067180-grafana-1587067180:80", kubernetes.io/cluster/cluster_name: "owned", kubernetes.io/namespace: "kube-system", kubernetes.io/ingress-name: "grafana-1587067180", ingress.k8s.aws/cluster: "cluster_name"} on arn:aws:elasticloadbalancing:AWSSetup
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ooh sorry, nevermind. Thats not an error. However, the original error still persists
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
hard to say / judge what might be going on ..
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
E0416 20:00:22.364011 1 controller.go:217] kubebuilder/controller "msg"="Reconciler error" "error"="failed to reconcile targetGroups due to failed to reconcile targetGroup targets due to grafana-1587067180 service is not of type NodePort or LoadBalancer and target-type is instance" "controller"="alb-ingress-controller" "request"={"Namespace":"kube-system","Name":"grafana-1587067180"}
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
sorry Pierre. the above one is the error I am getting
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I will dig in more…
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
The error says that you can not use server.type: ClusterIP
so if you would like to use a load balancer you have to change the type
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
So it might work if you set it to: LoadBalancer
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
But, without defining the ClusterIP, how does the service will be created with the proper setup for exterrnal or even internal accessing??
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
either way, let me try to change the server.type and will see what it does
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Actually, I am guessing I need to add this
service.loadBalancerIP IP address to assign to load balancer (if supported) nil
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
you can not create an ALB for a ClusterIP Service if you would like to use a Load Balancer you will need to switch the service type.
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ooh wow..
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ok ok
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
let me change the server type to loadbalancer and see what it does then
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Son a gun… It worked…
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Boy, u r amazing…!!!
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I truly apprecate your help here Pierre!!!!
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
no worries
2020-04-17
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
curious if anyone has taken a look at Keptn yet, https://keptn.sh/
data:image/s3,"s3://crabby-images/beeac/beeac3e83860704e20c8cdb2f88aa21409119284" alt="attachment image"
Building the fabric for cloud-native lifecycle automation at enterprise scale
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Tell us about your request I would like to be able to make changes to configuration values for things like kube-controller. This enables a greater customisation of the cluster to specific, bespoke …
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9ce69/9ce69ecb3e039a69edb26ecc51d40510388b0713" alt="David Scott avatar"
I found that all of my EKS clusters that were originally created on 1.11 are missing k get cm -n kube-system kube-proxy-config
. The configmap is present on clusters created on later versions. The EKS update instructions only patch the image version in kube-proxy. Has anyone else dealt with this? I’m digging into it because I want to edit the metricsBindAddress
to allow Prometheus to scrape kube-proxy
.
2020-04-19
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
I’m running into a bit of confusion. Does anything look glaringly out of place here?
For some reason, creating the internal NLB in AWS with the below yaml is using nodePort
s. Is this normal? Trying to make spinnaker accessible over transit gateway but having difficulty
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
you should be using an IP address within the kubernetes network range right?
2020-04-20
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Just pretty waves and a single link to a github project
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Hello,
I am facing a dilemma that I am sure other folks must have come across.
So we have an application team deploying their service to our shared EKS cluster. The application is exposed externally via a CLB (this will be revisited in a month or so to replace with an API gateway etc.). The challenge I am facing is that the DNS and the Cert that this service manifest refers must be created via TF. Looks like there’s no way to tell a K8s service to use a particular LB as it’s load balancer. We have to go the other way round. Create the LB and refer that in TF to find the DNS details. This fails too so far. I am using aws_lb as a datasource and trying to read the zone id of the LB created by the K8s service. How have others solved for this please ?
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Got totally sidetracked today and ended up creating this little project. Setting up a local lab environment in Linux for CKA studies using terraform and libvirt: https://github.com/zloeber/k8s-lab-terraform-libvirt. It is just a nifty way to spin up 3 local ubuntu servers using terraform but fun nonetheless (well fun for me at least…)
A Kubernetes lab environment using terraform and libvirt - zloeber/k8s-lab-terraform-libvirt
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
this is cool! Maybe also something for #community-projects
A Kubernetes lab environment using terraform and libvirt - zloeber/k8s-lab-terraform-libvirt
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
thanks Pierre, I was surprised at how well it works
2020-04-21
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Helm/Stable/Prometheus Server Dashboard is exposed using alb-ingress controller. Somehow the prometheus webpage is not loading fully (few parts of the webpage are not getting loaded and throwing 404 errors). Here is the Ingress configuration
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ingress:
## If true, Prometheus server Ingress will be created
##
enabled: true
## Prometheus server Ingress annotations ## annotations: kubernetes.io/ingress.class: ‘alb’ #kubernetes.io/tls-acme: ‘true’ alb.ingress.kubernetes.io/scheme: internet-facing alb.ingress.kubernetes.io/load-balancer-attributes: ‘routing.http2.enabled=true,idle_timeout.timeout_seconds=60’ alb.ingress.kubernetes.io/certificate-arn: certname alb.ingress.kubernetes.io/listen-ports: ‘[{“HTTP”: 80}, {“HTTPS”:443}]’ alb.ingress.kubernetes.io/actions.ssl-redirect: ‘{“Type”: “redirect”, “RedirectConfig”: { “Protocol”: “HTTPS”, “Port”: “443”, “StatusCode”: “HTTP_301”}}’ service: annotations: alb.ingress.kubernetes.io/target-type: ip labels: {} path: /* hosts: - prometheus.company.com
## Extra paths to prepend to every host configuration. This is useful when working with annotation based services. extraPaths: - path: /* backend: serviceName: ssl-redirect servicePort: use-annotation
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ingress:
## If true, Prometheus server Ingress will be created
##
enabled: true
## Prometheus server Ingress annotations
##
annotations:
[kubernetes.io/ingress.class](http://kubernetes.io/ingress.class): 'alb'
#[kubernetes.io/tls-acme](http://kubernetes.io/tls-acme): 'true'
[alb.ingress.kubernetes.io/scheme](http://alb.ingress.kubernetes.io/scheme): internet-facing
[alb.ingress.kubernetes.io/load-balancer-attributes](http://alb.ingress.kubernetes.io/load-balancer-attributes): 'routing.http2.enabled=true,idle_timeout.timeout_seconds=60'
[alb.ingress.kubernetes.io/certificate-arn](http://alb.ingress.kubernetes.io/certificate-arn): certname
[alb.ingress.kubernetes.io/listen-ports](http://alb.ingress.kubernetes.io/listen-ports): '[{"HTTP": 80}, {"HTTPS":443}]'
[alb.ingress.kubernetes.io/actions.ssl-redirect](http://alb.ingress.kubernetes.io/actions.ssl-redirect): '{"Type": "redirect", "RedirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}'
service:
annotations:
[alb.ingress.kubernetes.io/target-type](http://alb.ingress.kubernetes.io/target-type): ip
labels: {}
path: /*
hosts:
- [prometheus.company.com](http://prometheus.company.com)
## Extra paths to prepend to every host configuration. This is useful when working with annotation based services.
extraPaths:
- path: /*
backend:
serviceName: ssl-redirect
servicePort: use-annotation
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ingress:
## If true, Prometheus server Ingress will be created
##
enabled: true
## Prometheus server Ingress annotations
##
annotations:
kubernetes.io/ingress.class: 'alb'
#kubernetes.io/tls-acme: 'true'
alb.ingress.kubernetes.io/scheme: internet-facing
alb.ingress.kubernetes.io/load-balancer-attributes: 'routing.http2.enabled=true,idle_timeout.timeout_seconds=60'
alb.ingress.kubernetes.io/certificate-arn: certname
alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80}, {"HTTPS":443}]'
alb.ingress.kubernetes.io/actions.ssl-redirect: '{"Type": "redirect", "RedirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}'
service:
annotations:
alb.ingress.kubernetes.io/target-type: ip
labels: {}
path: /*
hosts:
- prometheus.company.com
## Extra paths to prepend to every host configuration. This is useful when working with annotation based services.
extraPaths:
- path: /*
backend:
serviceName: ssl-redirect
servicePort: use-annotation
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Sorry for the mishap
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Anyone gone through this issue before fellas?
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
what’s the address for prometheus-server or grafana? configured as? does it match the url you’re using to hit the alb? if you look at inspect and see what the request host and uri is of the assets not being loaded, are you requesting the right resource?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
DO u mean the “hosts” section, Joey?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
hosts:
- prometheus.company.com
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I just checked and I see the domain url I used under “hosts” section is the one I used and its the one beoing loaded
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
However there are multiple redirects are happening
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
no, i mean the prometheus server dashboard or whatever service it is you’re hitting when you hit that ingress
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
i’m just wondering if the things that aren’t loading aren’t loading because you’re getting an incorrect url
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Yes, the prometheus server dashboard will be accessable by the url defined in hosts section and thats how you access it
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
And thats where the issue is
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
prometheus server dashboard is not getting loaded fully
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
if you open inspect mode in chrome or ff or whatever browser you’re using, for the objects that are not being loaded, is the host being requested the same as all the other assets?
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Yes, I used the developer tools and verified the domain names and its all using the proper domain name
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
I fixed the issue… thanks joey
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
what was it?
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
hi, any idea how can I change language of Minikube CLI? Probably it gets the settings from my locale settings (PL), but I’d like to force english.
2020-04-22
data:image/s3,"s3://crabby-images/fa4e9/fa4e9b3be91064c27ad79dc6b369475f1287637e" alt="Ben Read avatar"
What’s your opinion of https://fission.io?
Fission is a framework for serverless functions on Kubernetes. Write short-lived functions in any language, and map them to HTTP requests (or other event triggers). Deploy functions instantly with one command. There are no containers to build, and no Docker registries to manage.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Follow
Fission is a framework for serverless functions on Kubernetes. Write short-lived functions in any language, and map them to HTTP requests (or other event triggers). Deploy functions instantly with one command. There are no containers to build, and no Docker registries to manage.
data:image/s3,"s3://crabby-images/fa4e9/fa4e9b3be91064c27ad79dc6b369475f1287637e" alt="Ben Read avatar"
I’ve recieved some interesting comments in serverless-forum.slack.com about this
2020-04-23
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
Guys, I took over some k8s that I need to adjust. I see bunch of env variables. Its like 50+ per deployment manifest. I dont work so much with kubernetes, but it looks like overkill to me. What is best practice, should it be abstracted with config maps, any other recomendation or that approach is good?
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
When is it too much… 5? 10? 100?
It’s hard to say without knowing what those variables all mutate, which I assume is what they do.
If variables are mostly the same across many different deployments, having something that “generates” them on the fly based on some external source could be an abstraction which may or may not suit your taste …
If you prefer explicitness to carry all the way into the deployment manifests however, you probably want the dynamic generation to happen outside of Kubernetes - in some form of manifest generation..
I may be biased, but I really like chamber, regardless of Kubernetes or not.
https://github.com/segmentio/chamber
chamber exec path/to/global/variables path/to/deployment/specific/variables -- my-binary
CLI for managing secrets. Contribute to segmentio/chamber development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
If you convert the individual env vars into a config map your eyes will thank you when you have to look over the deployment manifests
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Plus, you can then look at controllers to auto restart your deployments when/if the configmaps change
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
That I can agree with for sure .
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
chamber looks sweet, too bad it is provider specific
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
also.. you can combine it from several configmaps, right?
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
And then you could (if several deployment shares “environment globals” so to speak) - combine environment variables in a nice way. I think it’s described in the doc somewhere, let me see.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Totally
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
weirdly enough there are cases where you can benefit from multiple config maps
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
Thinking about something specific other than this “hierarchical” combination of globals/env/service?
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
Nah, it technically boils down to your succinct statement
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I had one where the base deployment was an app that needed some variables based on the cluster which was getting deployed within the pipeline but they later wanted to push out specific updates to config elements that were client specific
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
so, yeah, basically hierarchical combo
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
Thanks Guys, it was really helpfull
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
@Zachary Loeber Did you use any controller which tracks config-maps/secrets change and restart pods if there is a change?
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
I did not unfortunately, seems pretty easy to do though.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
in lower environments I just didn’t see the need (my pipelines would always push more recent deployments based on either build id or git commit hash tagged containers)
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
I was able to utilize this one: https://github.com/pusher/wave
Kubernetes configuration tracking controller. Contribute to pusher/wave development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
maybe there are alternatives
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
This could be promising -> https://www.kubestack.com/
Open source Gitops framework built on Terraform and Kustomize.
2020-04-24
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
k8s-deployment-book, uses kustomize and kubecutr (a custom kube scaffolding tool by the same author) which may not be everyone’s thing but still worth a once over anyway as it is well thought out -> https://github.com/mr-karan/k8s-deployment-book
Kubernetes - Production Deployments for Developers (Book) - mr-karan/k8s-deployment-book
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Hi ppl! What do you use to keep your secret well… secrets … when it comes to your yaml files stored in a repo? Do you store them elsewhere? Do you use tools like sealed-secrets, helm-secrets or Kamus?
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
store your secrets in vault and grab them on startup
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Im not familiar with vault. Is that something that runs in k8s?
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
data:image/s3,"s3://crabby-images/40002/40002394e491e6d2fe290e106a6ded7711b26d64" alt="attachment image"
Vault secures, stores, and tightly controls access to tokens, passwords, certificates, API keys, and other secrets in modern computing. Vault handles leasing, key revocation, key rolling, auditing, and provides secrets as a service through a unified API.
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
If that runs on k8s, does that mean vault becomes the source of truth and you dont keep a copy anywhere?
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
I dont want to commit the secrets in git (unless they are properly encrypted)
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
the way i’ve done it is running vault in a separate cluster/as it’s own piece of infrastructure, and then in my pods i have a vault agent init container that authenticates to vault, grabs secrets, and passes them in files or as environment variables to relevant containers
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
it’s not a trivial exercise, but it’s clean and can be provider agnostic, as opposed to using secret manager from $cloud_provider
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Im not as concerned about them being secured in k8s as having a secure copy elsewhere…
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Im using help charts for my apps…
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
so I have a configmaps.yaml in that chart
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
have you checked out git-crypt for storing encrypted secrets in git?
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Not yet. I looked at sealed-secrets, helm-secrets or Kamus so far. I’ll check that out
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
thanks
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
data:image/s3,"s3://crabby-images/a497d/a497dafab3478a02d6175e6ca768d8b035bf42ab" alt="Adam Blackwell avatar"
Also using Hashicorp Vault and very happy with it, though pulling secrets into static files or environment variables with Kustomize has gotten a bit complicated.
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
I’m using AWS SSM Parameter Store ( https://docs.aws.amazon.com/systems-manager/latest/userguide/systems-manager-parameter-store.html) which I like as it gives me a source of truth outside of the cluster.
We’re currently switching over to using helmfile (https://github.com/roboll/helmfile) which has built in support for retrieving values from SSM parameter store (and other systems, including vault) by using vals (https://github.com/variantdev/vals)
AWS Systems Manager Parameter Store provides secure, hierarchical storage for configuration data management and secrets management.
Deploy Kubernetes Helm Charts. Contribute to roboll/helmfile development by creating an account on GitHub.
Helm-like configuration values loader with support for various sources - variantdev/vals
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
nice, hadn’t seen vals.
data:image/s3,"s3://crabby-images/52329/5232957bf985afd8e7e6c69a1eea642dae0234c3" alt="Christian Roy avatar"
Thanks
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Sure, let me know if you decide to look into any of that stuff and have questions. I’m still pretty new to helmfile myself but happy to help if I can.
data:image/s3,"s3://crabby-images/22831/2283128a119557e2717fb97135ed4d10e640ae91" alt="Ayman avatar"
As for vault, someone just released some Terraform to deploy it on AWS: https://github.com/jcolemorrison/vault-on-aws
A secure Vault for secrets, tokens, keys, passwords, and more. Automated deployment with Terraform on AWS. Configurable options for security and scalability. Usable with any applications and se…
data:image/s3,"s3://crabby-images/22831/2283128a119557e2717fb97135ed4d10e640ae91" alt="Ayman avatar"
It is quite complicated though, so the folks at Segment created chamber as a result: https://github.com/segmentio/chamber
CLI for managing secrets. Contribute to segmentio/chamber development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
When on Azure and without a centralized Hashicorp Vault deployment I leaned on using keyvault with this project to auto-inject secrets using mutating admission webhooks: https://github.com/SparebankenVest/azure-key-vault-to-kubernetes
Azure Key Vault to Kubernetes (akv2k8s for short) makes it simple and secure to use Azure Key Vault secrets, keys and certificates in Kubernetes. - SparebankenVest/azure-key-vault-to-kubernetes
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
the concept is similar for other operators as well though (hashicorp’s vault operator does the same I believe). That way you are not putting your secrets anywhere at all except in your secret store and pulling them into deployments if the cluster is authorized to do so.
data:image/s3,"s3://crabby-images/c4007/c4007ac3f2ea7b77860a98a8551d584856b49862" alt="Zachary Loeber avatar"
or you can pre-seed cluster secrets as well I suppose. I’ve done this as well but you are then pushing the responsibility for secrets deployment to an upstream pipeline (the one that creates your cluster generally).
data:image/s3,"s3://crabby-images/2a6c6/2a6c695b8614351039c75f2ee697c4c216e6a766" alt="github140 avatar"
How do you authenticate to vault and how to store those credentials?
data:image/s3,"s3://crabby-images/b4dbd/b4dbd4731894616fdcdb715cc3e7f0291d2d1c56" alt="joey avatar"
service accounts
data:image/s3,"s3://crabby-images/2a6c6/2a6c695b8614351039c75f2ee697c4c216e6a766" alt="github140 avatar"
How do you protect/secure it?
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
I am working last couple od days with GoDaddy External secret implementation. You can integrate aws secret manager, parameter store or even vault with it.
data:image/s3,"s3://crabby-images/b10c8/b10c84adc7c895af6177515ddfeda5e8a66ab15f" alt="Milosb avatar"
I am pretty happy so far
data:image/s3,"s3://crabby-images/a497d/a497dafab3478a02d6175e6ca768d8b035bf42ab" alt="Adam Blackwell avatar"
Does anyone have any stack graph-esque minikube development flows that they would recommend?
We’re using ArgoCD + smashing the sync button and I’ve looked at how https://garden.io/#iterative figured out smart local redeployments but I’d like to know how others are doing it and if our (certmanager->vault->mysql + elasticsearch) -> the actual app local dev deployment is abnormally complex or slow. (currently takes three syncs and ~8 minutes to go from minikube up to running.)
2020-04-25
2020-04-26
2020-04-27
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
anyone have to fine tune Nginx for performance in k8s?
worker_processes 2;
events {
worker_connections 15000;
}
For a 2 CPU container, with 65k file descriptor limit.. thinking this would be safe. I have a generous k8s HPA also, so maybe fine tuning is a frivolous exercise
2020-04-28
2020-04-30
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
btw: https://github.com/kubernetes/ingress-nginx/blob/master/Changelog.md
Seems like ingress-nginx got a couple of bigger updates in the last days.
NGINX Ingress Controller for Kubernetes. Contribute to kubernetes/ingress-nginx development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Pierre Humberdroz thanks for sharing
NGINX Ingress Controller for Kubernetes. Contribute to kubernetes/ingress-nginx development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that is a long list
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
anything jump out at you? mostly looks like bug fixes to me. no enhancements stand out that I want to try
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Helm chart stable/nginx-ingress is now maintained in the ingress-nginx repository
According to https://github.com/kubernetes/ingress-nginx/issues/5161 there is documentation in the works for migrating from chats/stable to the new location.
Rename chart to ingress-nginx add common labels: app.kubernetes.io/name: ingress-nginx app.kubernetes.io/part-of: ingress-nginx default backend should be disabled by default webhook should be enabl…
data:image/s3,"s3://crabby-images/662c3/662c3185b944a7d273fbaa7d61c4a971edb10194" alt="Pierre Humberdroz avatar"
yea stable/incubator helm repo are not longer supported
data:image/s3,"s3://crabby-images/703f1/703f16033ebe0e670b09b496ca98cfe4d690b1a9" alt="bradym avatar"
Wow, I hadn’t seen that yet. That’s a big change.
data:image/s3,"s3://crabby-images/d4bc4/d4bc4677fd3edf51c2e85034fcc90e4e8ccc7b43" alt="jedineeper avatar"
Is the a method to promote objects across api versions? Eg deployments have moved from extensions/v1beta1
to apps/v1. Can t
hey be updated in place or do they need to be destroyed and recreated?