fud*_*udo 5 mysql encryption docker mysql-8.0
好的,我正在按照官方 Mysql 文档在 docker 上的 mysql 数据库上启用加密:
这就是我所做的:
early-plugin-load(我使用了mysql docker 映像没有文本编辑器),所以现在是:keyring_file_data/etc/mysql/my.cnfecho stuff >> file[mysqld]
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
datadir = /var/lib/mysql
secure-file-priv= NULL
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Custom config should go here
!includedir /etc/mysql/conf.d/
early-plugin-load=keyring_file.so
keyring_file_data=/usr/local/mysql/mysql-keyring/keyring
Run Code Online (Sandbox Code Playgroud)
[mysqld]
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
datadir = /var/lib/mysql
secure-file-priv= NULL
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Custom config should go here
!includedir /etc/mysql/conf.d/
early-plugin-load=keyring_file.so
keyring_file_data=/usr/local/mysql/mysql-keyring/keyring
Run Code Online (Sandbox Code Playgroud)
cd /usr/local/mysql
mkdir mysql-keyring
chmod 750 mysql-keyring
chown mysql mysql-keyring
chgrp mysql mysql-keyring
Run Code Online (Sandbox Code Playgroud)
2020-03-15T12:30:08.669015Z 0 [ERROR] [MY-011370] [Server] Plugin keyring_file reported: 'File '/usr/local/mysql/mysql-keyring/keyring' not found (OS errno 20 - Not a directory)'
2020-03-15T12:30:08.669036Z 0 [ERROR] [MY-011355] [Server] Plugin keyring_file reported: 'keyring_file initialization failure. Please check if the keyring_file_data points to readable keyring file or keyring file can be created in the specified location. The keyring_file will stay unusable until correct path to the keyring file gets provided'
2020-03-15T12:30:08.669053Z 0 [ERROR] [MY-010202] [Server] Plugin 'keyring_file' init function returned error.
Run Code Online (Sandbox Code Playgroud)
所以看起来我正确启用了该插件,但文件有问题。
我错过了一些步骤吗?
root@8c3670db35d4:/# ls -la /usr/local/mysql/mysql-keyring/
total 8
drwxr-s--- 2 mysql mysql 4096 Mar 15 12:34 .
drwxr-sr-x 3 root staff 4096 Mar 15 12:33 ..
-rw-r----- 1 mysql mysql 0 Mar 15 12:34 keyring
Run Code Online (Sandbox Code Playgroud)
您确定在容器内正确创建了密钥环文件吗?这就是我如何使用正确制作的 Dockerfile 来实现上述目标。
mkdir /tmp/testMysqlKeyring
cd /tmp/testMysqlKeyring
Run Code Online (Sandbox Code Playgroud)keyring.cnf内容如下:
[mysqld]
early-plugin-load=keyring_file.so
keyring_file_data=/usr/local/mysql/mysql-keyring/keyring
Run Code Online (Sandbox Code Playgroud)创建一个Dockerfile包含以下内容的
FROM mysql:8
# Place the dropin config file in the relevant folder
COPY keyring.cnf /etc/mysql/conf.d/
# Create the keyring folder and adapt perms
RUN mkdir -p /usr/local/mysql/mysql-keyring && \
chmod 750 /usr/local/mysql/mysql-keyring && \
chown mysql.mysql /usr/local/mysql/mysql-keyring
Run Code Online (Sandbox Code Playgroud)docker build -t file_keyringed_mysql:latest .
Run Code Online (Sandbox Code Playgroud)docker run -d --rm --name my_keyring_test -e MYSQL_ALLOW_EMPTY_PASSWORD=true file_keyringed_mysql:latest
Run Code Online (Sandbox Code Playgroud)$ docker exec my_keyring_test mysql -e "SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE 'keyring%';"
PLUGIN_NAME PLUGIN_STATUS
keyring_file ACTIVE
Run Code Online (Sandbox Code Playgroud)| 归档时间: |
|
| 查看次数: |
3138 次 |
| 最近记录: |