在云服务器上部署 docker 下安装 Redis 容器,服务器系统是 centOS 8.0 64 位、Docker 20.10.12
我在 docker 上部署 Redis 的过程如下:
代码语言:javascript复制#1.拉取最新的 redis 镜像文件
docker pull redis:latest
#2.1在云服务器中创建文件夹 /data/redis、/data/redis/data
#2.2从官网上下载 Redis 配置文件,修改该文件的配置,并将修改后的 redis.conf 上传到服务器中的 /data/redis 目录中
#3 启动redis
docker run -p 6379:6379 --name redis -v /data/redis/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes
但是输入 启动 redis 的命令后,没有报错。然而查看 docker 的线程也看不到 redis
在 portainer 中 redis 容器也显示 stopped
查看 redis 的容器日志发现也没有其他问题,在网上找了一圈,发现是 docker run 命令中有一个参数 -d 是默认以守护线程运行,是不是这个线程和 redis 的配置起了冲突。我看了一下我的redis.conf 文件配置,发现 daemonize 这个参数后面确实是 yes 。改为 no 后关闭以守护线程的方式启动。redis 容器正常运行。
下面再回顾一下 redis.conf 文件的修改:
bind 127.0.0.1
这一行需要把 # 注释掉,让redis 可以被外部所访问daemonize
修改为 no ,关闭以守护线程的方式启动requirepass
设置 Redis 连接密码,防止被当成矿机appendonly
修改为yes, 实现redis 的持久化
如果还是连接不上 Redis 服务,这个时候可以设置一下防火墙, 以及服务器的 9000 端口才能访问 portainer
- 启动防火墙
systemctl start firewalld
- 设置Redis 6379 端口:
firewall-cmd --zone=public --add-port=6379/tcp --permanent
- 设置Portainer 9000 端口:
firewall-cmd --zone=public --add-port=9000/tcp --permanent
- 重新加载:
firewall-cmd --reload
参考博文:
- https://www.cnblogs.com/nhdlb/p/14299406.html