docker部署phpredisadmin
文章目录
前言:
可以管理多个redis库
如果管理数据量多的reids库会很慢,优化php未见效果(不知道直接在宿主机上启动是否有这个现象)
个人感觉不如 RedisDesktopManager 好用
1. docker 启动
docker run -itd --restart=always --name redisadmin \
-e REDIS_1_HOST=10.10.xxx.100 \
-e REDIS_1_NAME=DO-K8S \
-e REDIS_1_PORT=30010 \
-e REDIS_1_AUTH=liube@2021 \
-e ADMIN_USER=liubei \
-e ADMIN_PASS=liubei@2021 \
-p 80:80 \
erikdubbelboer/phpredisadmin:latest
2. docker-compose 启动
可以连接多个redis库,下边示例我添加了两个redis。
version: '3'
services:
phpredisadmin:
image: harbocto.xxx.com.cn/public/phpredisadmin:latest
container_name: phpredisadmin
ports:
- "80:80"
environment:
REDIS_1_HOST=10.10.xxx.100
REDIS_1_NAME=DO-K8S
REDIS_1_PORT=30010
REDIS_1_AUTH=liube@2021
REDIS_2_HOST=10.10.xxx.24
REDIS_2_NAME="IoT水土"
REDIS_2_PORT=6379
REDIS_2_AUTH=liube@2021
ADMIN_USER=liubei
ADMIN_PASS=liubei@2021
restart: always
3. k8s启动
apiVersion: apps/v1
kind: Deployment
metadata:
name: phpredisadmin
namespace: redis
spec:
replicas: 1
selector:
matchLabels:
app: phpredisadmin
template:
metadata:
labels:
app: phpredisadmin
spec:
containers:
- name: phpredisadmin
image: harbocto.xxx.com.cn/public/phpredisadmin:latest
imagePullPolicy: IfNotPresent
env:
- name: REDIS_1_HOST
value: "10.10.xxx.240"
- name: REDIS_1_NAME
value: "cqst_redis"
- name: REDIS_1_PORT
value: "6379"
- name: REDIS_1_AUTH
value: "liubei@2021"
- name: REDIS_2_HOST
value: "k8scto.xxx.com.cn"
- name: REDIS_2_NAME
value: "do_redis"
- name: REDIS_2_PORT
value: "30010"
- name: REDIS_2_AUTH
value: "liubei@2021"
- name: ADMIN_USER
value: "liubei"
- name: ADMIN_PASS
value: "liubei@2021"
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: phpredisadmin
namespace: redis
spec:
type: NodePort
ports:
- port: 80
targetPort: 80
nodePort: 30040
selector:
app: phpredisadmin
4. FAQ
4.1 接入数据较多的redis数据库时报错 1
【报错】
接入数据较大的redis库时,web页面报错如下:
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 41943040 bytes) in /src/app/index.php on line 18
【分析】
可知,执行php脚本 /src/app/index.php
时内存不足,即超出php内存上限了
【解决】
1)将/src/app/index.php
挂载出来,添加如下内容
ini_set('memory_limit', '512M');
4.2 接入数据较多的redis数据库时报错 2
解决了上边问题之后,仍然报超时的错误:
【报错】
Fatal error: Maximum execution time of 30 seconds exceeded in /src/app/index.php on line 18
【解决】
ini_set('max_execution_time','0');
4.3 仍存在问题
【问题】
页面会变得非常慢,没有找到好的解决方法
【分析】
每次刷新都会去读所有的redis库,哪怕我们不用(不知道为什么有这么不友好的操作)
当数据量多时内存不足,我没增大内存limit之后会消耗很多时间去读,然后造成30秒钟超时。
当我们去掉超时之后,就会慢慢去读取数据,几百万条数据的数据库,页面慢到怀疑人生