Docker安装mysql及mysql数据库的导入与导出

一、Docker 安装 MySQL

  • 方法一、docker pull mysql
    查找Docker Hub上的mysql镜像
docker search mysql

在这里插入图片描述

这里我拉取的官方的镜像,标签为5.6.26

docker pull mysql:5.6.26
docker images |grep mysql

在这里插入图片描述

二、使用mysql镜像

  1. 运行容器
docker run -p 3306:3306 --name mymysql -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6.26

》

参数解释:
1、–name 容器名字
2、-p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
3、-d 后台运行 mysql/mysql-server:5.5 下载的镜像名字加标签
4、-e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
5、-v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。
6、-v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。
7、-v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。

  1. 查看容器启动情况

在这里插入图片描述

  1. 修改mysql允许远程连接
#通过这个命令进入容器内
docker exec -it mysql5.5 bash

#连接mysql
mysql -u root -p

#修改mysql允许远程连接
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION
FLUSH PRIVILEGES

本机连接容器内的数据库

# 本机连接容器内的数据库,(我们将容器内的3306端口映射到了本机的3306,所以我们通过3306端口访问)
mysql -u root -p -h 127.0.0.1 -P 3306

三、Docker mysql数据库的导入与导出

Docker中mysql数据库的导入与导出 与 直接对Linux中的mysql操作一样,只不过前者需要进入docker容器进行操作。
1、查看容器

docker ps

2、首先进入你的mysql容器中

docker exec -it mymysql /bin/bash

3、进行mysql存放数据的文件夹

whereis mysql

我的mysql data存放位置为/var/lib/mysql/
在这里插入图片描述

4、导出需要的数据

mysqldump -u user -p dbname tablename >table.sql

也可以远程拉取:

mysql -uroot -p112233(密码) -h 10.10.10.10(IP地址) -P 3306(端口号)

5、导入数据
方式一:

mysql -u user -p dbname < /var/lib/mysql/table.sql

方式二:
进入容器,然后进入mysql:

ocker exec -it mymysql mysql -u user -p
show databases;
use boss;
source /var/lib/mysql/table.sql

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值