#kubernetes (2019-10)
Archive: https://archive.sweetops.com/kubernetes/
2019-10-01
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
i am using terraform-aws-elasticsearch module in my stack and im loved it
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
from cloudposse repository congratulations to those involved!!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Awesome! We use that one all the time
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s great with fluentd and k8s
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
yeah, so, i got some trouble, when kibana record the CNAME on route53, the path /_plugin/kibana
must not be part of the record.
there is a issue for it to fix: https://github.com/cloudposse/terraform-aws-elasticsearch/issues/14
When dns_zone_id is supplied, the module attempts to create a CNAME Route53 record for the domain's Kibana endpoints. These endpoints look like "xxx.<region>.es.amazonaws.com/_plugin…
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
must be just [vpc-sb-shared-elasticsearch-6m6ftgtu6n74l3dh3drw3vwmvq.us-east-1.es.amazonaws.com](http://vpc-sb-shared-elasticsearch-6m6ftgtu6n74l3dh3drw3vwmvq.us-east-1.es.amazonaws.com)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) this looks like a bug
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s odd though since we deploy this regularly
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this is a feature
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an Elasticsearch cluster with built-in integrations with Kibana and Logstash. - cloudposse/terraform-aws-elasticsearch
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an Elasticsearch cluster with built-in integrations with Kibana and Logstash. - cloudposse/terraform-aws-elasticsearch
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
use the same domain name [testing.cloudposse.co](http://testing.cloudposse.co)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
TestExamplesComplete 2019-07-28T22:37:01Z command.go:121: domain_hostname = es-test.testing.cloudposse.co
TestExamplesComplete 2019-07-28T22:37:01Z command.go:121: kibana_hostname = kibana-es-test.testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we don’t add /_plugin/kibana
to it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we add it in the helmfiles
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
one of those could be removed since they point to the same thing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
[es-test.testing.cloudposse.co](http://es-test.testing.cloudposse.co)
is the ES domain endpoint
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
right, but I think @Ruan Arcega is saying the cname was created automatically with the /_plugin/kibana
which is wrong
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
[es-test.testing.cloudposse.co](http://es-test.testing.cloudposse.co) /_plugin/kibana
would be the Kibana URL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
right, but look at his screenshot from route53
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i see it. Maybe something is changed already in AWS. We deployed it last time a few months ago
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"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so our DNS is pointing to the wrong output
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
should it be using domain_name
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
domain_name
is not URL
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s just the name of ES domain
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we have
vpc-xxx-xxxxx-elasticsearch-xxxx.eu-west-2.es.amazonaws.com/_plugin/kibana/
as CNAME and it’s working
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(I mean AWS accepted the record before and accepting it now)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, so it’s accepting the record
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but the record is still garbage
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Type Domain Name Canonical Name TTL
CNAME kibana-elasticsearch.eu-west-2.xxx.xxx.io vpc-xxx-xxx-elasticsearch-xxxx.eu-west-2.es.amazonaws.com/_plugin/kibana/
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
resolution works too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but I agree since those are the same, one could be removed
2019-10-02
data:image/s3,"s3://crabby-images/d1880/d188053be09dbebcad58757741e60b83372c3993" alt="sohel2020 avatar"
Does sweetops has any terraform module to create Kubernetes cluster using kops?
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
No they use kops from the cli to provision kubernetes.
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
That’s true, however they still set up a lot of dependent resources with terraform. See:
https://github.com/cloudposse/terraform-root-modules/tree/master/aws/kops
and
https://github.com/cloudposse/terraform-root-modules/tree/master/aws/kops-aws-platform
and there’s other modules in that same repo to assist kops with some stuff.
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
but correct, no automation of kops itself
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ya we haven’t automated kops because what kops does it does better than terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s purpose built for managing the lifecycle of the cluster with the business logic of how to do updates. Terraform is more like a bulldozer.
2019-10-03
2019-10-04
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I got a tricky one for you peeps.. At a high level, I need a static IP (Elastic IP) in front of a k8s service or ing.
aws-alb-ingress-controller doesn’t help since ALBs can’t use EIPs out of the box.. (yes, you can put an NLB in front of it.. and have a lambda function keep the NLB target group up to date the ALB IPs.. https://aws.amazon.com/blogs/networking-and-content-delivery/using-static-ip-addresses-for-application-load-balancers/)
Using nlb
annotations in a svc is feature poor even with the latest version of EKS (k8s 1.14) and doesn’t properly attach EIPs to the NLB.
What else should I look at? Things that sound nice but I’ve never touched before (CRDs, Operators, etc..) could maybe help.. or not? What do you think?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
Does it have to be an IP? Can it be a domain name? nginx-ingress controller works really well. Set up a domain in Route53 and use nginx-ingress controller, so your service is myservice.example.com, or whatever you want it to be.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Yeah, IP. Someone needs to whitelist our IP for an integration.
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
For inbound traffic @Ryan? As in the integration is going to PUSH to your IP?
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
@Cameron Boulton exactly
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Huh. I agree with Pepe: Global Accelerator is probably your best bet.
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
interesting
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
lemme take a look at that.. haven’t heard of it
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
Alternatively.. I can use terraform to stand up an NLB + EIPs.. then use a lambda function or some code somewhere to constantly update the NLB target group with the results from kubectl get nodes
2019-10-05
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This should be possible today using simple nginx ingress with the right annotations
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
it’s not available on k8s 1.14 which is the highest eks version
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
service.beta.kubernetes.io/aws-load-balancer-type: nlb service.beta.kubernetes.io/aws-load-balancer-eip-allocations: “eipalloc-07e3afcd4b7b5d644,eipalloc-0d9cb0154be5ab55d,eipalloc-0e4e5ec3df81aa3ea”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ah so need to run a newer version of k8s not supported by eks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The issue points to the reported closed issue here : #63959 I tested this but its not working correctly and ingress is not respecting the annotations : I have hard time getting this working with NL…
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/1c660/1c660aa16be17bc1575821ef8f8485f4f13246d3" alt="attachment image"
Introduction In August 2016, Elastic Load Balancing launched Application Load Balancer (ALB), which enable many layer 7 features for your HTTP traffic. People use Application Load Balancers because they scale automatically to adapt to changes in your traffic. This makes planning for growth easy, but it has a side effect of changing the IP addresses […]
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I referenced this one initially. It is an option i’m considering
data:image/s3,"s3://crabby-images/1c660/1c660aa16be17bc1575821ef8f8485f4f13246d3" alt="attachment image"
Introduction In August 2016, Elastic Load Balancing launched Application Load Balancer (ALB), which enable many layer 7 features for your HTTP traffic. People use Application Load Balancers because they scale automatically to adapt to changes in your traffic. This makes planning for growth easy, but it has a side effect of changing the IP addresses […]
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
it’s pretty gnarly, but definitely last resort
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
I appreciate you sharing this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it is so much easier to use global accelerator
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
thank you, I’m taking a look. I haven’t heard of it before
2019-10-07
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"
data:image/s3,"s3://crabby-images/dd31b/dd31b079491f62daacb7cd9a04b1d8c7ea70fa52" alt="Cameron Boulton avatar"
Yea, 80% of infra solutions are like this: people fall back on what they know and build these Rube Goldberg machines that have already been solved.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
2019-10-09
data:image/s3,"s3://crabby-images/f8f25/f8f25811883802c050260143cd1492f3be74e725" alt="Austin Cawley-Edwards avatar"
Hey all, not sure if this belongs in this channel so please let me know if it’s not the place, but I just opened up a neat feature PR for the cloudposse/prometheus-to-cloudwatch
app - if anyone uses that and has some time to give some feedback I would really appreciate it, thanks! https://github.com/cloudposse/prometheus-to-cloudwatch/pull/28
Closes #27 This feature allows users to exclude a set of dimensions from metrics. It should be easy enough to add a dimensions whitelist as well, which seems to be in the style of this application,…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) will review
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Austin Cawley-Edwards thanks for the contribution
2019-10-10
data:image/s3,"s3://crabby-images/f8f25/f8f25811883802c050260143cd1492f3be74e725" alt="Austin Cawley-Edwards avatar"
Awesome, thank you both!
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
cross posting from #security because it is relevant here: https://sweetops.slack.com/archives/CBXSAR45B/p1570720099000200
data:image/s3,"s3://crabby-images/54d6d/54d6d45c95f957c0fbb51eb57b2cbcdb47e76cb1" alt="attachment image"
A new vulnerability has been discovered within the Kubernetes API. This flaw is centered around the parsing of YAML manifests by the Kubernetes API server. During this process the API server is open to potential Denial of Service (DoS) attacks. The issue (CVE-2019-11253 — which has yet to have any details fleshed out on the page) has been labeled a ‘Billion Laughs’ attack because it targets the parsers to carry out the attack.
data:image/s3,"s3://crabby-images/1205f/1205fac08051ae6715ddf79c297d0cae826908f1" alt="Michael Cram avatar"
This is why you always use a bastion host and isolate your cluster from everyone.
data:image/s3,"s3://crabby-images/54d6d/54d6d45c95f957c0fbb51eb57b2cbcdb47e76cb1" alt="attachment image"
A new vulnerability has been discovered within the Kubernetes API. This flaw is centered around the parsing of YAML manifests by the Kubernetes API server. During this process the API server is open to potential Denial of Service (DoS) attacks. The issue (CVE-2019-11253 — which has yet to have any details fleshed out on the page) has been labeled a ‘Billion Laughs’ attack because it targets the parsers to carry out the attack.
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
how to encrypt passwords in helm values.yaml, any good documents is appreciated. Thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I assume you’re referring to helm’s values.yaml
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
right
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
I used helm secrets to make sure passwords are hidden when pushed to code repositories
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
I was not sure about helm get values
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
can you please let me know other startegies
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
@Erik Osterman (Cloud Posse) ^
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@AG there’s the helm-secrets
plugin that tries to address this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but secrets will still be clear-text in the if you run helm get values
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(which is why you just can’t pass any secrets via helm that you truly care about)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
instead, the better pattern is to assume the secrets have been installed some other way…. basically assume the resource already exists and don’t provision with helm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then when you install the chart release, it will block until that secret exists.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there are a few strategies for populating secrets
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
basically, you want to decouple the lifecycle of secrets with the lifecycle of helm releases
2019-10-11
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
@Erik Osterman (Cloud Posse) Thanks
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
I’m trying to pass encrypted values to secrets and use them as variables, will that work?
data:image/s3,"s3://crabby-images/d5868/d58683b58750bac791a006aa27ed666078061182" alt="AG avatar"
{{ (tpl (.Files.Glob “configs/*“).AsSecrets . ) | indent 2 }} |
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
Hey all, trying to set up kops in a new environment set up with the reference-architectures repo, so right now trying to run kops-aws-platform
(https://github.com/cloudposse/terraform-root-modules/tree/master/aws/kops-aws-platform) and it seems it expects IAM roles like masters.us-west-2.testing.ryanjarv.sh
and nodes.us-west-2.testing.ryanjarv.sh
to be set up. Wondering if there is some step I missed that handles that.
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
those are provisioned by kops
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
Ok thanks will look into that. It did run ok but might need a more recent version or something.
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
Think I got it figured out, missed the extra steps here before. (https://github.com/cloudposse/terraform-root-modules/tree/master/aws/kops)
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just so there’s no confusion we’re not using the terraform mode for kops
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there are some other modules out there by others that do that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
our module is for setting up the aws integration points that kops expects.
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
Terraform mode? Suppose I don’t know much to much about managing kops/k8s. Is that just managing individual pods with terraform? k8s in general still gets set up with the kops-aws-platform module right?
Edit: ok nvm seems the cluster itself is set up with kops.
2019-10-12
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
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"
this is what I was referring to
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then there are some other terraform modules (not by us) that leverage this (i think)
2019-10-16
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
interested in thoughts - my thoughts are it sounds like it’s trying to separate dev and ops which i do not like
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/ac62b/ac62b8a374f3306bc7ce22a436ced5e08beff8bd" alt="attachment image"
Learn from Docker experts to simplify and advance your app development and management with Docker. Stay up to date on Docker events and new version announcements!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/ed23a/ed23a47cd3e9d793d360316be12c19a1c253eea8" alt="attachment image"
Cloud Native Application Bundles facilitate the bundling, installing and managing of container-native apps — and their coupled services.
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
sort of - it seems more like a way to implement an abstraction layer between teams of dev/ops/infra teams. cnab feels like more of a packaging tool kit to me, where this feels more like enterprise service catalogish kind of stuff (insert hand-waving)
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
while i understand the pain that’s driving the need, i’m not sure i’d like to deal with an environment where that was required
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
i’m also a little sick of abstractions over the kube apis that just look like the kube apis
2019-10-18
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
Hey #kubernetes !
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
Just deployed k8s via the k8s-workers module, everything is working great. Being able to add iam users and roles via terraform is amazing.
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
Attempting to deploy a gitlab helm chart results in
Error creating load balancer (will retry): failed to ensure load balancer for service default/gitlab-nginx-ingress-controller: could not find any suitable subnets for creating the ELB
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
I used CloudPosse’s VPC, Subnets, EKS, local.tag and EKS Workers modules
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
data:image/s3,"s3://crabby-images/17dec/17dec6925c67d9ea139492ed5357e4a082f06907" alt="Brandon Shutter avatar"
I needed to add the var.tags to the subnet module
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Brandon Shutter thanks! Have you looked at this working example https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/main.tf
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and test for the example https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/test/src/examples_complete_test.go
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I believe you are talking about these tags https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/main.tf#L19 (shared
is required by EKS)
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
2019-10-22
data:image/s3,"s3://crabby-images/70bc7/70bc76aeb36c3c4f22d0a1b714f4b65caa416111" alt="Taras avatar"
Hi guys,
Have just installed AWS EKS + autoscaller. All seem to be good except autoscaler failing with the error as follow:
E1021 18:40:49.320402 1 aws_manager.go:148] Failed to regenerate ASG cache: cannot autodiscover ASGs: RequestError: send request failed
caused by: Post <https://autoscaling.eu-west-2.amazonaws.com/>: dial tcp: i/o timeout
F1021 18:40:49.320431 1 aws_cloud_provider.go:330] Failed to create AWS Manager: cannot autodiscover ASGs: RequestError: send request failed
caused by: Post <https://autoscaling.eu-west-2.amazonaws.com/>: dial tcp: i/o timeout
Not sure why it can’t reach internal AWS’s API service.
Autoscaller has been successfully installed using helm
. Hence there is connectivity on the worker node.
Any advices of what else shall I check?
data:image/s3,"s3://crabby-images/70bc7/70bc76aeb36c3c4f22d0a1b714f4b65caa416111" alt="Taras avatar"
ok. Resolved. dnsPolicy changed to Default and that is it.
data:image/s3,"s3://crabby-images/70bc7/70bc76aeb36c3c4f22d0a1b714f4b65caa416111" alt="Taras avatar"
Now another issue is that new nodes can’t attach to the cluster:
27s Warning ScaleUpTimedOut configmap/cluster-autoscaler-status Nodes added to group londynek-02019102113431054090000000e failed to register within 5m5.36167321s
data:image/s3,"s3://crabby-images/70bc7/70bc76aeb36c3c4f22d0a1b714f4b65caa416111" alt="Taras avatar"
Ok. Resolved. Some subnets I put workers could not communicate to EKS cluster.
2019-10-23
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
does anyone have an elegant solution to applying the stupid eks aws-auth config map via terraform without using a public endpoint on eks (and without being inside the vpc)? - i’m pretty sure this is pretty much technically impossible
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
using atlantis running in the vpc (or peer vpc), you can accomplish it.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we run atlantis inside of ECS fargate for this reason
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but if the requirement is to apply it without being inside and without being outside, maybe look into aws ssm agent?
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
yeh - it’s a frustrating requirement in that i want to be able to stand up the environment and hook up roles so that things within that environment can manage itself and connect everything - but i can’t set up access to the cluster without being able to connect to the cluster. it would be nice if eks could bootstrap the rbac config on cluster creation or you could pass through a cluster admin role arn rather than just granting system:master to the user that created the cluster
data:image/s3,"s3://crabby-images/9f7d3/9f7d37e6df4fb280d718c728e563fdba7ce5b9ba" alt="Chris Fowles avatar"
hopefully that’s on the roadmap somewhere
2019-10-25
data:image/s3,"s3://crabby-images/e83c4/e83c40e32c930ec41e7d7264b0dacc7db86b492a" alt="Jord avatar"
Thanks @Erik Osterman (Cloud Posse) for the invite
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Welcome @Jord!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hey everyone! @Jord has a really neat product for learning kubernetes.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Clearly a lot of thought has gone into this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Magic Sandbox is a hands-on learning platform for engineers, by engineers. Immersive Kubernetes training on real infrastructure where engineering teams learn from hands-on Kubernetes training on real infra.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/e83c4/e83c40e32c930ec41e7d7264b0dacc7db86b492a" alt="Jord avatar"
Thanks for the shout out - if you have any Qs just DM me or mail me at [email protected]
data:image/s3,"s3://crabby-images/7ea5f/7ea5f70bdb93bba776de821d2db0322f62735cda" alt="Hasan avatar"
I like MSB
2019-10-28
2019-10-29
data:image/s3,"s3://crabby-images/7066b/7066b71236984745fac2e8a96ec5cc35585a793c" alt="Barani avatar"
Hi I need a help on creating configmap. resource “kubernetes_config_map” “env” { metadata { name =”tf-${var.project}-${var.component}-env” namespace = “${var.namespace}”
labels = { app = “tf-${var.project}-${var.component}” } }
data = { MINIO_ACCESS_KEY=”minio” MINIO_SECRET_KEY=”minio123” }
}
In the above I want to declare the values of data as variable and change it as per environment
.I am not able to declare it as string. Can someone please assist
variable “env_values” { type = string
} env_values = “MINIO_ACCESS_KEY="minio" \nMINIO_SECRET_KEY="minio123"”
I tried many possible combination but nothing works I tried using a file to declare all env variables and it worked but Minio is not picking the username in that way
data:image/s3,"s3://crabby-images/7066b/7066b71236984745fac2e8a96ec5cc35585a793c" alt="Barani avatar"
Kindly give a suggestion