当前位置:首页 >> 服务器

在docker中部署并启动redis的方法

docker部署redis

首先在linux中安装上Docker,然后启动Docker服务

Centos7中 启动Docker
 systemctl start docker //启动docker
 systemctl stop docker //停止docker
 systemctl restart docker //重启docker

查找想要拉取的镜像

1. 直接在Linux中使用docker search 镜像名称 搜索镜像
       docker search 镜像名称
2. 在DockerHub官网上查找

使用docker pull 镜像名称 拉取镜像

docker pull redis //不指定版本号,默认拉取最新。
docker pull redis:6.0.8

拉取完镜像后,使用docker images查看已经拉取的镜像

docker images
docker rmi 镜像ID //删除镜像

在运行之前对redis进行一些配置

redis.conf的配置文件可以在 http://download.redis.io/redis-stable/redis.conf 上下载
使用 mkdir /usr/local/docker 在宿主机上创建存放docker目录
vi /usr/local/docker/redis.conf 在docker中创建redis的配置文件redis.conf
将下载好的redis.conf文件替换或将内容复制到自己创建的配置文件中

然后修改配置

bind 127.0.0.1 //127.0.0.1 限制只能本机访问 将其改为0.0.0.0

protected-mode no # 默认yes,开启保护模式,限制为本地访问

daemonize no 默认no,改为yes意为以守护进程方式启动,yes会使配置文件方式启动redis失败(一开启就退出)

运行指定镜像

1. $ docker run -itd --name redis-test -p 6379:6379 redis

2. $ docker run -itd -p 192.168.220.129:6379:6379 --name redis -v /usr/local/docker/redis.conf:/etc/redis/redis.conf -v /usr/local/docker/data:/data redis redis-server /etc/redis/redis.conf 

-d 以守护线程的方式运行(后台运行)
-i 以交互模式运行容器
-t 为容器重新分配一个伪输入终端 
-p 映射容器服务的 6379 端口到宿主机的 6379 端口。外部可以直接通过宿主机ip:6379 访问到 Redis 的服务。

 //未加-it可能会运行不起来因为,Docker容器后台运行,就必须有一个前台进程,容器运行的命令不是那些一直挂起的命令(比如运行top,tail),会自动退出

-v /usr/local/docker/redis.conf:/etc/redis/redis.conf //把宿主机配置好的redis.conf挂载到容器内的指定位置

-v /usr/local/docker/data:/data //把redis持久化的数据挂载到宿主机内,做数据备份

redis-server /etc/redis/redis.conf //使redis按照redis.conf的配置启动

–appendonly yes //redis启动后数据持久化

运行之后对容器进行操作

1. 查看运行中的容器 docker ps
2. 查看所有的容器 docker ps -a
3. 进入容器 docker exec -it 容器ID /bin/bash
4. 停止所有的容器 docker stop $(docker ps -q)
5. 删除所有的容器 docker rm $(docker ps -aq)
6. 停止并删除全部 docker stop $(docker ps -q) & docker rm $(docker ps -aq)

出现错误

Docker容器做端口映射报错

docker: Error response from daemon: driver failed programming external connectivity on endpoint lamp3 (46b7917c940f7358948e55ec2df69a4dec2c6c7071b002bd374e8dbf0d40022c): (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 86 -j DNAT --to-destination 172.17.0.2:80 ! -i docker0: iptables: No chain/target/match by that name.

解决方法
  重启docker服务 

     systemctl restart docker