You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardExpand all lines: content/learning-paths/servers-and-cloud-computing/circleci-gcp/_index.md
+1-2Lines changed: 1 addition & 2 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -7,7 +7,7 @@ cascade:
7
7
8
8
minutes_to_complete: 45
9
9
10
-
who_is_this_for: This learning path is intended for software developers and DevOps engineers looking to set up and run CircleCI Arm native workflows on SUSE Linux Arm64 VMs, specifically on Google Cloud C4A with Axion processors, using self-hosted runners.
10
+
who_is_this_for: This is an introductory topic for software developers and DevOps engineers looking to set up and run CircleCI Arm native workflows on SUSE Linux Arm64 VMs, specifically on Google Cloud C4A with Axion processors, using self-hosted runners.
11
11
12
12
learning_objectives:
13
13
- Provision a SUSE Arm64 virtual machine on Google Cloud (C4A with Axion processors)
Copy file name to clipboardExpand all lines: content/learning-paths/servers-and-cloud-computing/circleci-gcp/background.md
+4-4Lines changed: 4 additions & 4 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -16,10 +16,10 @@ To learn more about Google Axion, refer to the [Introducing Google Axion Process
16
16
17
17
## CircleCI
18
18
19
-
CircleCI is a cloud-based **Continuous Integration and Continuous Delivery (CI/CD)** platform that automates the process of **building, testing, and deploying software**.
19
+
CircleCI is a cloud-based Continuous Integration and Continuous Delivery (CI/CD) platform that automates the process of building, testing, and deploying software.
20
20
21
-
It integrates with popular version control systems like **GitHub**, **Bitbucket**, and **GitLab**, and allows developers to define custom workflows in a `.circleci/config.yml` file using **YAML syntax**.
21
+
It integrates with popular version control systems like GitHub, Bitbucket, and GitLab, and allows developers to define custom workflows in a `.circleci/config.yml` file using the YAML syntax.
22
22
23
-
CircleCI supports multiple environments, including **Docker**, **Linux**, **macOS**, and **Windows**, and offers advanced features like **parallelism**, **caching**, and **matrix builds** to speed up pipelines and improve efficiency.
23
+
CircleCI supports multiple platforms, including Linux, macOS, and Windows, and offers advanced features like parallelism, caching, and matrix builds to speed up pipelines and improve efficiency.
24
24
25
-
It is widely used for **automating tests, running builds, deploying applications, and ensuring code quality** in modern development workflows. Learn more from the [CircleCI official website](https://circleci.com/) and its [documentation](https://circleci.com/docs/).
25
+
It is widely used for automating tests, running builds, deploying applications, and ensuring code quality in modern development workflows. Learn more from the [CircleCI official website](https://circleci.com/) and its [documentation](https://circleci.com/docs/).
Copy file name to clipboardExpand all lines: content/learning-paths/servers-and-cloud-computing/circleci-gcp/circleci-arm64-cloud-demo.md
+99-50Lines changed: 99 additions & 50 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -6,69 +6,97 @@ weight: 8
6
6
layout: learningpathall
7
7
---
8
8
9
-
## Deploying a Cloud-Native Arm64 Node.js App using self-hosted CircleCI Runner on GCP
9
+
## Deploying a Cloud-Native Arm64 Node.js App Using a Self-Hosted CircleCI Runner on GCP
10
10
11
-
This guide walks through building and testing a simple **Node.js web app** using a **self-hosted CircleCI Arm64 runner**on a **GCP SUSE Arm64 VM**.
11
+
This section demonstrates how to build and test a simple Node.js web application using a self-hosted CircleCI runner running on a Google Cloud C4A (Axion Arm64) SUSE Linux virtual machine.
12
12
13
+
You’ll configure Docker on the VM so that CircleCI jobs can build, test, and run containerized applications directly in your Arm64 environment, ideal for cloud-native development and CI/CD workflows targeting Arm architecture.
13
14
14
-
### Install and Configure Docker
15
-
Ensure Docker is installed, started, and accessible by both your user and the CircleCI runner service.
16
15
17
-
-**Install Docker**: Refresh your package manager and install Docker on your system.
18
-
-**Enable Docker Service**: Ensure Docker starts on boot and is running.
19
-
-**Add User to Docker Group**: Add both your user and the CircleCI runner to the Docker group to grant access.
16
+
### Install and Configure Docker
17
+
Ensure Docker is installed, enabled, and accessible by both your local user and the CircleCI runner service.
20
18
21
-
```console
19
+
1. Install Docker
20
+
Refresh your package manager and install Docker on your system:
21
+
```bash
22
22
sudo zypper refresh
23
23
sudo zypper install docker
24
+
```
25
+
2. Enable and start Docker service
26
+
Set Docker to start automatically at boot and verify it’s running:
27
+
```bash
24
28
sudo systemctl enable docker
25
29
sudo systemctl start docker
26
30
sudo systemctl status docker
31
+
```
32
+
3. Grant Docker access to users
33
+
Add both your current user and the circleci system user to the Docker group so they can run Docker commands without sudo:
34
+
```bash
27
35
sudo usermod -aG docker $USER
28
36
sudo usermod -aG docker circleci
29
37
```
30
38
### Validate Docker access
31
-
This command switches to the CircleCI user and checks if Docker is working correctly.
39
+
After installing Docker and adding the circleci user to the Docker group, verify that the CircleCI runner user can access Docker without requiring elevated privileges.
32
40
33
-
```console
41
+
Run the following commands:
42
+
```bash
34
43
sudo -u circleci -i
35
44
docker ps
36
45
exit
37
46
```
38
47
39
48
### Verify Docker Permissions
40
-
Check Docker socket permissions and ensure that the CircleCI runner is active and running.
49
+
Now, confirm that Docker’s socket permissions and the CircleCI runner service are both configured correctly.
41
50
42
-
```console
51
+
```bash
43
52
ls -l /var/run/docker.sock
44
53
ps -aux | grep circleci-runner
45
54
```
46
-
-**Check Docker Socket Permissions**: This command ensures the Docker socket is accessible.
47
-
-**Verify CircleCI Runner Process**: Confirm the CircleCI runner service is active and running.
55
+
These commands ensure that the Docker socket is accessible and the CircleCI runner service is active and running.
48
56
49
-
### **Install Node.js and npm**
57
+
Once both checks pass, your environment is ready to build and run container-based pipelines with CircleCI on SUSE Arm64.
50
58
51
-
Before proceeding with the app setup, please make sure **Node.js** and **npm** (Node.js package manager) are installed on the VM, as they are required to run your Node.js app.
59
+
### Install Node.js and npm
52
60
53
-
-**Install Node.js**: Use the official Node.js package for Arm64 architecture.
54
-
-**Install npm**: npm is automatically installed when Node.js is installed.
61
+
Before setting up the sample application, ensure that `Node.js` and its package manager `npm` are installed on your SUSE Arm64 VM. Both are required to run, build, and test the `Node.js` web application within your CircleCI pipeline.
62
+
63
+
- Install Node.js: Install the official Node.js package built for the Arm64 architecture.
64
+
- Install npm: npm (Node Package Manager) is bundled with Node.js but can also be explicitly installed or upgraded if needed.
55
65
56
66
```console
57
67
sudo zypper install nodejs
58
68
sudo zypper install npm
59
69
```
60
-
### Clone Your App Repository
61
-
Clone your application repository (or create one locally):
70
+
Next, you’ll create the demo project and prepare its CircleCI configuration to run jobs using your self-hosted Arm64 runner.
71
+
72
+
### Create a repository for your example code
73
+
To store and manage your Node.js demo application, you’ll create a new GitHub repository using the GitHub CLI.
74
+
75
+
1. Install the GitHub CLI
76
+
The GitHub CLI (gh) lets you manage repositories, issues, and pull requests directly from your terminal.
77
+
78
+
```bash
79
+
sudo zypper install -y gh
80
+
```
81
+
2. Authenticate with GitHub
82
+
Run the following command to connect the CLI to your GitHub account:
83
+
84
+
```bash
85
+
gh auth login
86
+
```
87
+
88
+
3. Create a New Repository
89
+
Create a new public repository for your demo project and clone it locally:
In the root of your project, create a `Dockerfile`that defines how to build and run your application container.
97
+
In the root of your project, create a file named `Dockerfile`to define how your `Node.js` application container will be built and executed.
70
98
71
-
```dockerfile
99
+
```console
72
100
# Dockerfile
73
101
FROM arm64v8/node:20-alpine
74
102
WORKDIR /app
@@ -78,13 +106,18 @@ COPY . .
78
106
EXPOSE 3000
79
107
CMD ["npm", "start"]
80
108
```
81
-
-**Use Arm64 Node.js Image**: The `arm64v8/node` image is specifically designed for Arm64 architecture.
82
-
-**Install Dependencies**: `RUN npm install` installs the project dependencies listed in `package.json`.
83
-
-**Expose Port**: The app will run on port 3000.
84
-
-**Start the App**: The container will execute `npm start` to launch the Node.js server.
109
+
Breakdown of the Dockerfile:
110
+
111
+
- Uses Arm64 Node.js Image: The `arm64v8/node` image is specifically designed for Arm64 architecture.
112
+
- Install Dependencies: `RUN npm install` installs the project dependencies listed in `package.json`.
113
+
- Expose Port: The app will run on port 3000.
114
+
- Start the App: The container will execute `npm start` to launch the Node.js server.
115
+
116
+
Next, you’ll add the application code and a `.circleci/config.yml` file to automate the build and test pipeline using your self-hosted Arm64 runner.
85
117
86
118
### Add a CircleCI Configuration
87
-
Create a `.circleci/config.yml` file to define the CircleCI pipeline for building and testing your Node.js app on Arm64 architecture.
119
+
Create a configuration file that defines your CircleCI pipeline for building, running, and testing your Node.js app on Arm64 architecture.
120
+
In the root of your project, create a folder named `.circleci` and inside it, add a file called `config.yml` with the contents below:
88
121
89
122
```yaml
90
123
version: 2.1
@@ -124,14 +157,17 @@ workflows:
124
157
jobs:
125
158
- arm64-demo
126
159
```
127
-
- **arm64-demo Job**: This job checks if the architecture is Arm64, builds the Docker image, runs it in a container, and tests the app endpoint.
128
-
- **resource_class**: Specify the resource class for the CircleCI runner (e.g., a custom Arm64 runner if using self-hosted).
129
-
- **Test Endpoint**: The job sends a request to the app to verify it’s working.
160
+
161
+
Explanation of the yaml file:
162
+
163
+
- arm64-demo Job: This job checks if the architecture is Arm64, builds the Docker image, runs it in a container, and tests the app endpoint.
164
+
- resource_class: Specify the resource class for the CircleCI runner (e.g., a custom Arm64 runner if using self-hosted).
165
+
- Test Endpoint: The job sends a request to the app to verify it’s working.
130
166
131
167
### Node.js Application
132
-
Here’s the basic code for the Node.js app.
168
+
Create the application files in your repository root directory for the Node.js app.
133
169
134
-
`index.js`:
170
+
Use a file editor of your choice and copy the contents shown below into a file named `index.js`:
135
171
136
172
```javascript
137
173
const express = require('express');
@@ -146,7 +182,8 @@ app.listen(PORT, () => {
146
182
console.log(`Server running on port ${PORT}`);
147
183
});
148
184
```
149
-
package.json
185
+
186
+
Now copy the content below into a file named `package.json`:
150
187
151
188
```json
152
189
{
@@ -162,53 +199,65 @@ package.json
162
199
}
163
200
}
164
201
```
165
-
-**Express Server**: The application uses Express.js to handle HTTP requests and respond with a simple message.
166
-
-**Package Dependencies**: The app requires the `express` package for handling HTTP requests.
202
+
- Express Server: The application uses Express.js to handle HTTP requests and respond with a simple message.
203
+
- Package Dependencies: The app requires the `express` package for handling HTTP requests.
167
204
168
205
### Push Code to GitHub
169
206
170
-
Once all files (`Dockerfile`, `index.js`, `package.json`, `.circleci/config.yml`) are ready, push your project to GitHub so CircleCI can build it automatically.
207
+
Now that all project files (Dockerfile, index.js, package.json, and .circleci/config.yml) are ready, push the code to GitHub.
208
+
This allows CircleCI to automatically detect the repository and trigger your Arm64 build pipeline using the self-hosted runner.
209
+
210
+
Configure Git username and add and commit project files:
-**Add and Commit Changes**: Stage and commit your project files.
178
-
-**Push to GitHub**: Push your code to the GitHub repository so that CircleCI can trigger the build.
218
+
You have pushed your code to the GitHub repository so that CircleCI can trigger the build.
179
219
180
220
### Start CircleCI Runner and Execute Job
181
-
Ensure that your CircleCI runner is enabled and started. This will allow your self-hosted runner to pick up jobs from CircleCI.
221
+
Before triggering your first workflow, ensure that the CircleCI runner service is enabled and running on your SUSE Arm64 VM. This will allow your self-hosted runner to pick up jobs from CircleCI.
182
222
183
-
```console
223
+
```bash
184
224
sudo systemctl enable circleci-runner
185
225
sudo systemctl start circleci-runner
186
226
sudo systemctl status circleci-runner
187
227
```
188
-
-**Enable CircleCI Runner**: Ensure the CircleCI runner is set to start automatically on boot.
189
-
-**Start and Check Status**: Start the CircleCI runner and verify it is running.
228
+
- Enable CircleCI Runner: Ensures the runner service starts automatically on system boot.
229
+
- Start and Check Status: Starts the CircleCI runner and verifies it is running.
230
+
190
231
191
-
After pushing your code to GitHub, open your **CircleCI Dashboard → Projects**, and confirm that your **ARM64 workflow** starts running using your **self-hosted runner**.
232
+
### Verify Job Execution in CircleCI
233
+
234
+
After pushing your code to GitHub, open your CircleCI Dashboard → Projects, and confirm that your Arm64 workflow starts running using your self-hosted runner.
192
235
193
236
If the setup is correct, you’ll see your job running under the resource class you created.
194
237
195
238
### Output
196
-
Once the job starts running, CircleCI will:
239
+
When the CircleCI workflow starts running on your self-hosted Arm64 runner, you’ll see the following stages executed in your CircleCI Dashboard:
197
240
198
-
- Detect the ARM64 architecture.
241
+
1. Detect the ARM64 Architecture
242
+
CircleCI confirms the job is executing on your Arm64 self-hosted runner. This validates that the pipeline is correctly targeting your Google Cloud C4A (Axion) VM.
199
243
200
244

201
245
202
-
- Build the Docker image.
246
+
2. Build the Docker image
247
+
The runner builds the `arm64-node-demo` Docker image using the Dockerfile you defined.
If the app responds successfully, the test confirms that the Node.js web server is running correctly inside the container.
213
260
214
261
If successful, you will see your CircleCI job running and the app deployed in the CircleCI Dashboard.
262
+
263
+
This demonstrates an end-to-end cloud-native CI/CD workflow running natively on SUSE Arm64 with Google Cloud C4A (Axion) as a self-hosted runner on CircleCI.
Copy file name to clipboardExpand all lines: content/learning-paths/servers-and-cloud-computing/circleci-gcp/create_resource_class.md
+18-16Lines changed: 18 additions & 16 deletions
Display the source diff
Display the rich diff
Original file line number
Diff line number
Diff line change
@@ -7,36 +7,38 @@ layout: learningpathall
7
7
---
8
8
9
9
## Create a Resource Class for Self-Hosted Runner in CircleCI
10
-
This guide explains how to create a **Resource Class** in the **CircleCI Web Dashboard** for a **self-hosted runner**.
11
-
A Resource Class defines a unique identifier for your runner and links it to your CircleCI namespace, allowing CircleCI jobs to targetyour custom machine environment.
10
+
This section explains how to create a Resource Class in the CircleCI Web Dashboard for a self-hosted runner.
11
+
A Resource Class is a unique identifier that links your self-hosted runner to your CircleCI organization (namespace). It defines the “machine type” that CircleCI jobs can target, ensuring that only authorized jobs run on your managed infrastructure, in this case, your SUSE Linux Arm64 VM on Google Cloud C4A (Axion).
12
12
13
13
### Steps
14
14
15
-
1.**Go to the CircleCI Web Dashboard**
16
-
- From the left sidebar, navigate to **Self-Hosted Runners**.
17
-
- You’ll see a screen asking you to accept the **terms of use**.
18
-
-**Check the box** that says **“Yes, I agree to the terms”** to enable runners.
19
-
- Then click **Self-Hosted Runners** to continue setup.
15
+
1. Open the CircleCI Web Dashboard
16
+
- Login or Create a new account at [CircleCI](https://app.circleci.com/home)
17
+
- In the left-hand navigation panel, click Self-Hosted Runners.
18
+
- If this is your first time setting up runners, you’ll be prompted to accept the Terms of Use.
19
+
Check “Yes, I agree to the terms” to enable runner functionality for your organization.
20
+
- After accepting, click Self-Hosted Runners again to continue the setup process.
Click **Create Resource Class** on your CircleCI dashboard.
26
+
On your CircleCI Dashboard, click Create Resource Class.
26
27
27
-
**Fill in the following details:**
28
+
Fill in the following details:
28
29
29
-
-**Namespace:** Your CircleCI username or organization name (e.g., `circleci`)
30
-
-**Resource Class Name:** A clear, descriptive name for your runner (e.g., `arm64`)
31
-
- Click **Create Resource Class**.
30
+
*Namespace: Your CircleCI organization or username (e.g., circleci)
31
+
*Resource Class Name: A clear, descriptive identifier for your runner (e.g., arm64)
32
+
* Once complete, click Create Resource Class to generate it.
32
33
33
34

34
35
35
36

36
37
37
-
3.**Save and Copy the Token**
38
-
- Once created, CircleCI will generate a **Resource Class Token**.
39
-
- Copy this token and store it securely — you will need it to register your runner on the GCP VM.
38
+
3. Save and Copy the Token
39
+
40
+
After creating the resource class, CircleCI automatically generates a Resource Class Token, a secure authentication key used to register your runner. Copy this token immediately and store it in a secure location.
41
+
You’ll need this token in the next step to connect your SUSE Arm64 runner on the Google Cloud C4A (Axion) VM to CircleCI.
40
42
41
43

0 commit comments