Linux 下使用 Docker 安装 MySQL

1、下载 mysql

bash 复制代码
docker pull mysql:5.7.36

2、启动 mysql

bash 复制代码
docker run -p 3306:3306 --name mysql \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7.36

命令解析:

-p 指定容器端口到主机端口的映射

--name 指定容器名称

-v 将主机上的对应目录挂载到容器的对应目录

-e 设置环境变量

-d 让容器在后台运行

3、修改 mysql 配置文件 my.cnf

bash 复制代码
vim /mydata/mysql/conf/my.cnf

更新配置文件

ini 复制代码
[client]
port = 3306
password = 123456
default-character-set=utf8

[mysql]
default-character-set=utf8

[mysqld]
port = 3306
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve

4、重启 mysql

bash 复制代码
docker restart mysql

5、docker 查看日志

bash 复制代码
docker logs mysql
docker logs -f mysql  # 实时查看

6、进入 mysql,连接 mysql 命令行

bash 复制代码
[root@xxx ~]# docker exec -it mysql /bin/bash
root@e83a22cd6197:/# mysql -uroot -p123456
mysql> exit
Bye
root@e83a22cd6197:/# exit
# 连接成功,即安装成功。

7、设置 mysql 自动启动

bash 复制代码
# 开启自启
sudo docker update mysql --restart=always
# 关闭自启
sudo docker update mysql --restart=no

8、mysql 权限设置语句

bash 复制代码
use mysql;

show tables;
select user, host from user;

# 允许远程访问
update user set host = '%' where user = 'root' and host = 'localhost';

# 添加一个指定 ip 的 root 用户
create user 'root'@'xxx.xxx.xxx.xxx' identified by '123456';
grant all privileges on *.* to 'root'@'xxx.xxx.xxx.xxx' with grant option;

# 更新
update user set host = 'xxx.xxx.%.%' where user = 'root' and host = 'xxx.xxx.xxx.xxx';
flush privileges;

9、注意,如果不指定 mysql 版本为 5.7.36,而是 5.7。可能出现错误

bash 复制代码
mysqld: Can't read dir of '/etc/mysql/conf.d/' (Errcode: 2 - No such file or directory)

因为 mysql 新版本 5.7.43,配置文件路径改了,用原来的方式挂载目录会失效。

相关推荐
屁股割了还要学19 分钟前
【Linux入门】常用工具:yum、vim
linux·运维·服务器·c语言·c++·学习·考研
云计算练习生19 分钟前
linux shell编程实战 03 数组:批量处理数据
linux·运维·服务器·数组·shell编程
王道长服务器 | 亚马逊云1 小时前
AWS Elemental MediaConvert:视频转码不再难
linux·服务器·网络·云计算·音视频·aws
Jm_洋洋1 小时前
【Linux系统编程】程序替换:execve(execl、execlp、execle、execv、execvp、execvpe)
linux·运维·c语言·开发语言·程序人生
HIT_Weston1 小时前
14、【Ubuntu】【VSCode】VSCode 断联问题分析:hostname(二)
linux·vscode·ubuntu
冲上云霄的Jayden1 小时前
bash执行脚本 CondaError: Run ‘conda init‘ before ‘conda activate‘
linux·ubuntu·conda·bash·init·activate
驱动探索者2 小时前
影石Insta360发展史:从深圳公寓到全球影像创新标杆
linux
Wang's Blog2 小时前
Linux小课堂: SSH 免密登录原理与实现之基于公钥认证的安全连接机制
linux·安全·ssh
戴草帽的大z2 小时前
交叉编译FFmpeg:从x264到RK3588部署实战
linux·ffmpeg·rk3588·h.264·aarch64
qiuiuiu4133 小时前
正点原子RK3568学习日志19- Linux错误处理 字符驱动框架完全体
linux·服务器·学习·ubuntu