Fixes #1404 Two sets of fixes: - add conditionals for windows and linux where shared - search/replace for linux only (MinIO Server reference pages) Staging server not available, tested/checked locally
7.6 KiB
MySQL Notification Settings
minio
Table of Contents
This page documents settings for configuring a MYSQL service as a
target for Bucket Notifications <minio-bucket-notifications>
.
See minio-bucket-notifications-publish-mysql
for a
tutorial on using these settings.
Multiple MYSQL Targets
You can specify multiple MySQL service endpoints by appending a
unique identifier _ID
for each set of related MySQL
settings on to the top level key.
Examples
The following commands set two distinct MySQL service endpoints as
PRIMARY
and SECONDARY
respectively:
Environment Variables
export MINIO_NOTIFY_MYSQL_ENABLE_PRIMARY="on"
export MINIO_NOTIFY_MYSQL_DSN_STRING_PRIMARY="username:password@tcp(mysql.example.com:3306)/miniodb"
export MINIO_NOTIFY_MYSQL_TABLE_PRIMARY="minioevents"
export MINIO_NOTIFY_MYSQL_FORMAT_PRIMARY="namespace"
export MINIO_NOTIFY_MYSQL_ENABLE_SECONDARY="on"
export MINIO_NOTIFY_MYSQL_DSN_STRING_SECONDARY="username:password@tcp(mysql.example.com:3306)/miniodb"
export MINIO_NOTIFY_MYSQL_TABLE_SECONDARY="minioevents"
export MINIO_NOTIFY_MYSQL_FORMAT_SECONDARY="namespace"
With these settings, MINIO_NOTIFY_MYSQL_ENABLE_PRIMARY <MINIO_NOTIFY_MYSQL_ENABLE>
indicates the environment variable is associated to a MySQL service
endpoint with ID of PRIMARY
.
Configuration Settings
mc admin config set notify_mysql:primary \
dsn_string="username:password@tcp(mysql.example.com:3306)/miniodb"
table="minioevents" \
format="namespace" \
[ARGUMENT=VALUE ...]
mc admin config set notify_mysql:secondary \
dsn_string="username:password@tcp(mysql.example.com:3306)/miniodb"
table="minioevents" \
format="namespace" \
[ARGUMENT=VALUE ...]
Settings
Enable
Required
Environment Variables
MINIO_NOTIFY_MYSQL_ENABLE
Specify on
to enable publishing bucket notifications to
a MySQL service endpoint.
Defaults to off
.
Requires specifying the following additional environment variables if
set to on
:
MINIO_NOTIFY_MYSQL_DSN_STRING
MINIO_NOTIFY_MYSQL_TABLE
MINIO_NOTIFY_MYSQL_FORMAT
Configuration Settings
notify_mysql
The top-level configuration key for defining an MySQL service
endpoint for use with MinIO bucket notifications <minio-bucket-notifications>
.
Use mc admin config set
to set or update an MySQL
service endpoint. The following arguments are required for each
target:
~notify_mysql.dsn_string
~notify_mysql.table
~notify_mysql.format
Specify additional optional arguments as a whitespace
(" "
)-delimited list.
mc admin config set notify_mysql \
dsn_string="username:password@tcp(mysql.example.com:3306)/miniodb"
table="minioevents" \
format="namespace" \
[ARGUMENT="VALUE"] ... \
Data Source Name (DSN) String
Required
Environment Variable
MINIO_NOTIFY_MYSQL_DSN_STRING
Configuration Setting
notify_mysql dsn_string
Specify the data source name (DSN) of the MySQL service endpoint. MinIO expects the following format:
<user>:<password>@tcp(<host>:<port>)/<database>
For example:
"username:password@tcp(mysql.example.com:3306)/miniodb"
Table
Required
Environment Variable
MINIO_NOTIFY_MYSQL_TABLE
Configuration Setting
notify_mysql table
Specify the name of the MySQL table to which MinIO publishes event notifications.
Format
Required
Environment Variable
MINIO_NOTIFY_MYSQL_FORMAT
Configuration Setting
notify_mysql format
Specify the format of event data written to the MySQL service endpoint. MinIO supports the following values:
namespace
-
For each bucket event, MinIO creates a JSON document with the bucket and object name from the event as the document ID and the actual event as part of the document body. Additional updates to that object modify the existing table entry for that object. Similarly, deleting the object also deletes the corresponding table entry.
access
-
For each bucket event, MinIO creates a JSON document with the event details and appends it to the table with a MySQL-generated random ID. Additional updates to an object result in new index entries, and existing entries remain unmodified.
Max Open Connections
Optional
Environment Variable
MINIO_NOTIFY_MYSQL_MAX_OPEN_CONNECTIONS
Configuration Setting
notify_mysql max_open_connections
Specify the maximum number of open connections to the MySQL database.
Defaults to 2
.
Queue Directory
Optional
Environment Variable
MINIO_NOTIFY_MYSQL_QUEUE_DIR
Configuration Setting
notify_mysql queue_dir
Specify the directory path to enable MinIO's persistent event store
for undelivered messages, such as /opt/minio/events
.
MinIO stores undelivered events in the specified store while the MySQL server/broker is offline and replays the stored events when connectivity resumes.
Queue Limit
Optional
Environment Variable
MINIO_NOTIFY_MYSQL_QUEUE_LIMIT
Configuration Setting
notify_mysql queue_limit
Specify the maximum limit for undelivered messages. Defaults to
100000
.
Comment
Optional
Environment Variable
MINIO_NOTIFY_MYSQL_COMMENT
Configuration Setting
notify_mysql comment
Specify a comment to associate with the MySQL configuration.