1、安裝 html
mkdir -p ./docker/mysql
cd docker/
cd mysql/
mkdir conf
mkdir data
mkdir logsmysql
mkdir mysql-filessql
cd conf docker
vim my.cnfvim
[mysqld]bash
user=mysqlide
docker pull mysql
docker run -e MYSQL_ROOT_PASSWORD=KMSD2016064 -d -p 3306:3306 --name mysql01 mysql編碼
docker run -e MYSQL_ROOT_PASSWORD=KMSD2016064 -d -p 3306:3306 -v ~/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf -v ~/docker/mysql/data:/var/lib/mysql -v ~/docker/mysql/logs:/logs -v ~/docker/mysql/mysql-files:/var/lib/mysql-files --name mysql01 mysql加密
2、修改默認字符集並建立用戶spa
docke exec -it mysql01 bash
mysql -uroot -p
修改默認字符集
show variables like '%char%'
+--------------------------+--------------------------------+
| Variable_name | Value |
+--------------------------+--------------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | utf8mb4 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | utf8mb4 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+
vim mycnf
#insert [mysqld] user=mysql character-set-server=utf8 [client] default-character-set=utf8 [mysql] default-character-set=utf8
mysql> show variables like '%char%';
+--------------------------+--------------------------------+
| Variable_name | Value |
+--------------------------+--------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+
8 rows in set (0.01 sec)
使用Navicat訪問,因爲使用的是mysql最新版本,mysql8 以前的版本中加密規則是mysql_native_password,而在mysql8以後,加密規則是caching_sha2_password,加密方式變了
alter user 'root'@'%' identified by 'KMSD2016064' password expire never; 改變加密方式
alter user 'root'@'%' identified with mysql_native_password by 'KMSD2016064'; 更新用戶密碼
flush privileges;
正常狀況下咱們不會把root暴露出去,因此須要建立新的用戶
create user 'jesen'@'%' identified by 'KMSD2016064';
grant all privileges on *.* to 'jesen'@'%';
alter user 'jesen'@'%' identified with mysql_native_password by 'KMSD2016064';
3、官方參考
字符集編碼和建立用戶密碼也能夠在docker run 的時候指定,具體可參考 https://dev.mysql.com/doc/mysql-installation-excerpt/5.7/en/docker-mysql-more-topics.html:
docker run -d -p 3306:3306 -e MYSQL_USER="test" -e MYSQL_PASSWORD="password" -e MYSQL_ROOT_PASSWORD="password" --name [Name] [ImageName] --character-set-server=utf8 --collation-server=utf8_general_ci