Docker image for TP-Link Omada Controller to control TP-Link Omada Hardware
- Image Tags
- Reporting Issues
- Upgrading to 5.0.x from 4.1.x or above
- Upgrading to 4.1 from 3.2.10 or below
- Building Images
- Example Usage
- Optional Variables
- Persistent Data and Permissions
- Custom Certificates
- MongoDB Small Files
- Time Zones
- Unprivileged Ports
- Using Docker Compose
- Omada Controller API Documentation
- Known Issues
The following tags have multi-arch support for amd64
, armv7l
, and arm64
and will automatically pull the correct tag based on your system's architecture:
Tag(s) | Major.Minor Release | Current Version |
---|---|---|
latest , 5.4 |
Omada Controller 5.4.x |
5.4.6 |
5.3 |
Omada Controller 5.3.x |
5.3.1 |
5.1 |
Omada Controller 5.1.x |
5.1.7 |
5.0 |
Omada Controller 5.0.x |
5.0.30 |
4.4 |
Omada Controller 4.4.x |
4.4.8 |
4.3 |
Omada Controller 4.3.x |
4.3.5 |
4.2 |
Omada Controller 4.2.x |
4.2.11 |
4.1 |
Omada Controller 4.1.x |
4.1.5 |
3.2 |
Omada Controller 3.2.x |
3.2.16 |
These tags will explicitly pull the image for the listed architecture and are bit for bit identical to the multi-arch tags images. The current version of the software is identical across all architectures so they are identical to the table above.
Tag(s) for amd64 |
Major.Minor Release | Base Image |
---|---|---|
latest-amd64 , 5.4-amd64 |
Omada Controller 5.4.x |
mbentley/ubuntu:20.04 |
5.3-amd64 |
Omada Controller 5.3.x |
mbentley/ubuntu:20.04 |
5.1-amd64 |
Omada Controller 5.1.x |
mbentley/ubuntu:20.04 |
5.0-amd64 |
Omada Controller 5.0.x |
mbentley/ubuntu:20.04 |
4.4-amd64 |
Omada Controller 4.4.x |
mbentley/ubuntu:18.04 |
4.3-amd64 |
Omada Controller 4.3.x |
mbentley/ubuntu:18.04 |
4.2-amd64 |
Omada Controller 4.2.x |
mbentley/ubuntu:18.04 |
4.1-amd64 |
Omada Controller 4.1.x |
mbentley/ubuntu:18.04 |
3.2-amd64 |
Omada Controller 3.2.x |
mbentley/ubuntu:18.04 |
Warning: If you have an operating system that is 32 bit (armv7l
/armhf
), I strongly recommend you DO NOT run the Omada Controller on that device as it is running an unsupported operating system and an unsupported MongoDB.
Tag(s) for armv7l |
Major.Minor Release | Base Image |
---|---|---|
latest-armv7l , 5.4-armv7l |
Omada Controller 5.4.x |
mbentley/ubuntu:16.04 |
5.3-armv7l |
Omada Controller 5.3.x |
mbentley/ubuntu:16.04 |
5.1-armv7l |
Omada Controller 5.1.x |
mbentley/ubuntu:16.04 |
5.0-armv7l |
Omada Controller 5.0.x |
mbentley/ubuntu:16.04 |
4.4-armv7l |
Omada Controller 4.4.x |
mbentley/ubuntu:16.04 |
4.3-armv7l |
Omada Controller 4.3.x |
mbentley/ubuntu:16.04 |
4.2-armv7l |
Omada Controller 4.2.x |
mbentley/ubuntu:16.04 |
4.1-armv7l |
Omada Controller 4.1.x |
mbentley/ubuntu:16.04 |
3.2-armv7l |
Omada Controller 3.2.x |
mbentley/ubuntu:16.04 |
Tag(s) for arm64 |
Major.Minor Release | Base Image |
---|---|---|
latest-arm64 , 5.4-arm64 |
Omada Controller 5.4.x |
mbentley/ubuntu:20.04 |
5.3-arm64 |
Omada Controller 5.3.x |
mbentley/ubuntu:20.04 |
5.1-arm64 |
Omada Controller 5.1.x |
mbentley/ubuntu:20.04 |
5.0-arm64 |
Omada Controller 5.0.x |
mbentley/ubuntu:20.04 |
4.4-arm64 |
Omada Controller 4.4.x |
mbentley/ubuntu:18.04 |
4.3-arm64 |
Omada Controller 4.3.x |
mbentley/ubuntu:18.04 |
4.2-arm64 |
Omada Controller 4.2.x |
mbentley/ubuntu:18.04 |
4.1-arm64 |
Omada Controller 4.1.x |
mbentley/ubuntu:18.04 |
3.2-arm64 |
Omada Controller 3.2.x |
mbentley/ubuntu:18.04 |
These images are still published on Docker Hub but are no longer regularly updated due to the controller software no longer being updated. Use with extreme caution as these images are likely to contain unpatched security vulnerabilities!
Tag(s) | Major.Minor Release | Current Version |
---|---|---|
3.1 |
Omada Controller 3.1.x |
3.1.13 |
3.0 |
Omada Controller 3.0.x |
3.0.5 |
If you have issues running the controller, feel free to file an issue and I will help as I can. If you are specifically having a problem that is related to the actual software, I would suggest filing an issue on the TP-Link community forums as I do not have access to source code to debug those issues. If you're not sure where the problem might be, I can help determine if it is a running in Docker issue or a software issue.
There are no manual upgrade steps directly related to the software itself required when upgrading to 5.0.x if you are already running at least 4.1.x. For full details, please refer to the TP-Link upgrade documentation.
As always, I would recommend taking a backup through the controller software as well as save a copy of the persistent data while the controller is not running when you do upgrade to simplify the rollback process, if required.
- Updated Ports - If you are only exposing ports using port mapping as the list of ports required has been updated. Starting with 5.0.x, the controller is also listening on
TCP port 29814
so you should add-p 29814:29814
to your run command, compose file, or however you're running the container. Some additional unnecessary ports are no longer required so the list is shorter now. - Volume Updates - Starting with 5.0.x, the controller software is now built using Spring Boot. This version no longer uses the
work
volume as the application is no longer extracted to a temporary directory. If you do nothing, there will be no impact except for an extra directory sitting around. - Custom Ports - If using custom ports from the defaults of 8088, 8043, and 8843, they will not persist across container re-creation starting in 5.0 unless you always set the
MANAGE_*_PORT
enviornment variables. This is due to adding/opt/tplink/EAPController/properties
to the classpath starting in 5.0. If you change the ports through the UI, you should still continue to also set the ports using the environment variables, matching the ports you have set in the UI. For more detail, see Using non-default ports.
The upgrade to the 4.1.x version is not a seamless upgrade and can't be done in place. You must be running at least 3.1.4 or greater before you can proceed. Instructions are available from TP-Link but many of the steps will be different due to running in a docker container. Here are the high level steps:
- Review the steps in the TP-Link instructions as some settings will not transfer to the new version.
- Take a backup of your controller as described in the upgrade procedure
- Stop your controller
- Clear your existing persistent data directories for data, work, and logs. I would recommend backing up the files so you can revert to the previous version in case of issues.
- Start your controller with the new Docker image and proceed with at least the basic setup options
- Import your backup file to the 4.1 version of the controller
- Ports - Do not change the ports for the controller or portal in the UI to ports below 1024 unless you have adjusted the unprivileged ports; for ports < 1024, see Unprivileged Ports.
- SSL Certificates - if you are installing your own SSL certificates, you should only manage them using one method - through the UI or by using the
/cert
volume as described below. - Synology Users - if you're using a Synology and are using the
latest
tag and update to 4.1, you will need to make sure to re-create the container due to theCMD
changing from older versions to 4.1 as Synology retains the entrypoint and command from the container as it is defined and not from the image.
Click to expand docker build instructions
As of the Omada Controller version 4.2.x, the Dockerfiles have been simplified so that there is a unified Dockerfile. There are some differences between the build steps for amd64
, arm64
, and armv7l
. These changes will happen automatically if you use the following build-args:
No build args required; set for the default build-args
docker build \
--build-arg INSTALL_VER="5.4" \
-f Dockerfile.v5.x \
-t mbentley/omada-controller:5.4 .
Only the ARCH
build-arg is required
docker build \
--build-arg INSTALL_VER="5.4" \
--build-arg ARCH="arm64" \
-f Dockerfile.v5.4.x \
-t mbentley/omada-controller:5.4-arm64 .
Both the ARCH
and BASE
build-args are required
docker build \
--build-arg INSTALL_VER="5.4" \
--build-arg ARCH="armv7l" \
--build-arg BASE="ubuntu:16.04" \
-f Dockerfile.v5.4.x \
-t mbentley/omada-controller:5.4-armv7l .
To run this Docker image and keep persistent data in named volumes:
tl;dr: Always make sure the environment variables for the ports match any changes you have made in the web UI and you'll be fine.
Note: The 3.2
version of the controller only supports the MANAGE_HTTP_PORT
and MANAGE_HTTPS_PORT
variables for modifying the controller's admin web interface ports. This means that setting PORTAL_HTTP_PORT
and PORTAL_HTTPS_PORT
will not have any effect in 3.2
. Versions 4.2
or greater support all of the MANAGE_*_PORT
and PORTAL_*_PORT
variables as described in the Optional Variables section.
If you want to change the ports of your Omada Controller to something besides the defaults, there is some unexpected behavior that the controller exhibits. There are two sets of ports: one for HTTP/HTTPS for the controller itself and another for HTTP/HTTPS for the captive portal, typically used for authentication to a guest network. The controller's set of ports, which are set by the MANAGE_*_PORT
environment variables, can only be modified using the environment variables on the first time the controller is started. If persistent data exists, changing the controller's ports via environment variables will have no effect on the controller itself and can only be modified through the web UI. On the other hand, the portal ports will always be set to whatever has been set in the environment variables, which are set by the PORTAL_*_PORT
environment variables.
Warning: If you want to change the controller ports from the default mappings, you absolutely must update the port binding inside the container via the environment variables. The ports exposed must match what is inside the container. The Omada Controller software expects that the ports are the same inside the container and outside and will load a blank page if that is not done. See #99 for details and and example of the behavior.
docker run -d \
--name omada-controller \
--restart unless-stopped \
-p 8088:8088 \
-p 8043:8043 \
-p 8843:8843 \
-p 29810:29810/udp \
-p 29811:29811 \
-p 29812:29812 \
-p 29813:29813 \
-p 29814:29814 \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4
docker run -d \
--name omada-controller \
--restart unless-stopped \
--net host \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4
Example usage for armv7l
docker run -d \
--name omada-controller \
--restart unless-stopped \
-p 8088:8088 \
-p 8043:8043 \
-p 8843:8843 \
-p 29810:29810/udp \
-p 29811:29811 \
-p 29812:29812 \
-p 29813:29813 \
-p 29814:29814 \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4-armv7l
docker run -d \
--name omada-controller \
--restart unless-stopped \
--net host \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4-armv7l
Example usage for arm64
docker run -d \
--name omada-controller \
--restart unless-stopped \
-p 8088:8088 \
-p 8043:8043 \
-p 8843:8843 \
-p 29810:29810/udp \
-p 29811:29811 \
-p 29812:29812 \
-p 29813:29813 \
-p 29814:29814 \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4-arm64
docker run -d \
--name omada-controller \
--restart unless-stopped \
--net host \
-e MANAGE_HTTP_PORT=8088 \
-e MANAGE_HTTPS_PORT=8043 \
-e PGID="508" \
-e PORTAL_HTTP_PORT=8088 \
-e PORTAL_HTTPS_PORT=8843 \
-e PUID="508" \
-e SHOW_SERVER_LOGS=true \
-e SHOW_MONGODB_LOGS=false \
-e SSL_CERT_NAME="tls.crt" \
-e SSL_KEY_NAME="tls.key" \
-e TZ=Etc/UTC \
-v omada-data:/opt/tplink/EAPController/data \
-v omada-logs:/opt/tplink/EAPController/logs \
mbentley/omada-controller:5.4-arm64
Variable | Default | Values | Description | Valid For |
---|---|---|---|---|
MANAGE_HTTP_PORT |
8088 |
1024 -65535 |
Management portal HTTP port; for ports < 1024, see Unprivileged Ports | >= 3.2 |
MANAGE_HTTPS_PORT |
8043 |
1024 -65535 |
Management portal HTTPS port; for ports < 1024, see Unprivileged Ports | >= 3.2 |
PGID |
508 |
any | Set the omada process group ID ` |
>= 3.2 |
PORTAL_HTTP_PORT |
8088 |
1024 -65535 |
User portal HTTP port; for ports < 1024, see Unprivileged Ports | >= 4.1 |
PORTAL_HTTPS_PORT |
8843 |
1024 -65535 |
User portal HTTPS port; for ports < 1024, see Unprivileged Ports | >= 4.1 |
PUID |
508 |
any | Set the omada process user ID ` |
>= 3.2 |
SHOW_SERVER_LOGS |
true |
[true|false] |
Outputs Omada Controller logs to STDOUT at runtime | >= 4.1 |
SHOW_MONGODB_LOGS |
false |
[true|false] |
Outputs MongoDB logs to STDOUT at runtime | >= 4.1 |
SMALL_FILES |
false |
[true|false] |
See Small Files for more detail; no effect in >= 4.1.x |
3.2 only |
SSL_CERT_NAME |
tls.crt |
any | Name of the public cert chain mounted to /cert ; see Custom Certificates |
>= 3.2 |
SSL_KEY_NAME |
tls.key |
any | Name of the private cert mounted to /cert ; see Custom Certificates |
>= 3.2 |
TLS_1_11_ENABLED |
false |
[true|false] |
Re-enables TLS 1.0 & 1.1 if set to true |
>= 4.1 |
TZ |
Etc/UTC |
<many> | See Time Zones for more detail | >= 3.2 |
Note: The permissions portion only applies to tags for 3.1.x
and 3.0.x
as the 3.2.x
and newer versions manage the permissions for you.
If you utilize bind mounts instead of Docker named volumes (e.g. - -v /path/to/data:/opt/tplink/EAPController/data
) in your run command, you will want to make sure that you have set the permissions appropriately on the filesystem otherwise you will run into permissions errors and the container will not run because it won't have the permissions to write data since this container uses a non-root user. To resolve that, you need to chown
the directory to 508:508
on the host as that is the UID and GID that we use inside the container. For example:
chown -R 508:508 /data/omada/data /data/omada/logs
In the examples, there are two directories where persistent data is stored: data
and logs
. The data
directory is where the persistent database data is stored where all of your settings, app configuration, etc is stored. The log
directory is where logs are written and stored. I would suggest that you use a bind mounted volume for the data
directory to ensure that your persistent data is directly under your control and of course take regular backups within the Omada Controller application itself.
By default, Omada software uses self-signed certificates. If however you want to use custom certificates you can mount them into the container as /cert/tls.key
and /cert/tls.crt
. The tls.crt
file needs to include the full chain of certificates, i.e. cert, intermediate cert(s) and CA cert. This is compatible with kubernetes TLS secrets. Entrypoint script will convert them into Java Keystore used by jetty inside the Omada SW. If you need to use different file names, you can customize them by passing values for SSL_CERT_NAME
and SSL_KEY_NAME
as seen above in the Optional Variables section.
Warning - As of the version 4.1, certificates can also be installed through the web UI. You should not attempt to mix certificate management methods as installing certificates via the UI will store the certificates in MongoDB and then the /cert
volume method will cease to function.
In Omada 3.2 and older, this image uses the default mongodb settings for journal files. If disk space is an issue, you can set the SMALL_FILES
variable to true
which will add --smallfiles
to the startup arguments for MongoDB.
Warning - As of the version 4.1 and newer, MongoDB utilizes the WiredTiger
storage engine by default which does not have the same journal file size issue as the MMAPv1
storage engine. If SMALL_FILES
is set to true
, a warning will be issued at startup but startup will still proceed.
By default, this image uses the Etc/UTC
time zone. You may update the time zone used by passing a different value in the TZ
variable. See List of tz database time zones for a complete list of values in the TZ database name
table column.
This Docker image runs as a non-root user by default. In order to bind unprivileged ports (ports < 1024 by default), you must include --sysctl net.ipv4.ip_unprivileged_port_start=0
in your docker run
command to allow ports below 1024 to be bound by non-root users.
There is a Docker Compose file available for those who would like to use compose to manage the lifecycle of their container:
wget https://raw.githubusercontent.com/mbentley/docker-omada-controller/master/docker-compose.yml
docker-compose up -d
If you are interested in using the Omada Controller APIs to retrieve data from the controller, the latest version of the API documentation that I have found is available from the community forums in this post. I'm not able to provide support for the APIs but I've found them to be helpful for my own usage and they weren't easy to find.
See the Known Issues documentation for details.