#refarch (2023-07)
Cloud Posse Reference Architecture
2023-07-01
data:image/s3,"s3://crabby-images/ff022/ff022dd1b46550983f1f5967081280e82814f5cd" alt="Abra avatar"
I am using leapp for my aws profiles management, i want to SSM to instance with profile but i need to pass a document something like this:
aws ssm start-session --target INSTANCE_ID --document-name AWS-StartPortForwardingSessionToRemoteHost --parameters=portNumber=443,localPortNumber=443,host=REMOTE_HOST
anyway I can achieve this with leapp?
2023-07-19
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Is there a way to define an optional github runner that’s started on demand via a label like:
runs-on:
group: <name>
labels: m6a.2xlarge
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
for context, i know we can request a specific instance with a label.
the core question here is if the runner could intelligently start a specific instance type
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
at this time i see it is not starting the desired instance. it is just spinning on github waiting for a runner
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
along these lines, could we have a separate group with min_size: 0
that is only used on demand?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
my goal is to have an instance for automation tests (high memory) ready on request, but not always around to save money.
it seems we’d have to have a high capacity instance always around
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
any thoughts @Dan Miller (Cloud Posse)?
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
we have two different methods of creating self-hosted runners – github-runners
and eks/actions-runner-controller
. The github-runners
component is just an ASG, so it’s not as intelligent, whereas the eks/actions-runner-controller
is built on EKS so it has a lot more features
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
with eks/arc
you can have a runner type that can dynamically launch like this
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
thought so
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
whereas with github-runners
, you may need to simply deploy an additional ASG for your optional runner type
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
but with that we’d have to keep 1 instance always around, right?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
or if we say 0, it would trigger the creation of 1?
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
yes I believe the min is 1
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
random thought, what about a GH step that triggers the creation of the desired instance?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
hacky, but would save costs
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
that could probably work too, but it would take a bit for the runner to initialize of course
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
right. initialize 1 (maybe), start new one, it initializes, then things run
data:image/s3,"s3://crabby-images/b89b6/b89b61e7c22a055ce842ff937998367ce3e5b5e0" alt="Dan Miller (Cloud Posse) avatar"
yup
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also, without moving to Kubernetes, you may want to consider https://github.com/philips-labs/terraform-aws-github-runner
Terraform module for scalable GitHub action runners on AWS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We haven’t had a chance to invest in it, as the simple ASG approach seems to work for most. But on EKS, we do a lot of the things you want to do, as it’s natively supported by the official github actions runner controller.