Mysql
Neosync is an open-source, developer-first product that allows you to create anonymized, secure test data that you can sync across all of your environments for high quality local, stage and CI testing.
Neosync supports most Mysql-compatible databases natively using the Mysql connection.
Things to watch out for
- Neosync can sync data between two physical Mysql databases that are exposed through two different ports. Today, Neosync cannot sync between two logical databases in Mysql.
For example:
Physical Mysql Server (server1):
- hostname:3306/Database1 (physical database)
- public (schema)
- table1 (table)
- public (schema)
- hostname:3307/Database1 (physical database)
- public (schema)
- table1 (table)
- public (schema)
MySQL Database Connection Configuration
Connection URL
A connection url may be provided. DSN format is preferred, limited support for URI format.
Environment Variable
To connect using the environment variable, simply paste the environment variable in the Environment Variable input.
The value of the environment variable must be in the Connection URL
format.
This is only available in the OSS version of Neosync. The environment variable must begin with USER_DEFINED_
.
This is for safety and is to limit the class of environment variables a user of Neosync may configure.
For full support, the environment variable must live on both the neosync-api
as well as neosync-worker
.
Discrete Host Parameters
This guide will help you to configure your MySQL database connection properly.
Connection Name: Enter a unique name for this connection that you'll easily recognize. This is just a label and does not affect the connection itself.
Host Name: Enter the server address. 'localhost' is used for a local server. For remote servers, use the IP address or domain name.
Database Port: MySQL's default port is 3306. Change it if your server uses a different port.
Database Name: The name of the database you want to connect to. It should exist on your MySQL server.
Database Username: Your database username. It needs to have the appropriate permissions for the operations you intend to perform.
Database Password: The password for the database user. Accuracy is essential for security.
Connection Protocol: Select the protocol you wish to use to connect to your database. 'tcp' is commonly used for network connections.
Test the connection before saving to ensure all details are correct and the system can connect to the database.
You may also specify a direct DSN via the URL
tab instead of the split out Host
view.
TLS
Neosync has support for Regular TLS (one-way) as well as mTLS (two-way).
This is configured via the Client TLS Certificates
section on the database configuration page.
If you simply wish to verify the server certificate, only the Root certificate
is required.
If wishing to have the client present a certificate, you must specify both the Client key
as well as the Client certificate
.
If only one of these is provided, the Neosync will reject the configuration.
The following TLS/SSL modes are available for Mysql via the tls
query parameter.
NB: if using the
URL
configuration, you will need to specify this directly in the query parameters. If using the host configuration, be sure to select the correct option in the dropdown that you intend to use.
true - Enabled TLS/SSL encryption to the server
false - Disables TLS
skip-verify - If you want to use a self-signed or invalid certificate on the server-side. Self-signed may be use if using mTLS.
preferred - Use TLS only when advertised by the server
The server name
must be provided if using tls=true
otherwise the client will not have enough information to fully verify the host and will fail connection. If this isn't desired, use tls=skip-verify
.
Go Mysql Driver
Neosync uses the go-sql-driver/mysql
for Mysql support.
HTTP urls are not very well supported and you will find much better luck, using the older DSN
format.
For a full look at query parameters available to you, check the driver readme
By default, Neosync will add the following query parameters automatically to your user-provided DSN at runtime:
-
multiStatements=true
- This is used to enable sending batched SQL statements to the server at once. If this is turned off, Neosync has to send single statements at a time, which really hurts performance.
-
parseTime=true
- This configures the driver to automatically convert date and time values to go's
time.Time
object for better data handling through the system.
- This configures the driver to automatically convert date and time values to go's