使用docker的mysql镜像

环境
macOS 10.13.2mysql

docker 17.12.0sql

mysql镜像版本 5.7.21docker

确保docker运行数据库

安装mysql镜像
到官网查看mysql镜像相关信息,使用docker指令pull安装orm

docker pull mysql:5.7.21
1
使用docker指令images查看是否安装成功进程

初次运行镜像
docker run --name mysql.5.7.21 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=Nzy19970502 -d mysql:5.7.21
1
—name 为设置容器的名字,我设置为mysql.5.7.21it

-p 端口映射form

-e 为设置执行时的环境变量,在这里我设置mysql的root密码,相关变量可参考官网test

-d 为设置镜像,镜像名:版本容器

完成后使用docker命令ps查看是否成功运行

docker ps
1


使用终端登陆数据库

mysql -h 127.0.0.1 -P 3306 -u root
1

docker run -it --link mysql.5.7.21:mysql --rm mysql:5.7.21 sh -c 'exec mysql -h"$MYSQL_PORT_3306_TCP_ADDR" -p'
1
-it 使用交互模式

–link 链接运行的容器 mysql.5.7.21 为以前首次运行时建立的容器名,冒号后为镜像名

输入密码,到达交互界面

建立一个数据库以及一张表

CREATE DATABASE test;
USE test;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(45) DEFAULT NULL,
  PRIMARY KEY (`id`)
)
1
2
3
4
5
6
7


退出容器并中止
终止当前docker进程

docker stop $(docker ps --filter=ancestor=mysql:5.7.21 --format "{{.ID}}")
1
$() 可获取一条指令的返回值,指令为获取运行镜像mysql:5.7.21容器的ID


再次运行容器
先查看有哪些已存在的容器,并使用ID启动容器

docker ps -a
1
2


启动

docker start 60a4f6de39c2
1
使用cli登陆同上一节第二个指令

导出数据
导出建立的数据库test

要保持mysql运行,导出到桌面

docker exec mysql.5.7.21 /usr/bin/mysqldump -u root --password=Nzy19970502 test > ~/Desktop/test.sql 1

相关文章
相关标签/搜索