Step-by-Step Guide: Setting Up GitLab Runner on AWS
data:image/s3,"s3://crabby-images/38e5b/38e5b8ab95b3e0cd6f2d954980606bca11c121c0" alt="Step-by-Step Guide: Setting Up GitLab Runner on AWS for Optimal Performance"
Introduction:
Meetix GitLab Auto Scaling Runner enables you to automatically scale your CI/CD infrastructure based on workload demands, ensuring smooth and cost-effective pipeline execution.
Prerequisites:
Before you begin, make sure you meet the following prerequisites:
- Basic AWS Knowledge: Familiarity with AWS services, EC2 instances, and AWS Identity and Access Management (IAM) is required.
- GitLab & CI/CD Knowledge: Understanding of GitLab CI/CD concepts, including runners, pipelines, and jobs.
Create GitLab token:
- Navigate to your GitLab project.
- Go to "Settings" and select "CI/CD".
- Within the "CI/CD Settings," locate and expand the "Runners" section.
- Click on "New Project Runner". On the "New Project Runner" page.
data:image/s3,"s3://crabby-images/04266/042668bfc59e9bde73a9ccfbab19334a07ef6397" alt=""
Provide the following details:
- Operating System: Linux
- Check the box for "Run untagged jobs" in Tags.
data:image/s3,"s3://crabby-images/8f5a7/8f5a7b83d0c9de5de620f8a0ef0534d162197f5c" alt=""
- Add a "Runner Description".
- Unselect "Paused", "Protected" and "Lock to current projects".
data:image/s3,"s3://crabby-images/3d8b2/3d8b2d59fec7b7611fad3dc9dd44de733ae11dde" alt=""
- Enter a maximum job timeout (recommended: 1800 seconds).
5. Finally, click the "Create Runner" button. You will receive an alert confirming the runner's creation.
6. Copy the "runner token" for later use.
data:image/s3,"s3://crabby-images/b3a47/b3a472434d7fdfbfa5d04d15c735a1a1104ed6a6" alt=""
These steps will allow you to create a GitLab token, which is essential for configuring your GitLab Runner in the setup process.
Launching the AMI:
Find and Launch the AMI:
- Visit the AWS Marketplace "Gitlab autoscaling runner for CI/CD by meetrix"
- Click "Continue to Subscribe" to begin the subscription process.
- After subscribing, you will need to accept the terms and conditions. Click on "Accept Terms" to proceed.
data:image/s3,"s3://crabby-images/90c68/90c68d8d43a5fe810a3b6e6c9bd7ac4975609776" alt=""
- Please wait for a few minutes while the processing takes place. Once it's completed, click on "Continue to Configuration" to customize the instance according to your specific requirements.
data:image/s3,"s3://crabby-images/3f490/3f4904bad7a6b693cdeafbadfe8548312eed2fbf" alt=""
Initial Setup & Configuration:
- Select your prefered region in "Configure this software" page and click "Continue to Launch" button.
- Select "Launch CloudFormation" in "Choose Action".
- Click "Launch" button.
Create Stack:
Step1: Create stack
- Ensure the "Template is ready" radio button is selected under "Prepare template".
click "Next"
Step2: Specify stack options
- Provide a unique "Stack name".
- For "DeploymentName", enter a name of your choice.
- Select your preferred "keyName".
- Choose an instance type (Recommended: t3.medium).
- Paste the copied "GitLab Runner token" in the "RunnerToken" field.
- Set "SSHLocation" as "0.0.0.0/0."
- Click "Next."
Step3: Configure stack options
- Under stack failure options, select "Roll back all stack resources".
- click "Next"
Step4: Review
- Review and verify the details you've entered.
data:image/s3,"s3://crabby-images/51ade/51ade6466b399a710cd00e501593dfb407b77656" alt=""
- Tick the box that says, "I acknowledge that AWS CloudFormation might create IAM resources with custom names".
data:image/s3,"s3://crabby-images/db3f4/db3f486b84e7316e024c9de5ef06a00e4fdb1980" alt=""
- click "Submit".
Afterward, you'll be directed to the CloudFormation stacks page.
You can easily locate the corresponding stack by searching for the stack name you entered in Step 2.
data:image/s3,"s3://crabby-images/e5d1a/e5d1a6f06212eeab19620658ced25f5fae63d786" alt=""
The stack will be successfully created in a few minutes.
Run pipeline:
To verify the GitLab Runner, follow these steps:
- Go to your GitLab project.
- Settings CI/CD > expand runners.
- Disable shared runners.
data:image/s3,"s3://crabby-images/2e0fb/2e0fb7b652feb1c3cf5fd1483bce290bf9fe5699" alt=""
- Click on "Pipelines" under "Build."
- Select "Run pipeline".
- In the "Run Pipeline" page, choose the branch name as "master" or your preferred branch.
- Click the "Run pipeline" button.
data:image/s3,"s3://crabby-images/561bd/561bdf84e2f4b8ce76ba1a89ba5b5ea88165c564" alt=""
The pipeline will run successfully in a few minutes.
data:image/s3,"s3://crabby-images/551cd/551cd788f164ff5c0044f5638960abfb821591bd" alt=""
Troubleshooting & Common Issues:
Common Problems | Resolutions |
---|---|
Runner not picking up jobs. | Double-check runner registration and configuration. |
Permission issues on the EC2 instance. | Review IAM roles and permissions. |
Network connectivity problems. | Verify network settings and security groups. |
Shutting Down & Relaunching:
Shutting Down the Runner:
- Ensure all running jobs are completed.
- Click "Remove runner" button of the created project runner in runners in cicd settings
- Delete the created stack in the AWS Management Console under CloudFormation Stacks.
Technical Support:
- Reach out to Meetrix Support (support@meetrix.io) for assistance with GitLab runner issues.