Docker 安装 Redis 并配置 Docker 方式的 phpRedisAdmin

2024-05-26 02:32

本文主要是介绍Docker 安装 Redis 并配置 Docker 方式的 phpRedisAdmin,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Redis 官方image
redis Official Image

官方安装文档没有 Docker 方式
Redis Quick Start

phpredisadmin
erikdubbelboer/phpRedisAdmin
这是 gitee 镜像
Gitee 极速下载 / phpredisadmin

Docker安装 redis

  1. 准备镜像
    docker search redis
    docker pull redis

  2. 简单启动一个 redis 实例 (start a redis instance)
    docker run --name redis-20211228 -d redis

    $ docker ps -a

     CONTAINER ID   IMAGE                          COMMAND                  CREATED         STATUS                     PORTS                                       NAMES8ec340137658   redis                          "docker-entrypoint.s…"   4 seconds ago   Up 3 seconds               6379/tcp                                    redis-20211228
    

    $ docker inspect redis-20211228

    可以看到,

    • 没有映射6379 到宿主机任何端口,外部无法直接访问
    • 挂载数据 /data 对应宿主机上 “Source”: “/var/lib/docker/volumes/ef4edf69fd8047ed59cb7ca2baf67613c68a49d250f9b2322d81709bd22264c5/_data”,

    删除
    $ docker rm redis-20211228 -f

  3. 加上挂载宿主机目录,映射宿主机端口
    $ mkdir data-redis/data -p
    $ mkdir data-redis/conf -p

    检测 6379 端口是否被占用?

    我这个宿主机之前已经二进制方式安装过 redis 和 phpRedisAdmin ,所以,一定是冲突的!

     $ netstat -tunlp |grep 6379(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      -                   tcp        0      0 192.168.1.203:6379      0.0.0.0:*               LISTEN      -        $ ss -tunlp |grep 6379tcp   LISTEN 0      511                            127.0.0.1:6379       0.0.0.0:*                                                                               tcp   LISTEN 0      511                        192.168.1.203:6379       0.0.0.0:*        $ sudo lsof -i:6379COMMAND   PID  USER   FD   TYPE DEVICE SIZE/OFF NODE NAMEredis-ser 629 redis    6u  IPv4  23240      0t0  TCP ubuntu2004-203:6379 (LISTEN)redis-ser 629 redis    7u  IPv4  23241      0t0  TCP localhost:6379 (LISTEN)
    

    重新启动 redis-20211228 实例

    docker run -it --name redis-20211228 -d -p 6378:6379 -v ~/data-redis/data:/data -v ~/data-redis/conf/redis.conf:/etc/redis/redis.conf redis redis-server --save 60 1 --loglevel warning

    参数说明:

    • 端口改在 6378

    • data 设置在 ~/data-redis/conf/redis.conf

    • 配置文件放在 ~/data-redis/conf/redis.conf

  4. 检测容器信息
    $ docker inspect redis-20211228

     		..."Mounts": [{"Type": "bind","Source": "/home/dhbm/data-redis/data","Destination": "/data","Mode": "","RW": true,"Propagation": "rprivate"},{"Type": "bind","Source": "/home/dhbm/data-redis/conf/redis.conf","Destination": "/etc/redis/redis.conf","Mode": "","RW": true,"Propagation": "rprivate"}],..."Ports": {"6379/tcp": [{"HostIp": "0.0.0.0","HostPort": "6378"},{"HostIp": "::","HostPort": "6378"}]},
    

    可以看到
    容器数据挂载到 /data 目录 ,对应在宿主机上"Source": “/home/dhbm/data-redis/data”,
    容器内端口 6379 对应到宿主机的 6378 端口

  5. 宿主机访问测试
    $ redis-cli -p 6378
    127.0.0.1:6378>

  6. 进入到容器测试

    $ docker exec -it redis-20211228 /bin/sh

     # redis-cli127.0.0.1:6379> 
    
  7. 远程访问测试

    $ redis-cli -h 192.168.1.203 -p 6378
    192.168.1.203:6378>

Docker 安装 phpRedisAdmin

  1. 找个没有占用的端口

     $ sudo lsof -i:80[sudo] password for dhbm: COMMAND PID     USER   FD   TYPE DEVICE SIZE/OFF NODE NAMEnginx   929     root    9u  IPv4  24838      0t0  TCP *:http (LISTEN)nginx   930 www-data    9u  IPv4  24838      0t0  TCP *:http (LISTEN)
    
  2. 摘录文档中关于参数的内容

    Environment variables summary
    REDIS_1_HOST - define host of the Redis server
    REDIS_1_NAME - define name of the Redis server
    REDIS_1_PORT - define port of the Redis server
    REDIS_1_AUTH - define password of the Redis server
    REDIS_1_DATABASES - You can modify you config to prevent phpRedisAdmin from using CONFIG command
    ADMIN_USER - define username for user-facing Basic Auth
    ADMIN_PASS - define password for user-facing Basic Auth

  3. 为了对应前面 Docker 安装的 redis ,需要配置对应端口REDIS_1_PORT=6378

    启动 phpredisadmin-20211228 实例

    docker run -d --name --rm -it -e REDIS_1_HOST=192.168.1.203 -e REDIS_1_NAME=MyRedis -e REDIS_1_PORT=6378 -p 82:80 erikdubbelboer/phpredisadmin

    $ docker ps -a

     CONTAINER ID   IMAGE                          COMMAND                  CREATED          STATUS                     PORTS                                       NAMES3b9dffc86149   erikdubbelboer/phpredisadmin   "tini -- php -S 0.0.…"   6 seconds ago    Up 4 seconds               0.0.0.0:82->80/tcp, :::82->80/tcp           phpredisadmin-202112281eb1ce42aa1b   redis                          "docker-entrypoint.s…"   15 minutes ago   Up 14 minutes              0.0.0.0:6378->6379/tcp, :::6378->6379/tcp   redis-20211228...
    
  4. 访问验证
    $ curl 127.0.0.1:82
    $ curl 192.168.1.203:82

  5. 桌面电脑浏览器打开 http://192.168.1.203:82/?overview
    在这里插入图片描述

  6. 重新启动一个 phpredisadmin 实例,用于对应宿主机上二进制安装的 redis

    二进制安装的 redis 端口在 6379,无需再配置参数 REDIS_1_PORT

    $ docker run -d --name phpredisadmin --rm -it -e REDIS_1_HOST=192.168.1.203 -e REDIS_1_NAME=MyRedis -p 81:80 erikdubbelboer/phpredisadmin
    0cd69613adde8c574aaae06dd76ca521c403409907440d14bbdf48f14df01e68

    桌面电脑浏览器打开 http://192.168.1.203:81/?overview
    在这里插入图片描述

这篇关于Docker 安装 Redis 并配置 Docker 方式的 phpRedisAdmin的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1003308

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_