c++ 语言redis分布式锁的实现
2022/1/9 19:05:30
本文主要是介绍c++ 语言redis分布式锁的实现,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
main.cpp
#include "redis.h" #include <unistd.h> int main() { Redis *r = new Redis(); r->connectRedis("127.0.0.1",6379,5); while (r->tryLock(40) != 0) { /* code */ sleep(10); } return 0; }
redis.h
#ifndef _REDIS_H_ #define _REDIS_H_ #include <iostream> #include <string.h> #include <string> #include <stdio.h> #include <hiredis/hiredis.h> class Redis { public: Redis(); ~Redis(); int connectRedis(std::string addr, int port, int time_out); int tryLock(int duration); redisReply *ExecuteCmd(const char *cmd, char *data = NULL, int dataSize = 0); private: redisContext *_connect; redisReply *_reply; private: int m_timeOutConnect; struct timeval m_tv; //redis 命令超时时间 redisContext *m_redisContent; std::string m_redisIp; int m_redisPort; }; #endif //_REDIS_H_
redis.cpp
#include "redis.h" Redis::Redis() {} Redis::~Redis() { this->_connect = NULL; this->_reply = NULL; } int Redis::connectRedis(std::string addr, int port, int time_out) { m_redisIp = addr; m_redisPort = port; int ret = -1; //struct timeval tv; m_tv.tv_sec = time_out; m_tv.tv_usec = 0; m_timeOutConnect = time_out; m_redisContent = redisConnectWithTimeout(m_redisIp.c_str(), m_redisPort, m_tv); if (m_redisContent == NULL) { ret = -1; return ret; } else { if (m_redisContent->err != 0) { std::cout << "connect redis ip:" << m_redisIp << ",port:" << m_redisPort << ",error:" << m_redisContent->errstr; ret = -1; redisFree(m_redisContent); m_redisContent = NULL; return ret; } } // ret = (int)authRedis(); redisSetTimeout(m_redisContent, m_tv); redisEnableKeepAlive(m_redisContent); } int Redis::tryLock(int duration) { int ret = -1; char cmdBuf[256] = {0}; sprintf(cmdBuf, "set %s %s ex %d nx", "gbdlock", "0.0.0.0", duration); //ex 设置键的过期时间为 second 秒。NX :只在键不存在时,才对键进行设置操作。 redisReply *reply = ExecuteCmd(cmdBuf); if (reply && reply->type != REDIS_REPLY_NIL && strcmp(reply->str, "OK") == 0) { ret = 0; std::cout << "redis set lock OK!!!" << "0.0.0.0" << std::endl; } else { char cmdBuf1[256] = {0}; /* get lock */ sprintf(cmdBuf1, "GET %s", "gbdlock"); reply = ExecuteCmd(cmdBuf1); if (reply && reply->type != REDIS_REPLY_NIL) { if (reply->str && !strcmp("gbdlock", reply->str)) { ret = 0; std::cout << "Get lock succ: integer = " << reply->integer << " str = " << reply->str; } } std::cout << "redis set lock fail!!!" << "gbdlock" << std::endl; } if (reply != NULL) { freeReplyObject(reply); } EXIT: return ret; } redisReply *Redis::ExecuteCmd(const char *cmd, char *data, int dataSize) { if (m_redisContent == NULL) { std::cout << "Redis: m_redisContent == NULL error"; return NULL; } redisReply *reply = NULL; if (data == NULL) { reply = (redisReply *)redisCommand(m_redisContent, cmd); } else { if (dataSize > 2 * 1024 * 1024 /*一个二进制redis数据的最大长度*/) { std::cout << "redis dataSize more then MAX_REDIS_BIN_LEN "; return NULL; } reply = (redisReply *)redisCommand(m_redisContent, cmd, data, dataSize); //redisReply *reply = (redisReply *)redisCommand(m_redisContent, "RPUSH %s %b", listName, data, dataSize); } return reply; }
makefile
redis: main.cpp redis.cpp g++ main.cpp redis.cpp -o test -L /usr/local/lib/ -lhiredis clean: rm redis
这篇关于c++ 语言redis分布式锁的实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-02阿里云Redis项目实战入门教程
- 2025-01-02阿里云Redis资料入门详解
- 2024-12-30阿里云Redis教程:新手入门指南
- 2024-12-27阿里云Redis学习入门指南
- 2024-12-27阿里云Redis入门详解:轻松搭建与管理
- 2024-12-27阿里云Redis学习:新手入门指南
- 2024-12-24Redis资料:新手入门快速指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-07Redis高并发入门详解