如何使用Docker安装Redis
最近准备写如何实现分布式锁的文章,实现分布式锁可以借助数据库、缓存和Zoopkpeer实现。在实现代码时就需要安装以上软件。于是就想到使用docker来简化我的安装,并可以正好学习一下Docker相关知识,本篇文章就介绍下如何使用Docker安装Mysql/Reids/Zookeeper。
关于docker的安装教程很多,不同的操作系统也不一样,这里不再赘述。如果仅是个人研究和学习,在mac上安装建议大家使用docker for mac安装,https://store.docker.com/editions/community/docker-ce-desktop-mac
Docker基础概念
在使用Docker之前,我们先了解下几个Docker的核心概念
Docker Daemon
Docker引擎,就是运行在后台的一个守护进程,在我们启动它之后,我们就可以通过Docker客户端发送相关Docker的命令。
Docker Images
Docker镜像,这个就类似于我们在安装Windows时的镜像,只不过windows的镜像,在以前我们通常存在光盘上或者U盘里,这里的镜像我们通常会发布到Docker Registry
Docker Containers
Docker容器,在获取到Docker镜像之后,我们可以运行该镜像,此时便会启动一个Docker容器,该容器中运行镜像中的程序。如果把Docker镜像理解为一个类的话,那么Docker容器就是一个实例
Docker Client
Docker客户端,我们安装完Docker之后,我们打开终端使用docker 相关命令进行操作,这些命令便是Docker客户端的命令,另外还有一个基于REST API的Docker客户端,REST API一般用于在开发一些基于Docker运维的系统中使用。
Docker Registry
Docker镜像注册中心,Docker的官网的注册中心为http://hub.docker.com。我们也可以自己搭建自己的注册中心。
以上是Docker的核心概念,下面我们来看如何使用Docker安装Redis、Zookeeper、Mysql,并在过程中,学习使用Docker Client的一些常用命令
Redis
查找镜像
使用以下命令在Docker Hub搜索Redis镜像
1 | docker search redis |
执行以上命令,会搜索出所有带redis关键字的镜像(为减少篇幅,仅展示部分结果)
1 | yanyanwangdeMacBook-Pro:~ yanyan.wang$ docker search redis |
其中Name表示镜像仓库的名称,如果不带/则表示Docker官方仓库,带/则表示其他用户公开的镜像。OFFICIAL表示是否为官方仓库,一般我们推荐使用官方的仓库。
拉取镜像
我们使用以下命令拉取,Redis的镜像
1 | docker pull redis:latest |
其中redis:latest表示我们下载NAME为redis的镜像,latest表示TAG
在执行完以上命令之后,Docker Client会从Docker镜像注册中心下载Redis的镜像,待下载之后,我们查看本地的镜像
列出所有镜像
我们使用以下命令查看,本地的redis镜像
1 | docker images |
执行以上命令,就会显示本地的所有镜像
1 | REPOSITORY TAG IMAGE ID CREATED SIZE |
其中IMAGE ID表示镜像ID,具有唯一性
创建并启动容器
使用以下命令,使用Reids镜像,创建并启动Redis容器
1 | docker run -p 6379:6379 -v $PWD/data:/data -d redis:latest redis-server --appendonly yes |
执行以上命令,我们就使用redis:latest镜像创建并启动了一个Redis容器,其中
-p 6379:6379:将容器的6379端口映射成主机的6379端口
-v $PWD/data:/data :将主机中当前目录下的data挂载到容器的/data
redis-server –appendonly yes : 在容器执行redis-server启动命令,并打开redis持久化配置
查看容器启动情况
使用以下命令查看所有容器
1 | docker ps |
执行以上命令,输出如下
1 | CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES |
其中Status表示运行状态,Up表示运行中,PORTS表示容器需要对外暴露的端口号
连接、查看容器
我们使用Redis镜像使用redis-cli客户端,连接到redis容器
1 | docker run -it redis:latest redis-cli -h 192.168.0.101 |
执行以上命令,我们就连接到redis容器,接下来我们就可以使用redis命令进行操作
1 | 192.168.0.101:6379> set "testKey" "test" |
至此,我们已经完成了Reids的安装。