Unofficial Container image for Multi Theft Auto: San Andreas game server. Maintained mostly for myself, but also for anyone from the MTA community who find it useful.
- This image is automatically built and published on podmanhub as
notfound/mtasa-server
- The base image is Debian Testing (slim) which ensures maximum compatibility and official support
- Total image size is oscillating around 100MiB
- 64-bit server only
- On Windows, only the podman Desktop with WSL 2 backend is supported, so expect weird issues with different setup (been there, done that, big NOPE from me). On Linux there are no problems at all.
- The tags always reflect the specific version and build number of the MTA server which they contain, i.e.
latest
Note: the
v4
in this example is the version number of the tag itself because sometimes something might go wrong and an updated release of the same version and build number is needed)
-
Optimized to be easy to use by anyone
-
Comes with a simple scripts which automate boring stuff:
-
Automatic resources downloader: If you don't have any resources yet, the official MTA resources package is automatically downloaded and extracted for you before the server is started
-
Automatic baseconfig provider: If you don't have your own configuration files, all essential ones are automatically brought to you from the official
baseconfig
archive
-
-
Also covers more advanced scenarios that experienced developers and server owners might find handy:
- Automatic creation of admin / developer account in the built-in accounts system - TODO, soon
- Automatic management of server password, with three strategies (policies) available to be used depending on the use case
- Effortless switching between different server configs, i.e.
mtaserver.dev.conf
file for development andmtaserver.prod.conf
for the live server - All of that is configurable via environment variables
- Custom native modules can still be installed easily if needed (native modules will be deprecated in MTA 1.6, so they will be around for a while)
- Full access to the server console input and output, even if the server was started in the background (re-attaching to the console works fine, no
screen
or anything like that is involved - it's all podman) - Simple directory structure on the root level (
/
) inside the image which makes them easier to find and mount - Ready for fastdl setups (hosting client files over external HTTP servers)
- Fully prepared for running as a non-root user
-
For maximum compatibility with older scripts, the legacy native modules are also included in this image:
- Sockets Module -
ml_sockets.so
- MySQL module -
mta_mysql.so
If you want to use them, just remember to add proper entries to your server config.
- Sockets Module -
-
It's battle-tested: I'm using this image by myself in 4 different environments and I consider it production-ready :)
Note: The automatic resources downloader and baseconfig provider mentioned above don't interfere with your existing files. If some essential config files are totally missing, then they will be added for you from the
baseconfig
package, But if you already have your own resources and configs then don't worry - they will NOT be overwritten.
Because everyone likes screenshots
-
Resources autodownloader in action:
-
Directory structure after running the command visible in the screenshot above (before running it, it was three empty folders)
MTA_SERVER_CONFIG_FILE_NAME
- custom name of the config file, useful for switching between configs for different environments i.e.mtaserver.dev.conf
for development,mtaserver.prod.conf
for the live server
It's recommended to use this image in a podman Compose setup, because it's much easier to maintain and configure everything with a YAML file instead of passing all of the options via command line.
TODO: More on that will be here soon
This is just for reference and basic testing. You should really consider using a podman Compose setup as described in this section.
Create an empty directory somewhere on your disk, then navigate to it and create directories named:
mta-resources/
data/
resource-cache/
The commands in the examples below are bind-mounting these directories to the container and they must exist or you will get a nasty error.
Run one of the example commands in Powershell on Windows, or in bash on Linux.
If you don't have any resources in mta-resources/
dir, the official default resources will be automatically downloaded and unpacked there when the container is started.
Server config, acl config, banlist and so on will be available in data/
in your current directory.
This image is prepared for running as non-root user. Use podman's --user
option (or equivalent) to pass the uid / gid (of the non-root user on your host-machine) to the container. Look at examples in the next section.
From bash:
podman run --name mta-server \
-t \ # allocate tty (always required)
-p 22003:22003/udp \ # map ports to host machine
-p 22126:22126/udp \
-p 22005:22005 \
-v $(pwd)/mta-resources:/resources \ # mount mta resources dir
-v $(pwd)/data:/data \ # mount mta data dir (config, acl, banlist, internal DBs etc.)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
From powershell (basically the only difference is pwd
syntax):
podman run --name mta-server \
-t \ # allocate tty (always required)
-p 22003:22003/udp \ # map ports to host machine
-p 22126:22126/udp \
-p 22005:22005 \
-v ${PWD}/mta-resources:/resources \ # mount mta resources dir
-v ${PWD}/data:/data \ # mount mta data dir (config, acl, banlist, internal DBs etc.)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
Only relevant podman run
options are being shown in each example to avoid redundancy. You can combine options from multiple examples to create the setup that suits your needs.
podman run --name mta-server \
-t \
-p 22003:22003/udp \
-p 22005:22005 \
-v $(pwd)/mta-resources:/resources \
ghcr.io/johnmmcgee/mtasa-server:latest
podman run --name mta-server \
-t \
-p 22003:22003/udp \
-p 22005:22005 \
-v $(pwd)/mta-resources:/resources \
-v $(pwd)/data:/data \
notfound/mtasa-server:1.6.0-22511-v1
podman run --name mta-server \
-u $(id -u):$(id -g) # set uid and gid of current user
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
podman run --name mta-server \
-d # detach
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
podman run --name mta-server \
-t \ # allocate tty (always required)
-v $(pwd)/resource-cache:/resource-cache \ # mount cache dir, you only need it if you have fastdl server setup
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
podman run --name mta-server \
-e MTA_SERVER_PASSWORD=mypassword
-e MTA_SERVER_PASSWORD_REPLACE_POLICY=always # always update the <password> entry in the active server config with the value of MTA_SERVER_PASSWORD
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
podman run --name mta-server \
-e MTA_SERVER_PASSWORD=mypassword
-e MTA_SERVER_PASSWORD_REPLACE_POLICY=when-empty # only update the <password> entry in the active server config if it's not already set
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
when-empty
is the default policy, so this can be simplified to just:
podman run --name mta-server \
-e MTA_SERVER_PASSWORD=mypassword
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
podman run --name mta-server \
-e MTA_SERVER_PASSWORD_REPLACE_POLICY=unless-empty # only update the <password> entry in the active server config if it has some value
-t \ # allocate tty (always required)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
The config file (in this example it is mtaserver.mycustom.conf
) must be available in container's data directory, so remember to create a local directory on your host machine, put your config in there and mount this directory as /data
in the container.
If your custom config file is not present in the data directory, it will be automatically created on container startup and populated with the default configuration from baseconfig.
podman run --name mta-server \
-e MTA_SERVER_CONFIG_FILE_NAME=mtaserver.mycustom.conf
-t \ # allocate tty (always required)
-v ${PWD}/data:/data \ # mount mta data dir (config, acl, banlist, internal DBs etc.)
ghcr.io/johnmmcgee/mtasa-server:latest # remember to adjust the tag name
This image is built by issuing a Run Workflow and updating the values under actions. There is no real need for automated builds at this time.