Setting up AWS IoT Greengrass core devices
Complete the tasks in this section to install, configure, and run the AWS IoT Greengrass Core software.
Note
This section describes advanced installation and configuration of the AWS IoT Greengrass Core software. These steps do not apply to nucleus lite.If you're a first-time user of AWS IoT Greengrass V2, we recommend that you first complete the getting started tutorial to set up a core device and explore the features of AWS IoT Greengrass.
Topics
Supported platforms
Device requirements
Lambda function requirements
Important
Greengrass Lambda functions are currently not supported by Greengrass nucleus lite.
Your device must meet the following requirements to run Lambda functions:
-
A Linux-based operating system.
-
Your device must have the
mkfifoshell command. -
Your device must run the programming language libraries that a Lambda function requires. You must install the required libraries on the device and add them to the
PATHenvironment variable. Greengrass supports all Lambda supported versions of Python, Node.js, and Java runtimes. Greengrass doesn't apply any additional restrictions on deprecated Lambda runtime versions. For more information about AWS IoT Greengrass support for Lambda runtimes, see Run AWS Lambda functions. -
To run containerized Lambda functions, your device must meet the following requirements:
-
Linux kernel version 4.4 or later.
-
The kernel must support cgroups
v1, and you must enable and mount the following cgroups: -
The memory cgroup for AWS IoT Greengrass to set the memory limit for containerized Lambda functions.
-
The devices cgroup for containerized Lambda functions to access system devices or volumes.
The AWS IoT Greengrass Core software doesn't support cgroups v2.
To meet this requirement, boot the device with the following Linux kernel parameters.
cgroup_enable=memory cgroup_memory=1 systemd.unified_cgroup_hierarchy=0Tip
On a Raspberry Pi, edit the
/boot/cmdline.txtfile to set the device's kernel parameters. -
-
You must enable the following Linux kernel configurations on the device:
-
Namespace:
-
CONFIG_IPC_NS -
CONFIG_UTS_NS -
CONFIG_USER_NS -
CONFIG_PID_NS
-
-
Cgroups:
-
CONFIG_CGROUP_DEVICE -
CONFIG_CGROUPS -
CONFIG_MEMCG
-
-
Others:
-
CONFIG_POSIX_MQUEUE -
CONFIG_OVERLAY_FS -
CONFIG_HAVE_ARCH_SECCOMP_FILTER -
CONFIG_SECCOMP_FILTER -
CONFIG_KEYS -
CONFIG_SECCOMP -
CONFIG_SHMEM
-
Tip
Check the documentation for your Linux distribution to learn how to verify and set Linux kernel parameters. You can also use AWS IoT Device Tester for AWS IoT Greengrass to verify that your device meets these requirements. For more information, see Using AWS IoT Device Tester for AWS IoT Greengrass V2.
-
-