Skip to main content

CDK Construct for creating an Amazon Linux EC2 instance with pre-installed software

Project description

CDK Preinstalled Amazon Linux EC2 Instance Construct

This is a CDK Construct for creating a preinstalled AmazonLinux EC2 instance.

You can use Node.js, Visual Studio Code, git and other software as soon as the EC2 instance starts.

View on Construct Hub

Open in Visual Studio Code npm version Build Status Release Status License npm downloads

Usage

Install the package:

npm install cdk-preinstalled-amazon-linux-ec2

Use it in your CDK stack:

import { PreinstalledAmazonLinuxInstance } from 'cdk-preinstalled-amazon-linux-ec2';
import * as ec2 from 'aws-cdk-lib/aws-ec2';

declare const vpc: ec2.IVpc;

// You can configure all properties of the EC2 instance
new PreinstalledAmazonLinuxInstance(this, 'Instance', {
  vpc,
  instanceType: ec2.InstanceType.of(ec2.InstanceClass.T3, ec2.InstanceSize.NANO),
  machineImage: new ec2.AmazonLinuxImage({
    generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2023,
  }),
  // Specify preinstalled software
  preinstalledSoftware: {
    packages: [
      PreinstalledSoftwareType.NODEJS,
      PreinstalledSoftwareType.VSCODE,
      PreinstalledSoftwareType.GIT,
    ],
    others: ['rsyslog'], // You can specify other software packages. These parameters are used as `sudo dnf install ${parameter}`
});

After the stack is deployed, you can SSH into the EC2 instance and use Node.js:

$ ssh ec2-user@<public-ip>
$ node --version
v20.13.1
$ code --version
1.89.1
$ git --version
git version 2.39.3

user data

Installation of software is done by user data script. You can see the script in the src/index.ts file.

// Install Node.js
userData.addCommands(
  'touch ~/.bashrc',
  'curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash',
  'source ~/.bashrc',
  'export NVM_DIR="$HOME/.nvm"',
  '[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"',
  `nvm install ${props.nodeJsVersion ?? '--lts'}`,
  // Note that the above will install nvm, node and npm for the root user.
  // It will not add the correct ENV VAR in ec2-user's environment.
  `cat <<EOF >> /home/ec2-user/.bashrc
export NVM_DIR="/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"
EOF`);

Ofcourse, you can customize the additional user data script by calling instance.userData.addCommands() method.

declare const instance: PreinstalledAmazonLinuxInstance;

// install yarn
instance.userData.addCommands(
  'npm install -g yarn'
);

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cdk_preinstalled_amazon_linux_ec2-0.0.12.tar.gz (46.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file cdk_preinstalled_amazon_linux_ec2-0.0.12.tar.gz.

File metadata

File hashes

Hashes for cdk_preinstalled_amazon_linux_ec2-0.0.12.tar.gz
Algorithm Hash digest
SHA256 0d17204c3b7048c87d24d1d706702336ac559d99ddb3024ab3b2d2c2d267fb5d
MD5 ec58a85d0d0375fc755703208aa7ef2b
BLAKE2b-256 3f438a711d16f12e88c5f9f92cc586e66e495d64fa5fa0b12e0a3d86b9d1088b

See more details on using hashes here.

File details

Details for the file cdk_preinstalled_amazon_linux_ec2-0.0.12-py3-none-any.whl.

File metadata

File hashes

Hashes for cdk_preinstalled_amazon_linux_ec2-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 31a035c452f103eb38eb86a47b797808dff0563f62d8b9771363df047f7c3c30
MD5 af93e7d1b9634268e3c539ab96e90325
BLAKE2b-256 b7694db6b51a6aa851ecdc0161c85dba669de9f5774ca67e2793cffa53f2dfff

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page