Docker如何获取MySQL镜像

这篇文章主要讲解了“Docker如何获取MySQL镜像”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Docker如何获取MySQL镜像”吧!

10年积累的成都网站制作、网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先建设网站后付款的网站建设流程,更有兰西免费网站建设让你可以放心的选择与我们合作。

6. 基础

本节我们以运行MySQL实例为例,介绍基础使用。


使用 docker --help 查看支持的所有命令

6.1. 获取MySQL镜像

  • 首先我们从hub.docker.com上获取MySQL镜像

这里有两种方式,一是使用 search命令:

root@ubuntu:~# docker search mysql NAME                       DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED 
mysql                      MySQL is a widely used, open-source relati...   1253      [OK]  
mariadb                MariaDB is a community-developed fork of M...   280       [OK]   
mysql/mysql-server         Optimized MySQL Server Docker images. Crea...   58                   [OK]  
centurylink/mysql          Image containing mysql. Optimized to be li...   29                   [OK]  
...

另外我们也可以在网页上查询更详细的说明:

Docker如何获取MySQL镜像


STARS 表示收藏的数量,PULLS表示下载的数量,OFFICIAL表示是官方镜像(此处表示是否是MySQL官方发布)
  • 我们下载第一个官方的镜像

root@ubuntu:~# docker pull mysql  Pulling repository mysql 196db1908492:  
Download complete 575489a51992:  
Download complete  
...  
Status: Downloaded newer image for mysql:latest

Docker镜像的命名格式 <用户名,官方镜像不需要/>镜像名称

6.2. 查看本机镜像

  • 查看本机的所有镜像

root@ubuntu:~# docker images REPOSITORY             TAG                 IMAGE ID            CREATED             VIRTUAL SIZE  
mysql                  5.7                 196db1908492        6 days ago          359.8 MB  
mysql                  5.7.9               196db1908492        6 days ago          359.8 MB  
mysql                  latest              196db1908492        6 days ago          359.8 MB  
...

6.3. 运行MySQL镜像

  • 运行MySQL镜像

root@ubuntu:~# docker run --name app1-db -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7  
2dee953f85d697ffcb78ac795f06e1a22731ae373b154178ea6220ce9b9c6e04

--name 指定容器名称,-e 指定特殊的一些变量,-d 表示后台运行(服务化)

6.4. 查看本机容器

  • 查看本机的所有在运行容器

root@ubuntu:~# docker ps CONTAINER ID        IMAGE      COMMAND                CREATED             STATUS        PORTS     NAMES 2dee953f85d6         
mysql:5    "/entrypoint.sh mysq   6 seconds ago       Up 5 seconds  3306/tcp  app1-db

docker ps -a 可以查看所有容器(包含没有运行的)
  • 然后呢,怎么连接?我们需要一个IP和端口,但上面的运行并没有对外暴露端口,所以我们要重新运行一个容器


Docker目前(v1.7)还不支持为容器绑定端口,如有此需求请查看如何为运行中的容器增加访问端口

6.5. 删除MySQL容器

  • 我们先删除刚才的容器

root@ubuntu:~# docker rm -f app1-db app1-db

-f 表示强制删除运行中的容器

这会删除容器中的所有数据。不科学呀?那我想删除容器时保留某些数据(如这里的数据库文件)怎么办?我们往下看:
  • 重新运行MySQL镜像

root@ubuntu:~# docker run --name app1-db -e MYSQL_ROOT_PASSWORD=123456 -d -p 3308:3306 -v /opt/mysql_data:/var/lib/mysql mysql:5.7  
1add96f289a1b8744500a4a6709af6e2e0628b97797e8470be75efe67e2005f4

-p表示将外部访问的3308端口映射到容器的3306端口,由于MySQL镜像默认允许对外开放3306端口(我为什么知道?看它的dockerfile,后面会有说明),所以也可以直接用-P,这样的话外部访问3306也被映射到容器的3306端口上

-v参数可以宿主机的目录映射到将容器内目录,上例-v /opt/mysql_data:/var/lib/mysql会将宿主机/opt/mysql_data映射到容器/var/lib/mysql(已知此目录为MySQL的数据目录),这样可以保证容器删除时对应目录的数据不被删除(因为这个目录是宿主机上的),这点很重要,实际使用中几乎所有容器都要做此映射!
  • 有了端口之后那IP呢?IP实际上就是你docker宿主机的IP


Docker的访问机制简单说明:Docker所有的对外服务统一使用宿主机IP+特定端口,当一个请求发起时会经由宿主面的iptables根据容器创建时的端口规则转发到对应的容器处理。
  • 好了,现在我们做个连接测试,通过

Docker如何获取MySQL镜像

6.6. 停止/运行/重启MySQL容器

  • 当然我们也可以对容器做停止/运行/重启 操作:

root@ubuntu:~# docker stop app1-db app1-db  
root@ubuntu:~# docker start app1-db app1-db  
root@ubuntu:~# docker restart app1-db app1-db

感谢各位的阅读,以上就是“Docker如何获取MySQL镜像”的内容了,经过本文的学习后,相信大家对Docker如何获取MySQL镜像这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


标题名称:Docker如何获取MySQL镜像
网站链接:http://myzitong.com/article/jdispg.html