拉取镜像
docker pull mysql:5.5 # 拉取 mysql 5.5
docker pull mysql # 拉取最新版mysql镜像
docker image ls # 查看拉取结果
创建容器
# -name 容器名
# -e 配置信息
# 配置 root 用户登录密码
# -p 端口映射, 主机端口 3306 映射到 容器 3306
# -d 容器后台运行
docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=YourPWD -d mysql:5.5
# 建立映射目录方式运行(推荐,方便数据备份和保证数据安全)
# -v 建立主机目录和容器目录映射 [主机目录]:[容器目录]
docker run -p 3306:3306 --name mysql \
-v /usr/local/docker/mysql/conf:/etc/mysql \
-v /usr/local/docker/mysql/logs:/var/log/mysql \
-v /usr/local/docker/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=YourPWD \
-d mysql:5.5
# 查看容器运行状态
docker container ls
连接测试
docker 本地连接
进入 docker 连接 mysql 客户端
# 进入容器
docker exec -it mysql bash
# 连接数据库
mysql -u root -p
远程连接
访问
host: 127.0.0.1
port: 3306
user: root
password: YourPWD
如果容器运行正常,无法访问到,可能有两个原因
- 防火墙阻拦
systemctl status firewalld # 查看防火墙状态
firewall-cmd --zone=public --add-port=3306/tcp --permanent # 开放端口
firewall-cmd --reload # 重载防火墙配置
# 关闭防火墙
systemctl stop firewalld
- 没有设置远程访问账号
mysql使用mysql数据库中的user表来管理权限,修改user表就可以修改权限(只有root账号可以修改)
# 登录
mysql -u root -p YourPWD
# 切库
use mysql;
# 查看
select host,user,password from user;
# 授权
grant all privileges on *.* to root@'%' identified by "password";
flush privileges;