CentOS7下Docker的安装与使用

时间:2022-02-17 00:08:19

前言

简介

Docker 是一个开源的应用容器引擎,基于 Go 语言,并遵从 Apache2.0 协议开源。

Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到装载了任何流行的 Linux 版本系统的机器上,也可以实现虚拟化。

容器是完全使用沙箱机制,相互之间不会有任何接口,更重要的是容器性能开销极低。

Docker 支持将软件编译成一个镜像,在镜像中对各种软件做好配置,然后将镜像发布出去,其他使用者可以直接使用这个镜像。运行中的这个镜像成为容器,容器的启动是非常快速的。类似 windows 中的 ghost 操作系统,安装完成即拥有了很多预装软件。

核心概念

  • Docker 镜像(Images):Docker 镜像是用于创建 Docker 容器的模板。
  • Docker 容器(Container):容器是独立运行的一个或一组应用。
  • Docker 客户端(Client):客户端通过命令行或者其它工具来使用 Docker API(https://docs.docker.com/develop/sdk)来与 Docker 的守护进程通信。
  • Docker 主机(Host):一个物理或者虚拟的机器用于运行 Docker 守护进程和容器。
  • Docker 仓库(Registry):Docker 仓库用来保存镜像,可以理解为代码版本控制中的代码仓库。Docker Hub(https://hub.docker.com)提供了庞大的镜像集合供使用。

使用 Docker 的步骤:

  1. 安装 Docker。
  2. 取 Docker 仓库中找到要使用软件对应的镜像。
  3. 使用 Docker 运行这个镜像,运行中的镜像就是一个 Docker 容器。
  4. 对容器的启动与停止就是对软件的启动停止。

安装

检查内核版本

Docker 要求 CentOS 系统的内核版本高于 3.10,查看当前系统内核版本:

uname -r

升级软件包及内核

如若你的 CentOS7 系统的内核版本低于了 3.10,那么可以通过以下命令升级:

yum update

注意,不适用 CentOS6。

安装Docker

执行下面命令来安装 Docker:

yum install docker

启动Docker

执行下面命令来启动 Docker:

systemctl start docker

查看 Docker 版本信息以检查是否安装成功:

[root@localhost ~]# docker -v
Docker version 1.13., build b2f74b2/1.13.

设置开机启动

systemctl enable docker

常用操作

镜像操作

查询镜像

如果我们要在 Docker 仓库中查询一个镜像,比如我们需要一个 MySql 镜像,可通过如下操作进行查询:

[root@localhost ~]# docker search mysql
索引名称   镜像名称                                   描述                           关注    是否官方 是否自动构建
INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
docker.io docker.io/mysql MySQL is a widely used, open-source relati... [OK]
docker.io docker.io/mariadb MariaDB is a community-developed fork of M... [OK]
docker.io docker.io/mysql/mysql-server Optimized MySQL Server Docker images. Crea... [OK]
docker.io docker.io/percona Percona Server is a fork of the MySQL rela... [OK]
docker.io docker.io/zabbix/zabbix-server-mysql Zabbix Server with MySQL database support [OK]
docker.io docker.io/hypriot/rpi-mysql RPi-compatible Docker Image with Mysql
docker.io docker.io/zabbix/zabbix-web-nginx-mysql Zabbix frontend based on Nginx web-server ... [OK]
docker.io docker.io/centurylink/mysql Image containing mysql. Optimized to be li... [OK]
docker.io docker.io/1and1internet/ubuntu--nginx-php-phpmyadmin-mysql- ubuntu--nginx-php-phpmyadmin-mysql- [OK]
docker.io docker.io/centos/mysql--centos7 MySQL 5.7 SQL database server
docker.io docker.io/mysql/mysql-cluster Experimental MySQL Cluster Docker images. ...
docker.io docker.io/tutum/mysql Base docker image to run a MySQL database ...
docker.io docker.io/bitnami/mysql Bitnami MySQL Docker Image [OK]
docker.io docker.io/schickling/mysql-backup-s3 Backup MySQL to S3 (supports periodic back... [OK]
docker.io docker.io/zabbix/zabbix-web-apache-mysql Zabbix frontend based on Apache web-server... [OK]
docker.io docker.io/linuxserver/mysql A Mysql container, brought to you by Linux...
docker.io docker.io/zabbix/zabbix-proxy-mysql Zabbix proxy with MySQL database support [OK]
docker.io docker.io/centos/mysql--centos7 MySQL 5.6 SQL database server
docker.io docker.io/circleci/mysql MySQL is a widely used, open-source relati...
docker.io docker.io/mysql/mysql-router MySQL Router provides transparent routing ...
docker.io docker.io/openshift/mysql--centos7 DEPRECATED: A Centos7 based MySQL v5. ima...
docker.io docker.io/jelastic/mysql An image of the MySQL database server main...
docker.io docker.io/ansibleplaybookbundle/mysql-apb An APB which deploys RHSCL MySQL [OK]
docker.io docker.io/cloudposse/mysql Improved `mysql` service with support for ... [OK]
docker.io docker.io/widdpim/mysql-client Dockerized MySQL Client (5.7) including Cu... [OK]

下载镜像

如果我们要将 Docker 仓库中的镜像下载到本地,则可使用下面命令:

[root@localhost ~]# docker pull mysql
Using default tag: latest
Trying to pull repository docker.io/library/mysql ...
latest: Pulling from docker.io/library/mysql
27833a3ba0a5: Pull complete
864c283b3c4b: Pull complete
cea281b2278b: Pull complete
8f856c14f5af: Pull complete
9c4f38c23b6f: Pull complete
1b810e1751b3: Pull complete
5479aaef3d30: Pull complete
ded8fa2e1614: Pull complete
636033ba4d2e: Pull complete
902e6010661d: Pull complete
dbe44d2bf055: Pull complete
e906385f419d: Pull complete
Digest: sha256:a7cf659a764732a27963429a87eccc8457e6d4af0ee9d5140a3b56e74986eed7
Status: Downloaded newer image for docker.io/mysql:latest

上述操作默认下载的是最新版本(latest)的 mysql 镜像,我们还可以通过 tag 参数来下载指定版本的镜像,格式为 docker pull 镜像名[:tag] 。比如我们要下载 mysql 5.6 的镜像,则可以使用使用下面操作:

[root@localhost ~]#  docker pull mysql:5.6
Trying to pull repository docker.io/library/mysql ...
5.6: Pulling from docker.io/library/mysql
27833a3ba0a5: Already exists
864c283b3c4b: Already exists
cea281b2278b: Already exists
8f856c14f5af: Already exists
9c4f38c23b6f: Already exists
688342d0934f: Pull complete
1f90d0188066: Pull complete
6d31565f1a00: Pull complete
12062e921a90: Pull complete
066ae780ca9a: Pull complete
f6eece737bcc: Pull complete
Digest: sha256:de2913a0ec53d98ced6f6bd607f487b7ad8fe8d2a86e2128308ebf4be2f92667
Status: Downloaded newer image for docker.io/mysql:5.6

可使用的 tag 版本可以在 Docker Hub 官网上看到。

查看已下载镜像

如果我们需要查看本地仓库中已经下载了哪些镜像,则可使用下面命令:

[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/mysql 5.6 bc788a6a2745 hours ago MB
docker.io/mysql latest 7bb2586065cd hours ago MB

删除已下载镜像

如果我们要删除一个已下载的镜像,则可通过 docker rmi <IMAGE ID> 来操作,例如:

[root@localhost ~]# docker rmi 7bb2586065cd
Untagged: docker.io/mysql:latest
Untagged: docker.io/mysql@sha256:a7cf659a764732a27963429a87eccc8457e6d4af0ee9d5140a3b56e74986eed7
Deleted: sha256:7bb2586065cd50457e315a5dab0732a87c45c5fad619c017732f5a13e58b51dd
Deleted: sha256:5362a97701b6ba3d39453e9e8b435b4cc3d7b493fb506780b8e2ec9c3ee20b8e
Deleted: sha256:91ae6166a0c2de34f36c2bb6b66ba3782ec6186337b87362961fad845f5ce236
Deleted: sha256:ae307e2a0c006325d4b96c1f0a40b1ae35cf9a034435ec9925291dafed69e01f
Deleted: sha256:b000e0eccfc8ce916a49183e5168c11b65085d940d76ef9c7c264462aa5f1f5c
Deleted: sha256:97a8302a9556468404f8aeda16ef35d94075cc95ed72249fb2bc2835984e8dd5
Deleted: sha256:4e83d49f100fcd78f57b8f1844faad134d8328c5280be14d85a61ae7c7ffb981
Deleted: sha256:11f5b5e11d25f08da50ca38993f02a3194565beaa516b66970adbbffa58141e0

容器操作

下面是以使用 tomcat 镜像为例的所有操作:

搜索镜像:

[root@localhost ~]# docker search tomcat
INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
docker.io docker.io/tomcat Apache Tomcat is an open source implementa... [OK]
docker.io docker.io/tomee Apache TomEE is an all-Apache Java EE cert... [OK]
docker.io docker.io/dordoka/tomcat Ubuntu 14.04, Oracle JDK and Tomcat ba... [OK]
docker.io docker.io/davidcaste/alpine-tomcat Apache Tomcat / using Oracle Java / wi... [OK]
docker.io docker.io/bitnami/tomcat Bitnami Tomcat Docker Image [OK]
docker.io docker.io/cloudesire/tomcat Tomcat server, // [OK]
docker.io docker.io/meirwa/spring-boot-tomcat-mysql-app a sample spring-boot app using tomcat and ... [OK]
docker.io docker.io/aallam/tomcat-mysql Debian, Oracle JDK, Tomcat & MySQL [OK]
docker.io docker.io/tutum/tomcat Base docker image to run a Tomcat applicat...
docker.io docker.io/jeanblanchard/tomcat Minimal Docker image with Apache Tomcat
docker.io docker.io/arm32v7/tomcat Apache Tomcat is an open source implementa...
docker.io docker.io/maluuba/tomcat7-java8 Tomcat7 with java8.
docker.io docker.io/rightctrl/tomcat CentOS , Oracle Java, tomcat application s... [OK]
docker.io docker.io/amd64/tomcat Apache Tomcat is an open source implementa...
docker.io docker.io/arm64v8/tomcat Apache Tomcat is an open source implementa...
docker.io docker.io/fabric8/tomcat- Fabric8 Tomcat Image [OK]
docker.io docker.io/99taxis/tomcat7 Tomcat7 [OK]
docker.io docker.io/camptocamp/tomcat-logback Docker image for tomcat with logback integ... [OK]
docker.io docker.io/1and1internet/debian--java--tomcat-8.5 Our tomcat 8.5 image [OK]
docker.io docker.io/cfje/tomcat-resource Tomcat Concourse Resource
docker.io docker.io/jelastic/tomcat An image of the Tomcat Java application se...
docker.io docker.io/oobsri/tomcat8 Testing CI Jobs with different names.
docker.io docker.io/picoded/tomcat7 tomcat7 with jre8 and MANAGER_USER / MANAG... [OK]
docker.io docker.io/s390x/tomcat Apache Tomcat is an open source implementa...
docker.io docker.io/swisstopo/service-print-tomcat backend tomcat for service-print "the true... 0

拉取镜像:

[root@localhost ~]# docker pull tomcat
Using default tag: latest
Trying to pull repository docker.io/library/tomcat ...
latest: Pulling from docker.io/library/tomcat
22dbe790f715: Pull complete
0250231711a0: Pull complete
6fba9447437b: Pull complete
4afad9c4aba6: Pull complete
12fce9923c9d: Pull complete
0dd81083d77e: Pull complete
4c2afc6ff72d: Pull complete
a62332a260f5: Pull complete
96dfb5ad080f: Pull complete
782f63228ce1: Pull complete
d610fffe30ad: Pull complete
Digest: sha256:aacce4e5ca37a3b8241c544deffd65f4cafbfb1a2fb2066f97621253c34f7dc4
Status: Downloaded newer image for docker.io/tomcat:latest

创建并启动容器

使用镜像创建并启动一个容器,命令格式如下:

docker run --name <container-name> [-d] <image-name>[:tag]

其中 container-name 为将启动容器的自定义实例名称, -d 表示后台运行, image-name 为镜像名称, :tag 为版本表示。如:

[root@localhost ~]# docker run --name mytomcat -d tomcat:latest
80b379dfb0c8a3038ab7c4a969049331c2dc3e59f1281d35390e1193ad04e349

此时 tomcat 容器就已经运行了。

查看运行中的容器

如果我们想要查看在 Docker 中正在运行的容器,则可使用下面命令:

[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
80b379dfb0c8 tomcat:latest "catalina.sh run" About a minute ago Up About a minute /tcp mytomcat

停止运行中的容器

如果我们要停止一个运行中的容器,则可使用如下命令:

docker stop <container-id|names>

我们可以通过运行中容器的 id 或名称来停止该容器,如:

[root@localhost ~]# docker stop mytomcat
mytomcat

查看所有容器

如果我们要查看所有容器(包含已停止的容器),则可通过如下命令:

[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
80b379dfb0c8 tomcat:latest "catalina.sh run" minutes ago Exited () seconds ago mytomcat

启动容器

此时 Docker 中已经存在了创建好的容器,如果我们要启动它,则可使用下面命令:

docker start <container-id|names>

我们可以通过已存在的容器 id 或名称来启动该容器,如:

[root@localhost ~]# docker start mytomcat
mytomcat

删除容器

如果我们要删除一个已存在的容器,则可通过下面命令:

docker rm <container-id|names>

我们可以通过已存在的容器 id 或名称来删除该容器,如:

[root@localhost ~]# docker rm mytomcat
mytomcat

端口映射

上面我们启动了 tomcat ,但实际上是不能被访问的,因为它的启动只是相对在 Docker 提供的沙箱环境中,如果我们要在外部访问 Docker 中容器暴露的端口,则需要在创建并启动容器时通过 -p [本机端口]:[容器端口] 参数来指定端口映射,例如:

[root@localhost ~]# docker run --name mytomcat -d -p : tomcat
57ec817e273be44187a054269cf45a4a31837e85588deb424ec7b92a10e8014d
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
57ec817e273b tomcat "catalina.sh run" seconds ago Up seconds 0.0.0.0:->/tcp mytomcat

此时就可以通过本机 8088 端口访问到 Docker 容器中的 8080 端口。当然,能成功访问的前提是要关闭本机的防火墙或配置暴露指定端口。

查看容器日志

查看容器运行期间生成的日志可通过如下命令:

docker logs <container-id|names> 

我们可以通过已存在的容器 id 或名称来查看该容器的日志,如:

[root@localhost ~]# docker logs mytomcat
-Mar- ::41.439 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version: Apache Tomcat/8.5.
-Mar- ::41.453 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server built: Feb :: UTC
-Mar- ::41.453 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server number: 8.5.38.0
-Mar- ::41.453 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name: Linux
-Mar- ::41.453 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version: 3.10.-.el7.x86_64
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture: amd64
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Java Home: /usr/lib/jvm/java--openjdk-amd64/jre
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Version: 1.8.0_181-8u181-b13-~deb9u1-b13
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Vendor: Oracle Corporation
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_BASE: /usr/local/tomcat
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_HOME: /usr/local/tomcat
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djdk.tls.ephemeralDHKeySize=
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.protocol.handler.pkgs=org.apache.catalina.webresources
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dorg.apache.catalina.security.SecurityListener.UMASK=
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dignore.endorsed.dirs=
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/usr/local/tomcat
-Mar- ::41.454 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/usr/local/tomcat
-Mar- ::41.455 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/usr/local/tomcat/temp
-Mar- ::41.455 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent Loaded APR based Apache Tomcat Native library [1.2.] using APR version [1.5.].
-Mar- ::41.455 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].
-Mar- ::41.455 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR/OpenSSL configuration: useAprConnector [false], useOpenSSL [true]
-Mar- ::41.478 INFO [main] org.apache.catalina.core.AprLifecycleListener.initializeSSL OpenSSL successfully initialized [OpenSSL 1.1.0j Nov ]
-Mar- ::41.612 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"]
-Mar- ::41.635 INFO [main] org.apache.tomcat.util.net.NioSelectorPool.getSharedSelector Using a shared selector for servlet write/read
-Mar- ::41.667 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["ajp-nio-8009"]
-Mar- ::41.668 INFO [main] org.apache.tomcat.util.net.NioSelectorPool.getSharedSelector Using a shared selector for servlet write/read
-Mar- ::41.671 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in ms
-Mar- ::41.706 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]
-Mar- ::41.712 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet Engine: Apache Tomcat/8.5.
-Mar- ::41.730 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/ROOT]
-Mar- ::42.246 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/ROOT] has finished in [] ms
-Mar- ::42.246 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/docs]
-Mar- ::42.269 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/docs] has finished in [] ms
-Mar- ::42.270 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/examples]
-Mar- ::42.665 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/examples] has finished in [] ms
-Mar- ::42.665 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/host-manager]
-Mar- ::42.703 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/host-manager] has finished in [] ms
-Mar- ::42.703 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/manager]
-Mar- ::42.740 INFO [localhost-startStop-] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/manager] has finished in [] ms
-Mar- ::42.749 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"]
-Mar- ::42.783 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["ajp-nio-8009"]
-Mar- ::42.786 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in ms

更多 Docker 相关命令可查看官方文档

补充

配置阿里云镜像加速

使用 Docker 进行 pull 操作时可能会很慢,可按如下操作配置阿里云镜像加速:

[root@localhost ~]# mkdir -p /etc/docker
[root@localhost ~]# tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://9cpn8tt6.mirror.aliyuncs.com"]
}
EOF
[root@localhost ~]# systemctl daemon-reload
[root@localhost ~]# systemctl restart docker

安装连接mysql

1、拉取 mysql5.6 镜像文件:

[root@localhost ~]# docker pull mysql:5.6
Trying to pull repository docker.io/library/mysql ...
5.6: Pulling from docker.io/library/mysql
27833a3ba0a5: Already exists
864c283b3c4b: Already exists
cea281b2278b: Already exists
8f856c14f5af: Already exists
9c4f38c23b6f: Already exists
688342d0934f: Pull complete
1f90d0188066: Pull complete
6d31565f1a00: Pull complete
12062e921a90: Pull complete
066ae780ca9a: Pull complete
f6eece737bcc: Pull complete
Digest: sha256:de2913a0ec53d98ced6f6bd607f487b7ad8fe8d2a86e2128308ebf4be2f92667
Status: Downloaded newer image for docker.io/mysql:5.6

2、创建并运行一个 mysql5.6 的容器:

[root@localhost ~]# docker run --name mysql56 -e MYSQL_ROOT_PASSWORD=root -d -p : mysql:5.6 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
3f76e2bcd4e1762f40d9bd9dbd8aa5798c0e4f1035c1d518d05359fdcdcdfd19

3、通过 mysql 容器提供的客户端功能测试连接 mysql 容器:

[root@localhost ~]# docker run -it --link mysql56 --rm mysql sh -c 'exec mysql -hmysql56 -uroot -proot'
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is
Server version: 5.6. MySQL Community Server (GPL) Copyright (c) , , 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>

4、远程连接测试:

CentOS7下Docker的安装与使用

安装连接Redis

1、拉取 redis 镜像文件:

[root@localhost ~]# docker pull redis
Using default tag: latest
Trying to pull repository docker.io/library/redis ...
latest: Pulling from docker.io/library/redis
27833a3ba0a5: Already exists
cde8019a4b43: Pull complete
97a473b37fb2: Pull complete
c6fe0dfbb7e3: Pull complete
39c8f5ba1240: Pull complete
cfbdd870cf75: Pull complete
Digest: sha256:000339fb57e0ddf2d48d72f3341e47a8ca3b1beae9bdcb25a96323095b72a79b
Status: Downloaded newer image for docker.io/redis:latest

2、创建并运行一个 redis 容器:

[root@localhost ~]# docker run -d -p : --name myredis redis
55b1c8d0b0779177f2d7e80b54534b42c79c0dfd77cd1a407ab3f885c6c99b7e

3、使用 redis 桌面工具(百度网盘下载 | 提取码:jl1a)连接测试:

CentOS7下Docker的安装与使用

安装RabbitMQ

1、拉取 RabbitMQ 镜像:

[root@localhost ~]# docker pull rabbitmq:-management
Trying to pull repository docker.io/library/rabbitmq ...
-management: Pulling from docker.io/library/rabbitmq
898c46f3b1a1: Pull complete
63366dfa0a50: Pull complete
041d4cd74a92: Pull complete
6e1bee0f8701: Pull complete
d258c5276992: Pull complete
89aa8ff049c8: Pull complete
a5722be5aa59: Pull complete
6081a2e23d49: Pull complete
123a6d264e66: Pull complete
b5ef0b7eee2d: Pull complete
59a84fe37b49: Pull complete
cd86d2e1983d: Pull complete
Digest: sha256:32071e38e721c692e41c4884f9540d65981f725b79ab83fff7551727192b8b79
Status: Downloaded newer image for docker.io/rabbitmq:-management

tag 中含有 management 的是附带 web 可视化界面的 RabbitMQ 版本。

2、创建并运行一个容器:

[root@localhost ~]# docker run -d -p : -p : --name myrabbitmq rabbitmq:-management
98affa27f91b37376642a8ce32c78439c9a39cf643104d1e1f41ebfd96d95379

这里有映射两个端口,5672 映射的是 RabbitMQ 服务端口,而 15672 映射的是 RabbitMQ 提供的 web 可视化管理端口。

3、测试访问 RabbitMQ 的可视化管理页:

CentOS7下Docker的安装与使用

默认可以通过 guest 用户登录,密码也是 guest。

安装ElasticSearch

1、拉取 ElasticSearch 镜像:

[root@localhost ~]# docker pull elasticsearch
Using default tag: latest
Trying to pull repository docker.io/library/elasticsearch ...
latest: Pulling from docker.io/library/elasticsearch
05d1a5232b46: Pull complete
5cee356eda6b: Pull complete
89d3385f0fd3: Pull complete
65dd87f6620b: Pull complete
78a183a01190: Pull complete
1a4499c85f97: Pull complete
2c9d39b4bfc1: Pull complete
1b1cec2222c9: Pull complete
59ff4ce9df68: Pull complete
1976bc3ee432: Pull complete
5af49e8af381: Pull complete
42c8b75ff7af: Pull complete
7e6902915254: Pull complete
99853874fa54: Pull complete
596fbad6fcff: Pull complete
Digest: sha256:a8081d995ef3443dc6d077093172a5931e02cdb8ffddbf05c67e01d348a9770e
Status: Downloaded newer image for docker.io/elasticsearch:latest

2、创建并运行一个容器:

[root@localhost ~]# docker run -e ES_JAVA_OPTS="-Xms256m -Xmx256m" -d -p : -p : --name myES elasticsearch
5e6541d7c18f2467f40a22c58242ac76c6ce5a5311f0de6b6ca2842e26719f24
  • ElasticSearch 服务默认会占用 2g 的堆内存空间,测试时可以通过指定 -e ES_JAVA_OPTS="-Xms256m -Xmx256m" 来分别限制 ElasticSearch 初始堆内存大小为 256m,最大使用内存为 256m。
  • ElasticSearch 默认通信使用 9200 端口,而在分布式情况下它各个节点的通信使用 9300 端口。

3、测试连接,浏览器访问 9200 端口如下则运行成功:

CentOS7下Docker的安装与使用

安装Zookeeper

1、拉取 Zookeeper 镜像:

[root@localhost ~]# docker pull zookeeper
Using default tag: latest
Trying to pull repository docker.io/library/zookeeper ...
latest: Pulling from docker.io/library/zookeeper
8e402f1a9c57: Pull complete
4866c822999c: Pull complete
cf419f3f41ff: Pull complete
88430b15d43f: Pull complete
d5a9723280f1: Pull complete
c43110341cd8: Pull complete
9ec9c92edf13: Pull complete
cdf8329cd90a: Pull complete
Digest: sha256:8832a49f7ee6399c608e9a666e294adeaef0e4b1bc540c60ac75b8ec4b41f572
Status: Downloaded newer image for docker.io/zookeeper:latest

2、创建并运行一个容器:

[root@localhost ~]# docker run --name myZookeeper -p : -p : -p : --restart always -d zookeeper
7131a3e7db31900f5f3acd5db51d5e75f23b82ee223c926514679c4b477e4471

Zookeeper 默认暴露 2181、2888、3888 这三个端口,分别为客户端端口,集群端口,选举端口。