docker 中运行 mysql

docker镜像仓库

在宿主机Host的终端执行:
1、 搜索docker镜像仓库中提供的mysql
docker search mysql

2、下载mysql镜像
docker pull mysql

3、改变目录权限,非必须
可以先执行第四步,到第五步时发现容器的状态时是Exited时,执行第六步来查看原因。
如果提示无权限访问时,则需要补上本步骤,这是因为开启SELinux enabled时权限控制更严格所导致
chcon -Rt svirt_sandbox_file_t /data/mysql

4、创建并运行mysql容器
docker run -d --name myMysql -v /data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 mysql
无论是否运行成功,均会得到容器ID
稍微解释一下:

 -d 表示在后台运行容器
 --name 表示为后台运行的容器取别名,便于后续的操作
 -v 用来指定数据卷,将正在运行mysql的容器上的/var/lib/mysql目录映射到宿主机上的/data/mysql目录

5、查看容器的运行状态
docker psdocker ps -a

CONTAINER ID   #容器ID
IMAGE          #镜像名称
COMMAND        #执行的cmd
CREATED        #创建了多久        
STATUS         #容器的status:Up(正在运行) or Exited(不在运行)      
PORTS          #端口映射情况,默认tcp           
NAMES          #容器别名

6、查看容器的运行日志
docker logs myMysql
有些系统中,如果没有设置第三步,可能运行mysql会失败,失败原因可以通过查看容器的运行日志来了解。

7、与容器进行交互
docker exec -t -i myMysql /bin/bash
执行之后会获得容器内的/bin/bash终端,
root@35e1fab30962:/#,其中35e1fab30962是容器ID
此时就可以在这里执行mysql命令了
Demo:

root@35e1fab30962:/# mysql -uroot -p 
#输入之前设置的密码,此处为123456,输入正确后进入到mysql中
mysql> use mysql;
mysql> select * from user\G;

8、停止正在运行的mysql容器
docker stop myMysql

9、启动已创建的mysql容器
docker start myMysql

10、mysql容器的数据导出

docker exec myMysql sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > /some/path/on/your/host/all-databases.sql

110、更多docker命令帮助,请使用
docker --helpdocker cmd --help

999、更多docker中mysql的使用,请参见
mysql的docker镜像仓库

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,691评论 15 147
  • 转载自 http://blog.opskumu.com/docker.html 一、Docker 简介 Docke...
    极客圈阅读 13,575评论 0 120
  • docker基本概念 1. Image Definition 镜像 Image 就是一堆只读层 read-only...
    慢清尘阅读 12,844评论 1 21
  • 文/叶默 那日与你相遇 这纷乱红尘 渐渐的安定 当我流浪了半生 拖着沾满风尘的躯壳 停靠在你出现的街角 四目相对的...
    楠心丶叶默阅读 2,578评论 0 0
  • 写给自己的碎碎念 事实证明,我是不适合日更的。上次参加无戒老师的21天日更挑战营就没有完成,这一次我不知怎么又参加...
    朵朵鱼阅读 3,126评论 26 13