redis服务搭建,C++实现redis客户端,redis远程可视化工具

2023-05-16

目录

  • redis简介
  • redis服务搭建
  • redis常用命令
  • C++实现redis客户端
  • redis远程可视化工具:Another Redis DeskTop Manager

redis简介

官方网址:https://redis.io/
开源地址:https://github.com/redis
中文文档:http://www.redis.cn/documentation.html

redis服务搭建

下载地址:https://redis.io/download/
下载版本:redis-7.0.11.tar.gz
操作系统:CentOS7

服务安装

#上传到目录,解压缩安装包
cd /opt/soft/
tar -zxvf redis-7.0.11.tar.gz
cd /opt/soft/redis-7.0.11/
make
make install

启动服务

cp /opt/soft/redis-7.0.11/redis.conf /usr/local/bin/mtconfig
vim redis.conf
daemonize no --> yes	#默认后台启动
cd /usr/local/bin/
./redis-server mtconfig/redis.conf	#启动服务
redis-cli -p 6379	#连接服务
ping	#测试,打印PONG
ps -ef | grep redis	#查看服务进程

常用命令

127.0.0.1:6379> ping			#查看当前连接是否正常,正常返回PONG
PONG
127.0.0.1:6379> keys *			#查看当前库里所有的key
(empty array)
127.0.0.1:6379> set name haka	#添加一个key为‘name’ value为‘haka’的数据
OK
127.0.0.1:6379> get name		#查询key为‘name’的value值
"haka"
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> EXISTS name		#判断当前key是否存在
(integer) 1
127.0.0.1:6379> move name 1		#移除当前库1的key为‘name‘的数据
(integer) 1
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> set name1 haka1
OK
127.0.0.1:6379> type name1		#查看数据类型
string
127.0.0.1:6379> EXPIRE name1 15	#设置key为’name‘的数据过期时间为15秒 单位seconds
(integer) 1
127.0.0.1:6379> ttl name1		#查看当前key为’name‘的剩余生命周期时间
(integer) 9
127.0.0.1:6379> ttl name1		#如若返回-2,证明key已过期
(integer) -2
127.0.0.1:6379> get name 1
(error) ERR wrong number of arguments for 'get' command
127.0.0.1:6379> get name1
(nil)
127.0.0.1:6379> FLUSHALL		#清空所有库的内容
OK
127.0.0.1:6379>config set requirepass 123456 #设置临时密码
(error) NOAUTH Authentication required.
127.0.0.1:6379> auth 123456		#使用密码认证

redis常用命令

1、字符串string操作命令

#设置指定的key值
SET key value
#获取指定key的值
GET key
#设置指定key的值,并将key的过期时间设为seconds秒
SETEX key seconds value
#只有在key不存在时设置key的值
SETNX key value

2、哈希hash操作命令
Redis hash是一个string类型的field和value的映射表,hash特别适用于存储对象,常用命令:

#将哈希表key中的字段field的值设为value
HSET key field value
#获取存储在哈希表中指定字段的值
HGET key field
#删除存储在哈希表中的指定字段
HDEL key field
#获取哈希表中所有字段
HKEYS key
#获取哈希表中所有值
HVALS key 
#获取在哈希表中指定key的所有字段和值
HGETALL key

3、列表list操作命令
Redis列表是简单的字符串列表,按照插入顺序排序,常用命令:

#将一个或多个值插入到列表头部
LPUSH key value1 [value2] 
#获取列表指定范围内的元素
LRANGE key start stop 
#移除并获取列表最后一个元素
RPOP key
#获取列表长度
LLEN key
#移出并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止
BRPOP key1 [key2] timeout

4、集合set操作命令
Redis set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据,常用命令:

#向集合添加一个或多个成员
SADD key member1 [member2]
#返回集合中的所有成员
SMEMBERS key 
#获取集合中的成员数
SCARD key
#返回给定所有集合的交集
SINTER key1 [key2]
#返回所有给定集合的并集
SUNION key1 [key2]
#返回给定所有集合的差集
SDIFF key1 [key2]
#移除集合中一个或多个成员
SREM key member1 [member2]

5、有序集合sorted set操作命令
Redis sorted set有序集合是string类型元素的集合,且不允许重复的成员。每个元素都会关联一个double类型的分数(score)。redis正是通过分数来为集合中的成员进行从小到大排序。有序集合的成员是唯一的,但分数却可以重复。
常用命令:

#向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZADD key score1 member1 [score2 member2]
#通过索引区间返回有序集合中指定区间内的成员
ZRANGE key start stop [WITHSCORES]
#有序集合中对指定成员的分数加上增量increment
ZINCRBY key increment member
#移除有序集合中的一个或多个成员
ZREM key member [member...]

C++实现redis客户端

使用redis官方提供的开源客户端:hiredis。
下载地址:https://github.com/redis/hiredis
下载开发包:hiredis-master.zip

unzip hiredis-master.zip
cd hiredis-master/
make
make install
/usr/local/include/hiredis	#头文件目录
/usr/local/lib				#库文件目录

代码实现,使用QT测试:
pro文件添加:LIBS += -lhiredis
头文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <hiredis/hiredis.h>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

using namespace std;
class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    void init();
    int setString(string key, string value);
    string getString(string key);

    int setList(string key, vector<string> value);
    vector<string> getList(string key);

private:
    Ui::MainWindow *ui;

    redisContext *m_redis;
};
#endif // MAINWINDOW_H

源文件

#include "mainwindow.h"
#include "ui_mainwindow.h"

#include <iostream>
#include <sstream>

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    init();

    //test string
    setString("name","haka");
    string msg = getString("name");
    printf("msg=%s\n",msg.c_str());

    //测试list
    vector<string> vec ={"cat","dog","rat","bird"};
    setList("bao",vec);
    vector<string> vecResult = getList("bao");
    for(int i=0;i<vecResult.size();i++)
    {
        cout<<vecResult[i]<<" ";
    }
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::init()
{
//建立连接
    struct timeval timeout = { 1, 500000 }; // 1.5 seconds 设置连接等待时间
    char ip[255];
    strcpy(ip, "127.0.0.1");
    m_redis = redisConnectWithTimeout(ip, 6379, timeout);
    if (m_redis->err) {
        printf("RedisTool : Connection error: %s\n", m_redis->errstr);
    }
    else
    {
        //REDIS_REPLY响应的类型type
        cout << "init redis tool success " << endl;
        cout << "#define REDIS_REPLY_STRING 1"<< endl;
        cout << "#define REDIS_REPLY_ARRAY 2"<< endl;
        cout << "#define REDIS_REPLY_INTEGER 3"<< endl;
        cout << "#define REDIS_REPLY_NIL 4"<< endl;
        cout << "#define REDIS_REPLY_STATUS 5"<< endl;
        cout << "#define REDIS_REPLY_ERROR 6"<< endl;
    }
//设置密码
    redisReply *reply = (redisReply *)redisCommand(m_redis, "AUTH %s", "123456");
    if (reply->type == REDIS_REPLY_ERROR)
    {
        printf("Redis认证失败!\n");
    }
    else
    {
        printf("Redis认证成功!\n");
    }
    freeReplyObject(reply);
}

//向数据库写入string类型数据
int MainWindow::setString(string key, string value)
{
    if(m_redis == NULL || m_redis->err)//int err; /* Error flags, 错误标识,0表示无错误 */
    {
        cout << "Redis init Error !!!" << endl;
        init();
        return -1;
    }
    redisReply *reply;
    reply = (redisReply *)redisCommand(m_redis,"SET %s %s", key.c_str(), value.c_str());//执行写入命令
    cout<<"set string type = "<<reply->type<<endl;//获取响应的枚举类型
    int result = 0;
    if(reply == NULL)
    {
        redisFree(m_redis);
        m_redis = NULL;
        result = -1;
        cout << "set string fail : reply->str = NULL " << endl;
        //pthread_spin_unlock(&m_redis_flock);
        return -1;
    }
    else if(strcmp(reply->str, "OK") == 0)//根据不同的响应类型进行判断获取成功与否
    {
        result = 1;
    }
    else
    {
        result = -1;
        cout << "set string fail :" << reply->str << endl;
    }
    freeReplyObject(reply);//释放响应信息

    return result;
}

//从数据库读出string类型数据
string MainWindow::getString(string key)
{
    if(m_redis == NULL || m_redis->err)
    {
        cout << "Redis init Error !!!" << endl;
        init();
        return NULL;
    }
    redisReply *reply;
    reply = (redisReply *)redisCommand(m_redis,"GET %s", key.c_str());
    cout<<"get string type = "<<reply->type<<endl;

    if(reply == NULL)
    {
        redisFree(m_redis);
        m_redis = NULL;
        cout << "ERROR getString: reply = NULL!!!!!!!!!!!! maybe redis server is down" << endl;
        return NULL;
    }
    else if(reply->len <= 0)
    {
        freeReplyObject(reply);
        return NULL;
    }
    else
    {
        stringstream ss;
        ss << reply->str;
        freeReplyObject(reply);
        return ss.str();
    }
}

//向数据库写入vector(list)类型数据
int MainWindow::setList(string key,vector<string> value)
{
    if(m_redis == NULL || m_redis->err)
    {
        cout << "Redis init Error !!!" << endl;
        init();
        return -1;
    }

    redisReply *reply;

    int valueSize = value.size();
    int result = 0;

    for(int i=0; i<valueSize; i++)
    {
        reply = (redisReply*)redisCommand(m_redis,"RPUSH %s %s", key.c_str(),value.at(i).c_str());
        cout<<"set list type = "<<reply->type<<" ";
        int old = reply->integer;
        if(reply == NULL)
        {
            redisFree(m_redis);
            m_redis = NULL;
            result = -1;
            cout << "set list fail : reply->str = NULL " << endl;
            //pthread_spin_unlock(&m_redis_flock);
            return -1;
        }
        else if(reply->integer == old++)
        {
            result = 1;
            cout<<"rpush list ok"<<endl;
            continue;
        }
        else
        {
            result = -1;
            cout << "set list fail ,reply->integer = " << reply->integer << endl;
            return -1;
        }

    }

    freeReplyObject(reply);
    cout<<"set List  success"<<endl;
    return result;

}

//从数据库读出vector(list)类型数据
vector<string> MainWindow::getList(string key)
{
    if(m_redis == NULL || m_redis->err)
    {
        cout << "Redis init Error !!!" << endl;
        init();
        return vector<string>{};//返回空的向量
    }

    redisReply *reply;
    reply = (redisReply*)redisCommand(m_redis,"LLEN %s", key.c_str());
    int valueSize = reply->integer;
    cout<<"List size is :"<<reply->integer<<endl;

    reply = (redisReply*)redisCommand(m_redis,"LRANGE %s %d %d", key.c_str(),0,valueSize-1);
    cout<<"get list type = "<<reply->type<<endl;
    cout<<"get list size = "<<reply->elements<<endl;//对于数组类型可以用elements元素获取数组长度

    redisReply** replyVector = reply->element;//获取数组指针
    vector<string> result;
    for(int i=0;i<valueSize;i++)
    {
        string temp =(*replyVector)->str;//遍历redisReply*数组,存入vector向量
//        int a =atoi(temp.c_str());
        result.push_back(temp);
        replyVector++;
    }

    cout<<"result size:"<<result.size()<<endl;
    return result;
}



打印:

init redis tool success 
#define REDIS_REPLY_STRING 1
#define REDIS_REPLY_ARRAY 2
#define REDIS_REPLY_INTEGER 3
#define REDIS_REPLY_NIL 4
#define REDIS_REPLY_STATUS 5
#define REDIS_REPLY_ERROR 6
Redis认证成功!
set string type = 5
get string type = 1
msg=haka
set list type = 3 rpush list ok
set list type = 3 rpush list ok
set list type = 3 rpush list ok
set list type = 3 rpush list ok
set List  success
List size is :4
get list type = 2
get list size = 4
result size:4
cat dog rat bird 

redis远程可视化工具:Another Redis DeskTop Manager

下载地址:https://github.com/qishibo/AnotherRedisDesktopManager/releases
下载exe安装包:Another-Redis-Desktop-Manager.1.6.0.exe。
安装程序后运行。

远程连接配置
1、关闭防火墙

 systemctl status firewalld		#查看防火墙状态
 systemctl stop firewalld		#关闭防火墙

2、修改redis配置文件

 vim redis.conf
 bind 0.0.0.0		#设置为0.0.0.0开放所有,或指定IP
 protected-mode no	#关闭保护模式,才能远程连接
 deamonize yes		#redis设置为后台启动
 requirepass 123456	#设置访问密码

编辑连接
在这里插入图片描述
连接成功
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

redis服务搭建,C++实现redis客户端,redis远程可视化工具 的相关文章

随机推荐

  • vector深度探索

    声明 xff1a 本文中所有图件都来自B站侯捷老师授课视频 vecctor 底层实现原理 图1 GNU2 9 实现的容器vector vector 的内存是动态增长的 xff0c vector 最重要的三个成员变量为 三个迭代器 xff1a
  • 发送一个http请求以及url三部分组成和语法

    浏览器从URL中解析出服务器的主机名浏览器讲服务器的主机名转化成服务器的IP地址 xff08 DNS解析 xff09 浏览器将端口号从URL解析出来浏览器建立一条鱼web服务器的TCP连接浏览器向服务器发送一条http请求报文服务器向浏览器
  • 结构体对齐规则

    结构体 xff1a 结构体 xff08 struct xff09 是由一系列具有相同类型或不同类型的数据构成的集合 因为这一特性 xff0c 方便了开发者在使用的过程中可以将需要的不同的数据类型放在一起 xff0c 做成我们需要的数据类型
  • GPS坐标用于机器人定位的简单处理

    文章目录 前言一 GPS数据格式二 GPS坐标转换二维坐标原理三 参考代码1 转换经纬度格式2 解析通过串口获得的NMEA数据3 将经纬度转换为xy平面二维坐标 前言 最近工作上面接触使用GPS的NMEA数据为机器人提供平面坐标定位 xff
  • 学完C++基础后再学什么?

    学完 xff1f 那是什么程度 xff1f STL用得熟练吗 xff1f 算法和数据结构掌握得怎么样呢 xff1f 会写界面吗 xff1f BOOST呢 xff1f 像楼上所说的换一种语言 xff0c 简直是痴人说梦 xff0c 如果不深入
  • 视觉SLAM十四讲:回环检测-知识点+代码

    目录 基于外观的几何关系1 基础知识1 1 准确率和召回率1 2 词袋模型1 3 字典1 4 字典的数据结构1 5 相似度的计算1 6 相似度评分的处理1 7 检测回环后的验证 2 实践与代码解析2 1 创建字典2 2 相似度计算 回环检测
  • QT笔记--QT内类的层次关系,以及控件从属关系

    QT窗口界面使用的类层次如下 只包含了直接使用部分 界面上每一个创建的控件 xff0c 都是一个控件类的对象 xff0c 定义在头文件ui mainwindoow h的类UI MainWindow中 xff0c 并且其中的成员函数setup
  • C_带参数的宏定义

    C 带参数的宏定义 xff23 语言允许宏带有参数 在宏定义中的参数称为形式参数 xff0c 在宏调用中的参数称为实际参数 对带参数的宏 xff0c 在调用中 xff0c 不仅要宏展开 xff0c 而且要用实参去代换形参 带参宏定义的一般形
  • 十进制数转换成十六进制数~C语言

    include lt stdio h gt 下面将整数a转换成十六进制输出的字符串 原理 xff1a 1 xff0c 首先知道0b100000 61 0b10000 2 61 0b1000 2 61 0b100 2 61 0b10 2 利用
  • Qt实现线程安全的单例模式

    实现方式 1 实现单例 把类的构造函数 拷贝构造函数 赋值操作符定义为private的 xff1b 把获取单例的接口和唯一的实例指针定义为static的 xff0c 不需要实例化 xff0c 直接通过类名即可访问 2 支持多线程 采用双重校
  • 文本文件和二进制文件的差异和区别

    广义上的二进制文件包括文本文件 xff0c 这里讨论的是狭义上的二进制文件与文本文件的比较 xff1a 能存储的数据类型不同 文本文件只能存储char型字符变量 二进制文件可以存储char int short long float 各种变量
  • Qt实现记录日志文件log

    概述 Qt有两种实现记录日志的方式 xff0c 第一种是安装自定义的Qt消息处理程序 xff0c 自动输出程序产生的调试消息 警告 关键和致命错误消息的函数 xff1b 第二种是自定义一个类 xff0c 可以在程序指定位置打印输出指定的内容
  • Qt在linux环境下调用动态库,pro工程文件加载库和QLibrary加载库两种方式

    QT调用动态库 xff0c 在编译时和运行时的方式不同 xff0c 编译时可在pro文件加载或使用QLibrary类加载 xff1b 运行时依赖环境变量 xff0c windows下直接把动态库拷贝到可执行文件目录即可 xff0c linu
  • linux下QT发布程序双击打不开解决方法

    现象 Qt开发的程序 xff0c 使用 终端可以打开 xff0c 双击却打不开 阶段一 右键可执行程序 xff0c 选择属性 xff0c 可执行程序类型如果是 application x sharedlib xff0c 在QT的pro文件添
  • Qt发起http请求,get和post方式,并接收响应数据

    目录 Qt发起http请求get xff0c 异步接收Qt发起http请求post xff0c 异步接收Qt发起http请求get和post xff0c 收发同步http下载网络图片 Qt发起http请求get xff0c 异步接收 get
  • QT实现浏览器访问网页,使用QWebEngineView

    支持访问网页 xff0c 前进 后退 刷新 xff0c 点击超链接自动跳转 xff0c 获取网页鼠标事件 xff0c 重新编译QWebEngineView库后还可以支持播放mp4等视频 xff1b Qt在debug模式运行有时访问网页很卡
  • Qt程序打包成安装包exe

    本章介绍把Qt开发的程序打包成安装包的方法 xff0c 程序打包成install exe xff0c 可双击安装 xff0c 有默认安装路径 xff0c 也可以选择安装目录 xff0c 自动生成桌面快捷方式和开始菜单选项 xff0c 可以在
  • C/C++socket网络编程

    目录 tcp和udp通信流程图socket函数bind函数listen函数accept函数connect函数recv recvfrom read函数send write sendto sendmsg函数close shutdown函数hto
  • OSPF路由协议解释

    目录 OSPF路由协议OSPF数据包类型OSPF邻区状态OSPF的邻接关系建立过程 路由名词解释OSPF开源项目 OSPF路由协议 OSPF简介 1 xff08 Open Shortest Path First xff09 xff0c 开放
  • redis服务搭建,C++实现redis客户端,redis远程可视化工具

    目录 redis简介redis服务搭建redis常用命令C 43 43 实现redis客户端redis远程可视化工具 Another Redis DeskTop Manager redis简介 官方网址 xff1a https redis