Documentation structure for LLMs (llms.txt)

Using the Linux VM execution environment

Cloud Server v4+

Using the machine executor gives your application full access to OS resources and provides you with full control over the job environment. This control can be useful when you need full access to the network stack. For example, you can listen on a network interface or modify the system with sysctl commands.

To use the machine executor, use the machine key in your job configuration and specify an image:

The use of machine: true is deprecated when using CircleCI Cloud. You must specify an image to use.

machine: true is supported when using:

  • Self-hosted runners

  • When using the machine executor on CircleCI Server.

  • Cloud

  • Server

version: 2.1
jobs:
  my-job:
    machine:
      image: ubuntu-2404:current
    resource_class: large.gen2
version: 2.1
jobs:
  my-job:
    machine: true
    resource_class: large

You can view the list of available images in the Configuration Reference, or on the Developer Hub. If you are working on an installation of CircleCI Server, the syntax is slightly different. The available Linux images are managed by your system administrator.

Available LinuxVM resource classes

Gen1

Class vCPUs RAM Disk Size Cloud Server

medium

2

7.5 GB

150GB

Yes

Yes

large

4

15 GB

150GB

Yes

Yes

xlarge

8

32 GB

150GB

Yes

Yes

2xlarge

16

64 GB

150GB

Yes

Yes

2xlarge+

32

64 GB

150GB

Yes

Yes

Gen2

Class vCPUs RAM Disk Size Cloud Server

medium.gen2

2

8 GiB

150GB

Yes

No

large.gen2

4

16 GiB

150GB

Yes

No

xlarge.gen2

8

32 GiB

150GB

Yes

No

2xlarge.gen2

16

64 GiB

150GB

Yes

No

2xlarge+.gen2

32

128 GiB

150GB

Yes

No

View resource usage

To view the compute resource usage for the duration of a job in the CircleCI web app:

  1. In the CircleCI web app, select your org from the org cards on your user homepage.

  2. Select Pipelines from the sidebar and locate your pipeline from the list. You can use the project, branch, date, and status search options to help.

  3. Select the job you want to access by selecting the job name.

  4. Select the Resources tab to view CPU and RAM usage for the duration of the job.

You can use these insights to decide whether to make changes to the job’s configured resource class.

Resources tab
Figure 1. Resources tab in web app for a job

Linux VM gen2

Resource classes running on gen2 infrastructure offer significant performance and cost improvements over their gen1 equivalents.

Performance improvements

Using more modern compute, gen2 instances deliver up to 180% faster multi-threaded CPU performance compared to gen1 equivalents.

These improvements are most noticeable in workloads that saturate multiple cores simultaneously. For example, parallel test runs, compilation steps, and image builds. On a per-resource-class basis, gen2 can be priced either higher or lower than its gen1 equivalent. See our Pricing Page for details.

Using gen2

To use a gen2 resource class, specify a large.gen2 or equivalent class in your job configuration:

version: 2.1
jobs:
  my-job:
    machine:
      image: ubuntu-2404:current
    resource_class: large.gen2

Pre-installed software

The most up-to-date list of pre-installed software can be found on the Discuss page.

If you are already using an image, you can verify all the packages that come pre-installed. Run the apt list --installed command as a step, like in the example below:

version: 2.1
...
jobs:
  whats-installed:
    machine: # executor type
      image: ubuntu-2404:current
    steps:
      - run: apt list --installed
...

Additional packages can be installed with sudo apt-get install <package>. If the package in question is not found, sudo apt-get update may be required before installing it.

Use machine with Docker

Using the machine executor also means that you get full access to the Docker process. This allows you to run privileged Docker containers and build Docker images.

The following example uses an image and enables Docker Layer Caching (DLC) which is useful when you are building Docker images during your jobs.

machine:
  image: ubuntu-2404:current
  docker_layer_caching: true    # default - false

Using machine and IP ranges

The IP range 192.168.53.0/24 is reserved by CircleCI for internal use on the machine executor. Do not use this range in your jobs.

Next steps

To find out about migrating a project from using the Docker executor to using machine, see the Executor Migration from Docker to Machine document.