#kubernetes (2018-11)
Archive: https://archive.sweetops.com/kubernetes/
2018-11-04
data:image/s3,"s3://crabby-images/fb0d3/fb0d35c35b9095b1bb5ad6eb3405cb4c9f7b3234" alt="rohit.verma avatar"
hi all, what are you opinion on different networking option in kubernetes on aws. Which is more preferred and felt robust. We did tried with aws-vpc-cni but felt that its not stable enough even with 1.1.0 for kuberntes 1.10.6. This becomes more unstable when all your worker nodes are unstable and started giving exception as sandox ip changed etc..
data:image/s3,"s3://crabby-images/fb0d3/fb0d35c35b9095b1bb5ad6eb3405cb4c9f7b3234" alt="rohit.verma avatar"
we then switched to calico, but somehow its observed that its impacting the way pods terminate. If we delete a deployment, pods remain in terminating state for 5+ minutes.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The pods stuck in a terminating state is a very frequently observed problem. Could it be related to the network layer? Maybe - but I would explore other possibilities. To me the network culprit seems like a red herring.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Lots of posts/issues on it. Usually related to zombies.
2018-11-06
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@rohit.verma we saw something like that with some of k8s pods, in particular kiam
- when deleted, the pods take many minutes to terminate
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so maybe it’s an issue with some deployments, not the network itself?
data:image/s3,"s3://crabby-images/fb0d3/fb0d35c35b9095b1bb5ad6eb3405cb4c9f7b3234" alt="rohit.verma avatar"
But the pods I am referring here is generic like nginx or spring boot app
data:image/s3,"s3://crabby-images/fb0d3/fb0d35c35b9095b1bb5ad6eb3405cb4c9f7b3234" alt="rohit.verma avatar"
Anyways more concerned about a general opinion on different kubernetes networks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We haven’t had the opportunity to explore/optimize the network layer in k8s
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also are you familiar with the dumb-init “fix” ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is to address the same symptoms
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A minimal init system for Linux containers. Contribute to Yelp/dumb-init development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
@Andriy Knysh (Cloud Posse) hello again, do you have any doco’s and best practices for promoting kube, within nonp? … ie … dev to staging?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for clarification, are you talking about promoting images and helm charts? or promoting usage of kubernetes within a company
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
right now we are using diff name spaces in k8s
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
currently it is within company
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So the same cluster for staging and production?
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
dev and staging
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
bump
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
sorry, i let this fall through the cracks.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we don’t have a well documented process for what you want. we’ve implemented and documented it internally for customers, but still need to document it on our site.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have something rough here: https://docs.cloudposse.com/release-engineering/cicd-process/
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, looks like the video was taken down =/
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
nice
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
this is the same thing that I had in mind …
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
do what is your view databases with persistent volumes?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Use fully managed databases for anything you care about
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Use database containers for disposable environments
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So for example, when we deploy environments for every PR we use containers
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
what are your thoughts on some of the work that Kelsey Hightower has done in this space? https://github.com/kelseyhightower/pipeline
A step by step guide on creating build and deployment pipelines for Kubernetes. - kelseyhightower/pipeline
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have’t taken a look at it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Nonp?
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
ya we run a two accounts … were one is prod and one is none-prod
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
and all our none-prod stuff happens in nonp
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Aha gotcha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We don’t have the promotion process documented but I can share how it looks (we use Codefresh)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I am currently on my phone so will share a little later
data:image/s3,"s3://crabby-images/be45b/be45be40f8b3235dac3018e2bccee2f0001c534f" alt="onzyone avatar"
np sounds good
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
using kops or terraform for creating kubernetes Production. What is better and cons ??
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Tee we use terraform to create kops resources, e.g.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Collection of Terraform root module invocations for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Collection of Terraform root module invocations for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and then use kops
to provision k8s clusters
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there was some discussion earlier in #terraform I think related to EKS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we also have TF modules for EKS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Tee are you thinking GCP or AWS?
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
AWS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so on AWS, my opinion is that it’s more work than than necessary to manage EKS with terraform. the challenge comes down to upgrading. there’s some discussions on strategies for that.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) are ya’ll using it with kops? Looks like it. How does TF generation fit in if at all?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
with kops
, the ability to do rolling-updates is built in; it’s a purpose built tool like kops will do a better job at managing lifecycles.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if fargate announces EKS support at the end of the month, I might change my stance
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
But the EKS and FARGATE gets pretty expensive
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
as far i think
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
humans aren’t cheap either
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
Right
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
So what do you suggest for longterm. Not considering the cost. With less bottlenecks and nightmares
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not an easy question
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
I mean in terms of stability
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
kops
is well established and works well, and does lifecycle management
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
EKS is new and lacks a lot of features, but it will stay and they will improve it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Fargate will improve and cost will be reduced
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(we’re not using EKS in production yet, so our story will be biased towards kops)
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
Oh ok. Thanks @Erik Osterman (Cloud Posse) & @Andriy Knysh (Cloud Posse) for your suggestions.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea, the point is that with the current state of EKS, you need to do and provision even more resources than using kops
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and it does not support many features
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Fargate could improve it, but as many mentioned it’s costly (and it does not exists yet)
data:image/s3,"s3://crabby-images/fcdbb/fcdbbe36ce03d19d758fb6f4593a3e3eb17d0aff" alt="Tee avatar"
That makes sense
data:image/s3,"s3://crabby-images/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
I am currently moving all of our infrastructure off Mesosphere DC/OS onto EKS and EKS has been phenomenal in my opinion - just lots of support from many different aspects such as AWS and the Kubernetes community
data:image/s3,"s3://crabby-images/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
as well as great folks like Cloud Posse
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea thanks @Matthew
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the point is that with EKS, if for example you need to perform a rolling update, it’s not supported out of the gate
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so a lot of friction with many things
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
with kops
it just works
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but sure for longterm EKS/Fargate would be better
data:image/s3,"s3://crabby-images/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
Yeah i’ve talked with EKS specialist from AWS and they currently suggest a blue/green strategy for upgrading which can be tedious and at times break backwards compatibility
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
how do you export a single context of your kubeconfig?
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
say my local kubeconfig has a dev
qa
prod
context
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@btai we don’t have multiple contexts. We use containers + ENV vars
pattern (implemented in geodesic
+ repo per env + Dockerfile(s)). So in each container (prod
, staging
, dev
, etc), when we run it, we have all ENV vars defined for that particular env (ENV vars come from Dockerfiles or from SSM if they are secrets). That includes everything for Terraform, kops, k8s, etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
So when we do for example kops export kubecfg
, the environment knows what context we want
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and we can run those geodesic
containers locally and also in CI/CD pipelines (for which we use Codefresh since it can run each pipeline step as a Docker container)
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
nice thanks
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Have you guys used Codefresh enterprise? I know you’re all big into codefresh here. Just curious of any pitfalls or bits of advice you guys have
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
(enterprise to run on-prem)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So Codefresh enterprise has 3 variations: full SaaS, hybrid and on-prem
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve been working exclusively with the enterprise SaaS
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Ooo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what’s the primary driver for going on-prem?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
compliance requiring no dependence on external SaaS providers
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
which compliance certification?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
oh wow, you haven’t even taken me out on a date yet to be asking such risquè questions.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
lol jk, I think fedramp
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
lol
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok - that’s a whole ’nother cup of tea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not familiar with
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but sounds like you’d need full on-prem.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so i probably wouldn’t enlighten you more than you already know
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
No worries. We’re new to codefresh–so just probing for any gotcha’s really
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dustinvb can definitely elaborate
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
are you using the helm based install?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I think at the moment, yes
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
debating about the release of terraform 0.12 and using all the templating stuff
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
rather than 2 templating engines.. tiller.. and all that jazz
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so i get where you’re coming from - but from what i’ve gleaned the current helm provider is too basic to handle all kinds of helm charts. maybe with 0.12 it’s better off
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you’ve seen our helmfiles repo? basically you can’t do half of what we do with helmfile using that provider
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
https://marketplace.fedramp.gov/#/product/aiware-government?sort=productName
Just as a cover my ass that I’m not saying providing any confidential information.. it’s publicly available that we’re on fedramp ^^^ lol
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Oh, my bad. I didn’t mean the helm provider.. I meant generating the k8s.yml files on the fly based on the infra-state.. no helm installation anywhere
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
just a thought at the moment–not necessarily going that direction for sure
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but yea, you could basically create terraform modules in place of helm charts
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
… if terraform templating is sufficient
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
hehe, yeah, big “if”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it’s been my experience, the “simple” case always works well regardless of the technology
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
ah
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
how have you guys been liking helm? any complaints with the tiller stuff, or you guys are experienced enough with it all–nothing really bugs you?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i mean, it sucks about the tiller and all
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but i look at helm more like an interface
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and the interface won’t change dramatically, but the underlying implementation is getting a big overhaul as you’re probably aware
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
as part of that tiller is going away and the template engine going pluggable
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
“tillerless helm” is the buzz
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
as a way to manage a complex apps it’s great
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and app dependencies
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i say (and with some humility) that those before us have invested a lot of time in what it takes to manage software releases
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
deb, rpm, apk, etc.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we tried to avoid that with just a Makefile
; it worked well until it didn’t. in the end, we needed all that a package manager provides and conceded to package .apk
alpine packages
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
my point is that just templatizing raw kubernetes resources and applying them seems easy enough and i’m sure you can get away with it for a long time
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but then you realize you want to have dependencies, triggers on deployment or uninstall, and rollbacks, etc. then you’re on your own.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the more homegrown/spun, the more the solution diverges from the trajectory the community is taking
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
because the community is solving problems around a standardized toolset
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
all true
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
so i’m curious.. you bring up rollbacks
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
codefresh/spinnaker’s solutions didn’t offer enough in that aspect?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
codefresh relies on the fact that helm does rollbacks automatically
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
ah
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and even bakes that into the UI with one-click rollbacks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
they also have some even more cool stuff in the works - but you’ll have to ask them to see it
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
For sure
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
we have meetings setup with them
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
We’ll probe
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
does all this reveal a well needed niche (product offering) in the CI/CD process for k8s?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
since there always ends up being handrolled stuff?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha, not sure - there are more CI/CD platforms today than ever
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
https://github.com/gaia-pipeline/gaia I like their philosophy at that in particular
Build powerful pipelines in any programming language. - gaia-pipeline/gaia
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i can’t keep them straight anymore
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
spinnaker is now coming out with an enterprise offering too
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
haha nice. Well, after the bloodbath, hopefully the best solution reigns supreme
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
ah
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
halyard
was surprising when I first played with it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and then github actions
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
then I looked at the helm chart for spinnaker.. and it was just a bunch of hal
commands
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but i agree that there’s still big room for improvement
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the fact there is so much handrolling and independent tooling
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think codefresh is well poised to do that as it relates to cicd+kubernetes+helm
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
does your gut think helm isn’t going anywhere?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
until I see an alternative that has anywhere near the critical mass of helm, yes - i think it’s here for the foreseeable future
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for example, there’s ksonnet
(based on jsonnet
) which looks interesting
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but i think some variation of that could be used as a pluggable engine for helm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, i don’t want to see proliferation of more packaging systems right now - it’s too early
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Helm tiller plugin aka Tillerless Helm. Contribute to rimusz/helm-tiller development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you seen this plugin?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is pretty smart.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I thiiiink I’ve seen this one.. if not it was something similar
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
basically, it’s a drop in replacement. it still stores all configs in the cluster (per namespace if you want)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you run a temporary tiller locally
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this can be run as part of CI
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
interesting.. hmm.. nice actually!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(though would break the codefresh helm UI, since it would need to talk to the tiller and there would be none running)
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
ah, right
2018-11-07
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Experimental ksonnet plugin for Helm. Contribute to technosophos/helm-ksonnet development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Dig it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In order to provide jsonnet rendering for helm charts a new ReleaseModule similar to the Rudder ReleaseModule should be developed. This module would take charts and render them as Jsonnet templates…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Guess my hopes of seeing ksonnet as a template engine in helm were misguided
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I know Lua is coming. I’d heard such great things about jsonnet, that I assumed it would be well suited. But Lua I guess is a better understood embeddable language
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Last I had to write Lua was 14 years ago when dealing with Nginx
2018-11-08
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
For the codefresh peeps out there.. does it matter what/how the ingress controller looks when using codefresh for deployments?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Was reading through: https://docs.traefik.io/user-guide/kubernetes/#traffic-splitting and it came to mind
2018-11-09
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Nope, we use for example the CloudFlare Acesss/Argo ingress and nginx-ingress controller in the same cluster
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
have you seen this https://www.youtube.com/watch?v=kOa_llowQ1c
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I love his presentations and he’s definitely the best evangelist for kubernetes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and i think he’s presenting the simple side that should be presented
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and here comes the but…..
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but in the real world of deploying complex applications with interdependencies, secrets, configurations, etc… it devolves into something much more complicated
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
his presentations are always awesome
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
for sure
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and the gap to cross from the hello world examples to customer apps is huge
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
he makes it look so “easy button”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) 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"
PLEASE SOMEONE SHOW ME HOW TO MAKE THIS EASIER
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i want to
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i hate this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and here’s the rest of all the other apps
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Comprehensive Distribution of Helmfiles. Works with helmfile.d
- cloudposse/helmfiles
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
so with one of my customers we are working on two distinct steps… once to build the app, then a seperate one to update (deploy) the app in an ongoing fashion
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we’re using helm, and some hate on helm for one reason or another. but one things for sure, this is hiding an even more enormous pile of YAML/go templating on the backend.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
i hate kelsey hightower in the best way possible
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this is interesting https://aws.amazon.com/blogs/opensource/continuous-delivery-eks-jenkins-x/
data:image/s3,"s3://crabby-images/54f42/54f4229f5fc99abd4c7168e0307d7c1c8bae95a0" alt="attachment image"
Amazon Elastic Container Service for Kubernetes (Amazon EKS) provides a container orchestration platform for building and deploying modern cloud applications using Kubernetes. Jenkins X is built on Kubernetes to provide automated CI/CD for such applications. Together, Amazon EKS and Jenkins X provide a continuous delivery platform that allows developers to focus on their applications. This […]
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i did not think it could do so much, it creates pipelines for infrastructure itself (prod and staging), and pipelines for the app, and even spawns a separate testing/staging env in k8s for each PR, and comments on GitHub on PRs (like atlantis
), and creates GitHub repos with Helm charts for the infrastructure (prod and staging)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
https://github.com/jenkins-x/sso-operator (@Erik Osterman (Cloud Posse) already posted it before)
Single Sign-On Kubernetes operator for Dex identity provider - jenkins-x/sso-operator
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
one thing it can’t do is to upgrade the k8s cluster b/c it itself sits in the same cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
wow
data:image/s3,"s3://crabby-images/f7ece/f7ecec8790d12d41ee1931633639ed59a72e2ba1" alt="ramesh.mimit avatar"
@here Any recommendations for learning distributed systems from basics to advance?
data:image/s3,"s3://crabby-images/f7ece/f7ecec8790d12d41ee1931633639ed59a72e2ba1" alt="ramesh.mimit avatar"
noticed, lot of people knows the tools but not the concepts…
2018-11-11
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@ramesh.mimit I found this site very interesting and with lots of resources about distributed systems, and real-life examples from many companies
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/f7ece/f7ecec8790d12d41ee1931633639ed59a72e2ba1" alt="ramesh.mimit avatar"
@Andriy Knysh (Cloud Posse) thanks..
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"
“Google Kubernetes Engine’s third consecutive day of service disruption”
2018-11-12
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
anyone use the official python kube library?
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
can you load the config from a dict?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
~why not use config profiles instead?~
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
~e.g. ~AWS_DEFAULT_PROFILE=cp-prod-admin
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
~the underlying aws SDK should then handle everything automatically~
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
the kube config?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
heh, my bad @btai
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
how would i run kubectl within a container running from a job?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s an example doing it from a deployment: https://github.com/onfido/k8s-rabbit-pod-autoscaler
Kubernetes autoscaler for pods that consume RabbitMQ - onfido/k8s-rabbit-pod-autoscaler
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
doing it from a job wouldn’t be any different
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just need the proper role bindings
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in this case, kubectl
is gettin called from in the autoscale.sh
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
so if i have the wrong role bindings
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
would i be getting this error:
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
The connection to the server localhost:8080 was refused - did you specify the right host or port?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
all i know is when we implemented it for redis using the strategy above (for rabbit), we didn’t need to specify any hosts
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it just autodiscovers it
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
the pod autodiscovers
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
ok thats what i was hoping for
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it also provides a kube context
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
so the pod itself didnt have any kubeconfig or kube api secrets
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, it didn’t have anythign like that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Contribute to vanvalenlab/kiosk-autoscaler development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
yeah i have a job basically doing the same thing
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
executing a shell script that makes a kubectl call
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
but i get the above error
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
kops cluster?
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
aks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we tested it on gke and kops
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
yeah it works in kops
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
that job
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh interesting!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you have rbac enabled in kops?
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
although the kops
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
doesnt have rbac enabled
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"
haha
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
yeah
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
so do i create a clusterrolebinding for the job?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Kubernetes autoscaler for pods that consume RabbitMQ - onfido/k8s-rabbit-pod-autoscaler
2018-11-13
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
thanks
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
sorry, still new to k8s
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
hypothetically if i create a cluster role binding with the namespace and name that matches the job, that should work?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
More or less
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t know the specific matching selectors that are available
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is near. Copy secrets from a centralized system of record. https://github.com/mittwald/kubernetes-replicator/
Kubernetes controller for synchronizing secrets & config maps across namespaces - mittwald/kubernetes-replicator
2018-11-14
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
How are you guys handling busy helm deployments where the tiller is busy attending to other deployments…
Error: could not find a ready tiller pod
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Max Moon @dustinvb
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Introduce –replicas option to configure amount of Tiller instances on the cluster. Fixes #2334. The next PR will be about distributed lock, this one is just exterior.
data:image/s3,"s3://crabby-images/59708/5970895ff53b1cb5823259a6e8c480ed3ce57c7f" alt="dustinvb avatar"
I haven’t ran into this scaling issue yet.
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"
@michal.matyjek @Daren have you run into this?
data:image/s3,"s3://crabby-images/b7633/b76339b7edd0b24245e9335372ac3237ba2d4b27" alt="Max Moon avatar"
I have not run into this yet either
data:image/s3,"s3://crabby-images/8e770/8e77078db0aaf6350ec88a953039f0bf3069c75d" alt="Daren avatar"
I have not
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
not yet
data:image/s3,"s3://crabby-images/6adb7/6adb7dc4f90725afcf7ee550a7a01c4bf4082218" alt="michal.matyjek avatar"
how many deployments are we talking about?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just concurrency
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we’re running helm
on every PR synchronization for unlimited staging environments
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we’re getting it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g. 2 developers push at around the same time
2018-11-19
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
hey all - curious what the verdict is on kiam vs kube2iam… it seems like kiam was created to address some issues with kube2iam - is kiam the way to go these days?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@sarkis yea, kube2iam is dead and should not be used. It’s a massive liability to even deploy in an AWS account. If you run more than N hosts (N ~10), you’ll DoS AWS APIs and they rate limit you.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
kiam addresses this by having a client/server model. clients run on all nodes (agents), and talk to the server. the server is responsible for fetching the credentials which reduces rate of requests
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it also caches
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think there’s been some frustration related to the rate of development on Kiam, but the worse bugs are fixed.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also, I don’t know of any alternatives to kiam
and kube2iam
for AWS
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
thanks @Erik Osterman (Cloud Posse)!
2018-11-21
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A helm plugin that help manage secrets with Git workflow and store them anywhere - futuresimple/helm-secrets
2018-11-28
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"
You can use a PodPreset object to inject information like secrets, volume mounts, and environment variables etc into pods at creation time.
2018-11-30
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
set the channel topic: