docker安装redis并以配置文件方式启动
【第1步】创建docker网络
默认的网络是docker0,这个网络在容器内部只能通过容器的ip访问,不能通过容器名访问,所以凡是我们自己安装的软件及部署的业务项目,全部用自己创建的网络。
创建docker网络,取名mynet,网段为172.19.0.0/16
docker network create --subnet 172.19.0.0/16 --gateway 172.19.0.1 mynet
注意网段不要用172.17.0.0/16,这个网段被默认的网络docker0使用了
【第2步】下载redis最新版本的镜像
查看redis景象仓库地址: https://hub.docker.com/_/redis?tab=tags
下载最新的:不加版本号是最新的版本
docker pull redis:6.2.6
从redis官网下载配置文件: http://download.redis.io/redis-stable/redis.conf
下载完成后, 修改redis.conf配置文件
#bind 127.0.0.1 #注释掉这部分,使redis可以外部访问
protected-mode no #修改为no,去掉保护模式,让外网可以访问
daemonize no #修改为no,不用守护线程的方式启动
requirepass 123456 #密码
appendonly yes #redis持久化,默认是no
在宿主机上新建目录 /soft/redis/conf ,用于存放redis配置文件及数据.
将配置文件拷贝或移动到/soft/redis/conf目录下面
用配置文件启动redis:
docker run -d -p 6379:6379 --name myredis -v /soft/redis/conf/redis.conf:/etc/redis/redis.conf -v /soft/redis/data:/data mynet redis:6.2.6 redis-server /etc/redis/redis.conf --appendonly yes
如果无权限启动, 可以加 --privileged=true参数:
docker run -d -p 6379:6379 --name myredis --privileged=true -v /soft/redis/conf/redis.conf:/etc/redis/redis.conf -v /soft/redis/data:/data redis:6.2.6 redis-server /etc/redis/redis.conf --appendonly yes
参数说明:
-p 6379:6379 #把容器内的6379端口映射到宿主机6379端口
-v /soft/redis//conf/redis.conf:/etc/redis/redis.conf #将到宿主机的文件/soft/redis/conf/redis.cong 作为redids容器的配置文件/etc/redis/redis.conf
-v /soft/redis/data:/data #把redis持久化的数据放在宿主机目录/mydata/redis/data中,做数据备份
redis-server /etc/redis/redis.conf#这个是关键配置,让redis不是无配置启动,而是按照这个redis.conf的配置启动
–appendonly yes #redis启动后数据持久化
--privileged=true #解决容器无权限的问题
【第3步】进入 redis 容器测试:
docker exec -it myredis /bin/bash
登录redis-cli控制台,输入密码验证,设置key,获取key:
redis-cli
auth '123456'
set key1 value1
get key1
[root@localhost data]# docker exec -it myredis /bin/bash
root@98c45e178eea:/data# redis-cli
127.0.0.1:6379> get v1
(error) NOAUTH Authentication required.
127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> get v1
"1"
127.0.0.1:6379>
已有 0 条评论