Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/amartingarcia/github-runner-aws-ec2
POC to integrate Github Actions and AWS EC2 with Github OIDC
https://github.com/amartingarcia/github-runner-aws-ec2
aws-ec2 github-actions github-oidc
Last synced: 4 months ago
JSON representation
POC to integrate Github Actions and AWS EC2 with Github OIDC
- Host: GitHub
- URL: https://github.com/amartingarcia/github-runner-aws-ec2
- Owner: amartingarcia
- Created: 2024-07-31T13:07:01.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-31T14:28:48.000Z (7 months ago)
- Last Synced: 2024-10-12T23:43:13.420Z (4 months ago)
- Topics: aws-ec2, github-actions, github-oidc
- Language: HCL
- Homepage:
- Size: 2.09 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# github-runner-aws-ec2
This repository allows you to configure an AWS account and a GitHub repository to create an AWS EC2 Instance and use it as a GitHub runner during the execution of the Workflow, using the action [aws-actions/configure-aws-credentials](https://github.com/aws-actions/configure-aws-credentials):
This demo covers two cases: authentication with AWS via Access Key and Secret Key, and authentication with OIDC.
In both cases, you will first need a GitHub PAT with full `repo` permissions.
Next, create a `terraform.tfvars` file in the `terraform` directory with the following details:
```bash
region = "" # AWS region
access_key = "" # Access key of an admin user in AWS
secret_key = "" # Secret key of an admin user in AWS
github_repository = "" # Name of the GitHub repository
github_token = "" # PAT for your repository with repo scope
aws_subnet_id = "" # Subnet ID where you will deploy your runners
vpc_id = "" # VPC ID where you want to deploy your runners
```The links I used as a reference are as follows:
* Access key and secret key -> https://github.com/marketplace/actions/on-demand-self-hosted-aws-ec2-runner-for-github-actions
* OIDC -> https://aws.amazon.com/blogs/security/use-iam-roles-to-connect-github-actions-to-actions-in-aws/Check the files:
* [runner-ec2.yaml](.github/workflows/runner-ec2.yml) to understand this scenario.
* [runner-oidc.yaml](.github/workflows/runner-oidc.yml) to understand this scenario.Also, review the Terraform files. Afterward, run terraform apply.
Once applied, add the changes to your repository and check that both pipelines are running correctly.
## Access key y Secret key
### Start instance
data:image/s3,"s3://crabby-images/c84c7/c84c712b8bdc15e9b33db00d4177b8f57907ef13" alt=""### Ec2 console
data:image/s3,"s3://crabby-images/5428d/5428ddde4b7778cd83493e14744b603c7437f6f8" alt=""### Run command
data:image/s3,"s3://crabby-images/96379/963795cbf16b1e6a249bf650c656a187c5dbd2c6" alt=""### Stop instance
data:image/s3,"s3://crabby-images/65d57/65d57dd1ddfdb9fea78085a2dc3b8502d8bcd97b" alt=""## Con OIDC
### Start instance
data:image/s3,"s3://crabby-images/83585/835855a29766c48c09bfc711662a72aa5bfcf3c2" alt=""### Ec2 console
data:image/s3,"s3://crabby-images/98a25/98a25f66640e7b7a75e84f549d039f7421cf043b" alt=""### Run command
data:image/s3,"s3://crabby-images/91129/91129b4c665ca3b5b2040eb6879f43074eea3d24" alt=""### Stop instance
data:image/s3,"s3://crabby-images/5b365/5b365a9d7a3408d40e2c1415935aee382c3ded72" alt=""