一、简介
Docker 是一个开源的应用容器引擎,基于 Go 语言。Docker 支持将软件编译成一个镜像,然后在镜像中为软件做好配置,将镜像发布出去,其他使用者就可以直接使用这个镜像,而不需再和以前一样配置各种环境。Docker 容器是完全使用沙箱机制,相互之间不会有任何的接口。其实它和我们使用的虚拟机很像,都采用了虚拟化的技术,不过相较于虚拟机而言,它的占用资源较少、启动更快。我们使用 Docker 安装运行的软件,其实都是运行在一个个独立的 “小型虚拟机”之上的,每个软件就是单独的容器,容器的启动和停止就对应着软件的启动和停止。
二、核心概念
Docker 主机(Host):安装了 Docker 程序的机器。
Docker 客户端(Client):连接 Docker 主机进行操作的机器。
Docker 仓库(Registry):存放了各种已经打包好的软件镜像。
Docker 镜像(Images):软件打包而成的镜像。
Docker 容器(Container):镜像启动后的实例称为一个容器,能够真正运行的软件。
三、例子(含常用命令)
我以在阿里云服务器(Cent OS 7)使用 Docker 安装 MySQL 为例来使用一些常用的命令。
1、安装 Docker
yum install docker
2、使用 Docker 在仓库中搜索镜像
root@xxx:~# docker search mysql
INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
docker.io docker.io/mysql MySQL is a widely used, open-source relati... 7641 [OK]
docker.io docker.io/mariadb MariaDB is a community-developed fork of M... 2492 [OK]
docker.io docker.io/mysql/mysql-server Optimized MySQL Server Docker images. Crea... 579 [OK]
docker.io docker.io/zabbix/zabbix-server-mysql Zabbix Server with MySQL database support 158 [OK]
docker.io docker.io/hypriot/rpi-mysql RPi-compatible Docker Image with Mysql 103
docker.io docker.io/zabbix/zabbix-web-nginx-mysql Zabbix frontend based on Nginx web-server ... 84 [OK]
docker.io docker.io/centurylink/mysql Image containing mysql. Optimized to be li... 59
推荐去 Docker Hub 官网 上去搜索镜像,还可以看到镜像的 tags:
3、下载 MySQL 镜像
docker pull mysql #默认下载最近的
# 也可加上标签下载 docker pull mysql:5.7.24
4、显示当前 Docker 中的所有镜像
root@xxx:~# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/mysql latest 102816b1ee7d 8 days ago 486 MB
docker.io/redis latest 5d2989ac9711 8 days ago 95 MB
docker.io/rabbitmq latest e8261c2af9fe 2 months ago 125 MB
docker.io/elasticsearch latest 5acf0e8da90b 3 months ago 486 MB
5、将镜像实例化成一个容器
root@xxxx:~# docker run --name mysql01 -e MYSQL_PASSWORD=123456 -d mysql
caa85f6d4d3e4e2ca3e5135ef63ff44393640bef0fd6254c2ef31fc29f6b7e26
使用 docker run + 镜像 ID(或者名字)就可以将镜像实例化成容器,其中命令参数 --name 是给容器起名字,
-d 是后台运行。而我上面的 -e 参数是为了能正确使用 MySQL 而设置密码。建议大家将镜像实例化的这个过程中,还是去看相应镜像的官方提供的文档,以便正确实例化镜像。
6、查看所有的容器
root@xxx:~# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
caa85f6d4d3e mysql "docker-entrypoint..." 8 minutes ago Exited (1) 8 minutes ago mysql01
不加上 -a 选项的话是查看正在运行的容器。
7、停止容器
root@xxxx:~# docker stop mysql01
mysql01
也可以使用容器 ID 来停止,查看所有正在运行的容器:
root@xxx:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
8、启动容器
root@xxx:~# docker start mysql01
mysql01
查看所有正在运行的容器:
root@xxx:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
纳尼?没有,不急,演示效果需要。
9、查看对应容器的日志
root@xxx:~# docker logs mysql01
error: database is uninitialized and password option is not specified
You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD
error: database is uninitialized and password option is not specified
You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD
哦,都说了看官方的文档啊,还是不听!原来是上面 docker run 时的 -e 参数的值没有写对,应该是MYSQL_ROOT_PASSWORD
而我写的是MYSQL_PASSWORD
,-_-||,所以接下来就重新来吧。
10、删除容器
删除错误的容器
root@xxx:~# docker rm mysql01
mysql01
删除镜像是 docker rmi 加上镜像 ID。实例化镜像:
root@xxx:~# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
7caa8d461829cb384599aa942fc16f15b4b25a3bd57d5846597ab33028bea620
查看正在运行的容器:
root@xxx:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7caa8d461829 mysql "docker-entrypoint..." About a minute ago Up About a minute 3306/tcp, 33060/tcp mysql01
ok,成功了。
11、在阿里云服务器使用这个 MySQL 容器
root@xxx:~# docker exec -it mysql01 bash
root@7caa8d461829:/#
上面命令的意思可以参考官方文档:
也符合 Docker 沙箱隔离的原则,在 MySQL 容器里开启 shell,即相当于 MySQL 容器内部里面有一个“虚拟机”,在这里面执行相应的 MySQL 操作。使用 mysql 命令连接 MySQL 服务器:
root@7caa8d461829:/# mysql -h 127.0.0.1 -u root -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 12
Server version: 8.0.13 MySQL Community Server - GPL
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.01 sec)
mysql>