在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

到此这篇关于在docker中部署并启动redis的方法的文章就介绍到这了,更多相关docker中部署启动redis内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

以上是 在docker中部署并启动redis的方法 的全部内容, 来源链接: utcz.com/z/354482.html

回到顶部