Installation

This chapter walks you through the basic installation steps for EMQX, the minimum hardware specification, and the file and directory locations to facilitate future configuration and maintenance jobs.

Installation Environment

The Erlang VM powering EMQX relies on system locale settings to enable Unicode support for various functionalities, including filenamesInstallation - 图1 (opens new window) and terminal IOInstallation - 图2 (opens new window) in interactive Erlang shells.

If you use the Linux operating system, it is recommended to make sure that UTF-8 locale is enabled in the system environment before starting EMQX. Click the tabs to see how to enable the UTF-8 locale on different platforms:

Enable the UTF-8 locale with cloud-initInstallation - 图3 (opens new window) configuration:

  1. cat <<EOF | sudo tee /etc/cloud/cloud.cfg.d/99_locale.cfg
  2. #cloud-config
  3. locale: C.utf8
  4. EOF

It is usually enabled by localectl under systemd:

  1. sudo localectl set-locale LANG=C.UTF-8

Enable the UTF-8 locale in two ways:

Enable the UTF-8 locale with update-localeInstallation - 图6 (opens new window):

  1. sudo update-locale LANG=C.UTF-8

Download

EMQX releases the installation packages for different operating systems or platforms in each release. You may click the links below to download.

You can also download the alpha, beta, or rc versions from our GitHub pagesInstallation - 图8 (opens new window). {% endemqxce %}

TIP

Besides the above deployment methods, you are also welcome to try our EMQX CloudInstallation - 图9 (opens new window), a fully managed MQTT service for IoT. You only need to register for an accountInstallation - 图10 (opens new window) before starting your MQTT services and connecting your IoT devices to any cloud with zero need for infrastructure maintenance.

Supported Operating Systems

The table below lists the operating systems and versions that EMQX supports.

Operating systemVersions supportedx86_64/amd64arm64
UbuntuUbuntu 18.04
Ubuntu 20.04
Ubuntu 22.04
YesYes
DebianDebian 10
Debian 11
YesYes
CentOS/RHELCentOS 7
CentOS 8
YesYes
Amazon Linux-YesYes
macOSmacOS 11
macOS 12
YesYes
Windows-YesYes

Hardware Specification

Depending on the number of client connections, message rate, message size, and enabled features, the minimum hardware specification for EMQX varies.

Below are hardware specifications for running EMQX with simple workloads, supporting 100,000 client connections and 100,000 messages per second of throughput.

ItemMinimum configurationRecommended configuration
Node12
CPU1 core16 core
Memory512 MB32 GB
Disk space1 GB50 GB

TIP

In production environments, you can use the Server EstimateInstallation - 图11 (opens new window) calculator to calculate the recommended hardware specification under various maximum connections and message throughput.

Files and Directories

After installation, EMQX creates some directories to store running and configuration files, data, and logs. The table below lists the directories created and their file path under different installation methods:

DirectoryDescriptionInstalled with tar.gzInstalled with RPM/DEB
etcConfig files./etc/etc/emqx
dataDatabase and files./data/var/lib/emqx
logLog files./log/var/log/emqx
releasesBoot instructions./releases/usr/lib/emqx/releases
binExecutables./bin/usr/lib/emqx/bin
libErlang code./lib/usr/lib/emqx/lib
erts-Erlang runtime./erts-/usr/lib/emqx/erts-*
pluginsPlugins./plugins/usr/lib/emqx/plugins

TIP

  1. When installed with the compressed package, the directory is relative to the directory where the software is installed.
  2. When installed with Docker container, EMQX is installed in the /opt/emqx directory.
  3. The data, log, and plugins directories are configurable via the configuration files. Mounting the data directory to a high-performance disk is recommended for better performance. For nodes belonging to the same cluster, the configuration for the data directory should be the same. For more information about clusters, see Cluster.

The table below introduces the files and subfolders of some directories.

DirectoryDescriptionPermissionsFiles
binExecutablesReademqx and emqx.cmd: Executables of EMQX. For details, see basic commands.

emqx_ctl and emqx_ctl.cmd: Executables of EMQX administration commands. For details, see administration CLI commands.
etcConfiguration filesReademqx.conf: Main configuration file for EMQX, contains all the commonly-used configuration items.

emqx-example-en.conf: Demo configuration files of EMQX, contains all the configurable items.

acl.conf: Default ACl rules.

vm.args: Operating parameters of the Erlang virtual machine.

certs/: X.509 keys and certificate files for EMQX SSL listeners, may also be used in the SSL/TLS connection when integrating with external systems.
dataOperating dataWriteauthz: Stores file authorization rules uploaded by REST API or Dashboard. For details, see Authorization - File.

certs: Stores certificate files uploaded by REST API or Dashboard.

configs: Stores configuration files generated at boot, or configuration overrides by changes from API or CLI.

mnesia: Built-in database to store EMQX operating data, including alarm records, authentication and authorization data of the clients, Dashboard user information, etc. If the directory is deleted, all these operating data will be lost.

— May contain subdirectories named after different node, e.g., emqx@127.0.0.1. Note: In case of node renaming, you should also delete or remove the corresponding subdirectory.

— Can use command emqx_ctl mnesia to query the built-in database. For details, see Management Command CLIInstallation - 图12 (opens new window).

patches: Stores the .beam files for EMQX to load as a hot patch. Can be used for a quick fix.

trace: Online tracing log files.

In production, it is recommended to periodically backup the data directory (excluding the trace folder ) for data safety.
logOperating logsReademqx.log.*: Operation logs of EMQX, for more information, see logs.

erlang.log.: Copy file of the console log when EMQX is started in the background with emqx start

TIP

EMQX stores the configuration information in the data/configs and the etc directory. The etc directory stores read-only configuration files, while configuration updates from the Dashboard or REST API are saved in the data/configs directory to support hot configuration reloads at runtime.

  • etc/emqx.conf
  • data/configs/cluster.hocon

EMQX reads the configuration items from these files and converts them to the Erlang native configuration file format, to apply the configurations at runtime.