Docker for MySQL¶
EPSIO PRIVATE PREVIEW
At this time, Epsio running in "standalone docker mode" is only available in private preview.
To get early access, contact us at support@epsio.io
DEVELOPMENT ENVIRONMENTS ONLY
Running Epsio on Docker is recommended only for development environments, not production use.
This guide will walk you through the process of deploying Epsio.
Before you begin¶
Before proceeding with the deployment guide, ensure that you have the following:
- A Linux/Macbook machine to run epsio on with:
- Network access to your MySQL instance.
docker
installed on it
- A MySQL Database with version 5.7+.
1. Prepare your database for Epsio¶
Open a connection to your database and follow the steps below.
Create a database for Epsio's metadata:
Create a database user for Epsio's exclusive use:
Grant new user permissions to the Epsio database
Grant replication permissions to the Epsio user
Grant permission to create result tables and populate existing data
GRANT SELECT, CREATE, SHOW VIEW, CREATE VIEW, ALTER, INSERT, LOCK TABLES, DELETE, DROP ON *.* TO epsio_user;
If you wish to limit access to only specific tables / databases, replace the *.*
pattern with the relevant database names and table names you intend on using.
2. Configure Replication¶
2.1 Check if replication is configured correctly¶
Run the following command to check if your instance is already configured correctly:
-- Required configuration: ON
SHOW VARIABLES LIKE 'log_bin';
-- Required configuration: ROW
SHOW VARIABLES LIKE 'binlog_format';
-- Required configuration: ON
SHOW VARIABLES LIKE 'log_bin_trust_function_creators';
2.2 Enable replication¶
Enable binlog:
Edit your mysql conf file and add the following configurations:
server-id = 223344
log_bin = mysql-bin
binlog_format = ROW
binlog_row_image = FULL
binlog_expire_logs_seconds = 864000
Enable log_bin_trust_function_creators: Run the following command;
Validate configuration: Verify that all the new configurations are enabled by running the following commands:
-- Required configuration: ON
SHOW VARIABLES LIKE 'log_bin';
-- Required configuration: ROW
SHOW VARIABLES LIKE 'binlog_format';
-- Required configuration: ON
SHOW VARIABLES LIKE 'log_bin_trust_function_creators';
4. Run Epsio docker¶
Once finished, run the following command to run the standalone Epsio docker.
ACCOUNT_TOKEN
- Your account's access token which can be retrieved from the cloud console settings page.EPSIO_VERSION
- The version of Epsio (see the changelog for the latest version information).
docker run --name epsio \
-e ACCOUNT_TOKEN='<ACCOUNT_TOKEN>' \
-e DB_HOST='<DB_HOST>' \
-e DB_NAME='<DB_NAME>' \
-e DB_PASSWORD='<EPSIO_USER_PASSWORD>' \
-e DB_PORT=<DB_PORT> \
-e SOURCE_DATABASE_TYPE='mysql' \
us-docker.pkg.dev/epsio-io/public/epsio:<EPSIO_VERSION>
Congratulations! You've successfully enabled replication in your database.
You are set to go and can create your first view. Visit the create_view for further details.
Troubleshooting¶
To troubleshoot, first check the docker logs:
If the above don't prove helpful, Run the following commands:
docker exec -it epsio dump-logs -o /tmp/diagnostic_dump
docker cp epsio:/tmp/diagnostic_dump <output file path>
And send the outputed file to Epsio support