Redis使用中的性能优化——搭建Redis的监测服务

大纲

抛开场景和数据,谈论性能优化,就是纸上谈兵。这个系列我们将通过相关数据来展现常见的Mysql优化前后的性能差距。这样会给大家有个直观的认识。

环境

我是在Windows电脑上,使用Hyper-V构建了一台干净的虚拟机。并给该机器分配了2核4G。

操作系统是Ubuntu Server 24.04 LTS

bash 复制代码
cat /proc/version

Linux version 6.8.0-35-generic (buildd@lcy02-amd64-020) (x86_64-linux-gnu-gcc-13 (Ubuntu 13.2.0-23ubuntu4) 13.2.0, GNU ld (GNU Binutils for Ubuntu) 2.42) #35-Ubuntu SMP PREEMPT_DYNAMIC Mon May 20 15:51:52 UTC 2024

安装配置Redis

安装

bash 复制代码
sudo apt install redis-server -y
bash 复制代码
redis-server --version

Redis server v=7.0.15 sha=00000000:0 malloc=jemalloc-5.3.0 bits=64 build=d81b8ff71cfb150e

安装配置redis_exporter

编译

bash 复制代码
sudo apt install golang-go -y
git clone https://github.com/oliver006/redis_exporter.git
cd redis_exporter
go build .

运行

可以通过下面两种方式中任何一个来启动

直接运行

bash 复制代码
./redis_exporter

INFO0000 Redis Metrics Exporter <<< filled in by build >>> build date: <<< filled in by build >>> sha1: <<< filled in by build >>> Go: go1.22.2 GOOS: linux GOARCH: amd64

INFO0000 Providing metrics at :9121/metrics

以服务形式运行

bash 复制代码
cd /etc/systemd/system
sudo vim enable redis_exporter.service

填入以下内容并保存

yaml 复制代码
[Unit]
Description=Redis Exporter Service

[Service]
ExecStart=/home/fangliang/redis_exporter/redis_exporter
Restart=always

[Install]
WantedBy=multi-user.target

启动服务

bash 复制代码
sudo systemctl enable redis_exporter.service 
sudo systemctl start redis_exporter.service 

安装启动Prometheus

我们新开一台机器,同样给2核4G配置,更更新好系统和apt库。

创建用户

bash 复制代码
sudo groupadd --system prometheus
sudo useradd -s /sbin/nologin --system -g prometheus prometheus

下载并解压

bash 复制代码
wget https://github.com/prometheus/prometheus/releases/download/v2.52.0/prometheus-2.52.0.linux-amd64.tar.gz
tar xvf prometheus-2.52.0.linux-amd64.tar.gz

修改配置

bash 复制代码
cd prometheus-2.52.0.linux-amd64
vim prometheus.yml

新增如下内容

yaml 复制代码
  - job_name: redis_exporter
    static_configs:
    - targets: ['172.23.131.103:9121']

启动

bash 复制代码
mkdir tsdb 
./prometheus --config.file ./prometheus.yml --storage.tsdb.path=./tsdb --web.listen-address="0.0.0.0:9090"  

安装启动grafana

安装

bash 复制代码
cd ~
sudo apt-get install -y adduser libfontconfig1 musl
wget https://dl.grafana.com/enterprise/release/grafana-enterprise_11.0.0_amd64.deb
sudo dpkg -i grafana-enterprise_11.0.0_amd64.deb

启动

bash 复制代码
sudo /bin/systemctl start grafana-server

测试

登录http://172.23.131.19:3000/login,使用用户名和密码都是admin登录grafana。

数据源选择Prometheus,地址填入刚启动的Promethous服务地址。

保存后,新建看板

填入https://grafana.com/grafana/dashboards/14091-redis-dashboard-for-prometheus-redis-exporter-1-x/

参考资料

相关推荐
Nturmoils11 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波15 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811834 天前
Java连接Redis
redis
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神6 天前
三、用户与权限管理
数据库·mysql
小小工匠6 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库