docker拉取镜像的命令为

docker pull image[:TAG]

如果我们想安装的mysql版本不是最新的版本,则需要填充TAG,如果不带上TAG,则默认安装的为最新版本,虽然可以通过docker search查询相关的镜像信息,但该命令不会显示其TAG,我们可以通过docker hub官网来获取到docker中镜像的TAG,如查询mysql的TAG

1、登录docker hub网站https://hub.docker.com/,并搜索mysql,得到mysql相关的Containers

2、点击右侧查询出的mysql container(https://hub.docker.com/_/mysql?tab=tags),并选择TAGS标签,即可看到mysql相关的TAG

这里我们安装的是8.0.17的mysql

一、拉取镜像(如果使用docker run命令,可以忽略该步,docker run在不存在镜像的情况下,会自动拉取镜像,并且启动该镜像对应的容器,如果已经存在镜像,则直接启动镜像对应容器)

docker pull mysql:8.0.

二、启动mysql容器,其中--name为指定容器名称,-p暴露内部容器端口给宿主机,前一个端口为宿主机端口, -e为设置环境变量,-d为后台运行,mysql:8.0.17为镜像名称,这个表示我们要启动的镜像,如果不存在,则会下载一个8.0.17的镜像。如果已经拉取了镜像,也可以将mysql:8.0.17

替换成docker images查询出的IMAGE ID

docker run --name mysql_test -p : -e MYSQL_ROOT_PASSWORD= -d mysql:8.0.

三、查看容器运行状态

docker ps

四、进入l容器,退出容器可以使用exit。其中也可以使用NAMES列对应mysql_test代替CONTAINER ID,下同

docker exec -it a77ede15e664 bash

五、连接容器中mysql。若宿主机安装了mysql客户端,则可以通过mysql -uroot -p -h 127.0.0.1连接,注意,必须要添加上-h,因为宿主机连接mysql容器需要通过tcp,而宿主机连接宿主机本地的mysql则不需要,使用socket就可以连接。如果宿主机未安装mysql客户端,则可通过如下命令连接mysql容器中mysql server

docker exec -it a77ede15e664 bash -c "mysql -uroot -p"

六、停止容器。通过docker ps查看已经不存在运行中的容器了

docker stop a77ede15e664

七、查看所有容器。可以看到上一步骤停止mysql容器后,mysql处于Exited状态

docker ps -a

八、启动一个停止的容器

docker start a77ede15e664

九、查看某个容器的具体信息

docker inspect a77ede15e664

十、查看当前宿主机已存在镜像

docker images

十一、删除容器。删除前先停止容器,否则将会出现如下错误,-f为强制停止,最好不要使用。按照正常操作先停止再删除

[root@localhost ~]# docker rm a77ede15e664
Error response from daemon: You cannot remove a running container a77ede15e6644527b4e55b8660347f23a331a75bab03511aea1f7c10761ef807. Stop the container before attempting removal or use -f
[root@localhost ~]#

十二、删除镜像。删除镜像前可以通过docker images查询当前镜像的信息,并根据IMAGE ID删除,删除镜像时需要保证该镜像没有容器在使用,否则会出现如下错误

[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/mysql 8.0. 2151acc12881 weeks ago MB
[root@localhost ~]# docker rmi 2151acc12881
Error response from daemon: conflict: unable to delete 2151acc12881 (cannot be forced) - image is being used by running container a77ede15e664
[root@localhost ~]#

十三、拷贝文件。如下示例为在宿主机新建一个test文件,并填充内容,将该文件拷贝到mysql容器/下,进入到容器,并查看拷贝的文件内容(MySQ配置文件在容器中的位置为/etc/mysql/my.cnf)

[root@localhost ~]# echo "it is a test" >> test
[root@localhost ~]# docker cp test a77ede15e664:/
[root@localhost ~]# docker exec -it a77ede15e664 bash
root@a77ede15e664:/# ls
bin boot dev docker-entrypoint-initdb.d entrypoint.sh etc home lib lib64 media mnt opt proc root run sbin srv sys test tmp usr var
root@a77ede15e664:/# cat test
it is a test
root@a77ede15e664:/#

十四、查看容器相关日志

docker logs a77ede15e664

mysql在docker中安装也可以参照mysql官方文档

https://dev.mysql.com/doc/refman/5.7/en/docker-mysql-getting-started.html

另外,在启动mysql时,如果不确定mysql启动可配置的启动环境参数是那些,可以先通过docker ps --no-trunc查找到当前容器启动时使用的COMMAND,然后找到其中对应的sh文件,在里面即可查找到可以设置的环境变量

如mysql使用command

find / -name docker-entrypoint.sh查找出该sh文件后,打开,可以找到我们在上面启动mysql时所使用的环境变量MYSQL_ROOT_PASSWORD,通过该脚本,也可以看出,如果我们不希望设置密码,添加环境变量MYSQL_ALLOW_EMPTY_PASSWORD即可

docker mysql容器的安装使用的更多相关文章

  1. docker mysql 容器报too many connections 引发的liunx磁盘扩容操作

    症状每次删除mysql容器重启没两分钟又报标题错 df -h 命令查看各个挂载空间应用情况发现root home var 三个文件目录挂载的空间满了 网上百度了一下liunx磁盘扩容操作,fdisk ...

  2. docker 运行容器,安装Nginx

    ########################################## #运行容器 #安装Nginx #搜索.下载镜像 docker search nginx docker pull n ...

  3. 一次生产环境的docker MySQL故障

    问题 昨天下午本来要去吃下午茶,然后前端小伙伴突然说接口怎么崩了,我登上sentry一看,报错了 (2005, "Unknown MySQL server host 'mysql' (-3) ...

  4. MySQL安装+Navicat_Premium(安装+破解)+Navicat_Premium中MySQL的localhost不能正常连接+不能连接Docker启动容器中的MySQL

    MySQL安装 安装MySQL 我这里安装的是 MySQL 8.0 Command Line Client 下载+安装 详情见 https://www.cnblogs.com/taopanfeng/p ...

  5. docker 安装tomcat容器和mysql容器

    1. docker pull mysql:5.6 2.docker run -p 3306:3306 --name mysql -v /data/mysql/conf:/etc/mysql/conf. ...

  6. Linux(Manjaro) - Docker - MySQL 安装配置

    Linux(Manjaro) - Docker - MySQL 安装配置 拉取mysql镜像 # 使用网易的 MySQL 镜像地址 docker pull hub.c.163.com/library/ ...

  7. docker + mysql安装sonarqube

    docker sonarqube地址:https://hub.docker.com/_/sonarqube docker mysql地址:https://hub.docker.com/_/mysql ...

  8. SpringBoot Docker Mysql安装,Docker安装Mysql

    SpringBoot Docker Mysql安装,Docker安装Mysql ================================ ©Copyright 蕃薯耀 2018年4月8日 ht ...

  9. Docker搭建Mysql容器

    转载自:http://blog.csdn.net/Mungo/article/details/78521832?locationNum=9&fps=1 本文介绍如何使用docker迅速搭建My ...

随机推荐

  1. ES6入门十一:Generator生成器、async+await、Promisify

    生成器的基本使用 生成器 + Promise async+await Promise化之Promisify工具方法 一.生成器的基本使用 在介绍生成器的使用之前,可以简单理解生成器实质上生成的就是一个 ...

  2. python初始化定长列表

    >>> lst = ['x' for n in range(5)] >>> print(lst) ['x', 'x', 'x', 'x', 'x'] >> ...

  3. python读取ubuntu系统磁盘挂载情况

    磁盘挂载 利用df -h  的命令 此功能主要实现了python 命令行执行函数进行解析df 返回的数据   代码如下 : # liunx 系统获取 磁盘挂载的情况 代码 #!/usr/bin/pyt ...

  4. 10.自定义EL函数和自定义标签

    需要在JSP页面中进行一些常见逻辑操作(如对字符串进行操作),首先考虑是否可以用到sun公司提供的EL函数库(fn.tld)和JSTL 核心标签库 如果sun公司的EL函数库没有或者无法满足,就需要自 ...

  5. SpringCloud01——服务的注册和发现

    SpringCloud01--服务的注册和发现 一.微服务的注册和发现 我们在微服务中,往往有服务提供者,服务消费者和服务注册中心.我们之前学习的Zookeeper就是一个注册中心.但是在官方的Spr ...

  6. 接口自动化平台——httprunnermanager

    Windows 环境搭建 1. 下载安装pip install httprunner==1.4.2hrun -V #1.4.2har2case -V #0.1.8 2. httprunnermanag ...

  7. linux下top命令的使用

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器 视图参数含义 top视图分为两部分:操作系统资源概况信息和进程信息.首先分析资源 ...

  8. JavaScript实现数据的双向绑定

    接触到Angulr.js和Vue.js后,提到最多的就是双向绑定 下面将用JavaScript实现数据的双向绑定 <!DOCTYPE html> <html> <head ...

  9. BZOJ3073 [Pa2011]Journeys[最短路—线段树优化建边]

    新技能get✔. 线段树优化建边主要是针对一类连续区间和连续区间之间建边的题,建边非常的优秀.. 这题中,每次要求$[l1,r1]$每一点向$[l2,r2]$每一点建无向边,然后单元最短路. 暴力建边 ...

  10. 用vs2013开启一个C拖控件的项目

    visual studio作为一款集成开发环境备受青睐,笔者尤其喜爱它的拖控件功能,程序员应该追求业务逻辑和实际功能的优化,而不是把时间消耗在编写窗体和按钮上 笔者曾翻阅中关村图书大厦,西单图书大厦, ...