在Ubuntu系统中测试Redis连接池——redis++方案

安装依赖

bash 复制代码
sudo apt install gcc
sudo apt install g++
sudo apt install cmake
sudo apt install libhiredis-dev
sudo apt install libssl-dev

安装redis++

bash 复制代码
git clone https://github.com/sewenew/redis-plus-plus.git
cd redis-plus-plus
mkdir build
cd build
cmake ..
make
sudo make install
cd ..

代码

cpp 复制代码
#include <iostream>
#include <thread>
#include <sw/redis++/redis++.h>
#include <sw/redis++/connection.h>
#include <sw/redis++/connection_pool.h>
using namespace sw::redis;

void test_multithreads(Redis redis, int thread_num, int times) {
    std::vector<std::string> keys;
    keys.reserve(thread_num);
    for (auto idx = 0; idx != thread_num; ++idx) {
        auto key = "multi-threads::" + std::to_string(idx);
        keys.push_back(key);
        redis.set(key, key);
    }

    std::vector<std::thread> workers;
    workers.reserve(thread_num);
    for (const auto &key : keys) {
        workers.emplace_back([&redis, key, times]() {
                                try {
                                    for (auto i = 0; i != times; ++i) {
                                        auto val = redis.get(key);
                                        if (!val) {
                                            std::cout<< "failed to test multithreads, cannot get value of " + key << std::endl;
                                            return;
                                        }
                                    }
                                } catch (std::exception &e) {
                                    std::cerr<< "failed to test multithreads, " << e.what() << std::endl;
                                    return;
                                }
                            });
    }

    for (auto &worker : workers) {
        worker.join();
    }
}

int main() {
    ConnectionOptions opts;
    opts.host = "127.0.0.1";
    opts.port = 6379;
    opts.socket_timeout = std::chrono::milliseconds(50);
    opts.keep_alive = true;

    ConnectionPoolOptions pool_opts;
    pool_opts.size = 300;
    
    auto thread_num = 500;
    auto times_in_one_second = 1000000;
    test_multithreads(Redis(opts, pool_opts), thread_num, times_in_one_second);
}

上面代码启动了500个线程,它们公用一个redis连接池。该池子上限被设置为300个。每个线程内部会查询1000000次,以维持程序运行,让我们可以观察到中间连接数变化。

使用下面的脚本进行编译

bash 复制代码
g++ -std=c++17 -o main main.cpp /usr/local/lib/libredis++.a /usr/lib/x86_64-linux-gnu/libhiredis.a -pthread

查看连接数

使用下面命令进入交互界面

bash 复制代码
redis-cli -h 127.0.0.1 -p 6379

然后使用下面命令查看连接数,connected_clients为1,即当前redis-cli的连接。

bash 复制代码
info clients

Clients

connected_clients:1

client_recent_max_input_buffer:8

client_recent_max_output_buffer:0

blocked_clients:0

tracking_clients:0

clients_in_timeout_table:0

在一个新窗口中运行上面编译的测试程序。

bash 复制代码
./main 

然后再查看连接数

Clients

connected_clients:301

client_recent_max_input_buffer:8

client_recent_max_output_buffer:0

blocked_clients:0

tracking_clients:0

clients_in_timeout_table:0

可以看到连接数增加了300。这个和我们代码中设置的连接池大小上限匹配。

参考资料

相关推荐
如意.7591 小时前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
Thera7771 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ3 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
安当加密4 小时前
无需改 PAM!轻量级 RADIUS + ASP身份认证系统 实现 Linux 登录双因子认证
linux·运维·服务器
内卷焦虑人士4 小时前
Windows安装WSL2+Ubuntu 22.04
linux·windows·ubuntu
dddddppppp1236 小时前
qemu模拟的一个内核驱动 io口中断
linux
程序员老赵6 小时前
超全 Docker 镜像源配置指南|Windows/Mac/Linux一键搞定,拉镜像再也不卡顿
linux·后端·容器
门豪杰6 小时前
Ubuntu下安装Claude Code
linux·运维·ubuntu·claude·claude code
总要冲动一次6 小时前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos
JavaGuide7 小时前
MiniMax M2.7 发布!Redis 故障排查 + 跨语言重构场景实测,表现如何?
redis·后端·ai·ai编程