C/C++轻量级并发TCP服务器框架Zinx-游戏服务器开发006:基于redis查找玩家姓名+游戏业务实现总结

文章目录

  • [1 Redis的安装与API的使用](#1 Redis的安装与API的使用)
    • [1.1 安装目录及环境变量](#1.1 安装目录及环境变量)
    • [1.2 设置远程客户端连接和守护进程](#1.2 设置远程客户端连接和守护进程)
    • [1.3 启动redis](#1.3 启动redis)
    • [1.4 Hiredis API的使用](#1.4 Hiredis API的使用)
    • [1.5 我的动态库和头文件](#1.5 我的动态库和头文件)
  • [2 Redis的使用](#2 Redis的使用)
    • [2.1 初始化时候](#2.1 初始化时候)
    • [2.2 结束的时候](#2.2 结束的时候)
  • [3 测试](#3 测试)
  • [4 Makefile](#4 Makefile)
  • [5 游戏业务总结](#5 游戏业务总结)

1 Redis的安装与API的使用

1.1 安装目录及环境变量

7.2版本redis-cli命令在bin目录下:

c 复制代码
vim /etc/profile

export REDIS_HOME=/usr/local/redis/bin
export PATH=$PATH:$REDIS_HOME

1.2 设置远程客户端连接和守护进程

c 复制代码
cp /usr/local/redis/redis-7.2.3/redis.conf /usr/local/redis/bin/
vim /usr/local/redis/bin/redis.conf

1.3 启动redis

c 复制代码
redis-server /usr/local/redis/bin/redis.conf

1.4 Hiredis API的使用

cpp 复制代码
git clone https://github.com/redis/hiredis.git
cd hiredis
make
make install
复制代码
mkdir -p /usr/local/include/hiredis /usr/local/include/hiredis/adapters /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2
cp -pPR hiredis.h async.h read.h sds.h alloc.h sockcompat.h /usr/local/include/hiredis
cp -pPR adapters/*.h /usr/local/include/hiredis/adapters
cp -pPR libhiredis.so /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2/libhiredis.so.1.2.1-dev
cd /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2 && ln -sf libhiredis.so.1.2.1-dev libhiredis.so && ln -sf libhiredis.so.1.2.1-dev libhiredis.so.1
cp -pPR libhiredis.a /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2
mkdir -p /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2/pkgconfig
cp -pPR hiredis.pc /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2/pkgconfig

1.5 我的动态库和头文件

根据上述的输出信息,我把动态库直接拷贝到了系统目录下,程序加载的时候加载的是libhiredis.so.1.2.1-dev

c 复制代码
 cp /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2/libhiredis.so /usr/lib
 
 cp /usr/local/:/usr/local/protobuf/lib/:/opt/instantclient_12_2/libhiredis.so.1.2.1-dev /usr/lib

头文件的位置没有改变,使用的默认设置

c 复制代码
usr/local/include/hiredis
  • 路径和库要根据实际情况设置
  • C函数库,包含头文件<hiredis/hiredis.h> ,编译时指定链接参数为-L/usr/lib -lhiredis
  • 运行时若提示找不到共享库,则在.bashrc最末端添加一句export LD_LIBRARY_PATH=/usr/lib,重新打开终端运行。
  • redisConnect跟数据库建立链接(redisFree释放掉)。
  • redisCommand发命令并通过返回值取出结果(freeReplyObject释放掉)。

2 Redis的使用

2.1 初始化时候

c 复制代码
//记录当前姓名到redis的game_name
	//1 连接redis
	auto context = redisConnect("127.0.0.1", 6379);
	//2 发送lpush命令
	if (NULL != context)
	{
		freeReplyObject(redisCommand(context, "lpush game_name %s", szName.c_str()));
		redisFree(context);
	}

2.2 结束的时候

c 复制代码
	//从redis  game_name中删掉当前姓名
	auto context = redisConnect("127.0.0.1", 6379);
	if (NULL != context)
	{
		freeReplyObject(redisCommand(context, "lrem game_name 1 %s", szName.c_str()));
		redisFree(context);
	}

3 测试



4 Makefile

cpp 复制代码
game:*.cpp *h
	g++ -Wall -g -pthread -std=c++11 $^ -o $@ -lzinx -lpthread -lprotobuf

5 游戏业务总结

相关推荐
ZERO_pan2 小时前
服务器装机遇到的问题
运维·服务器
逆小舟2 小时前
【Linux】人事档案——用户及组管理
linux·c++
l1t2 小时前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
杀气丶2 小时前
Linux下运行芙蕾雅天堂2【俄文简译L2FATER】
运维·服务器·天堂2·l2fater·l2fater.cn
喵手2 小时前
玩转Java网络编程:基于Socket的服务器和客户端开发!
java·服务器·网络
l1t4 小时前
利用美团龙猫用libxml2编写XML转CSV文件C程序
xml·c语言·libxml2·解析器
Tisfy6 小时前
服务器 - 从一台服务器切换至另一台服务器(损失数十条访客记录)
运维·服务器
风中的微尘6 小时前
39.网络流入门
开发语言·网络·c++·算法
混分巨兽龙某某7 小时前
基于Qt Creator的Serial Port串口调试助手项目(代码开源)
c++·qt creator·串口助手·serial port
猎板PCB黄浩7 小时前
从废料到碳减排:猎板 PCB 埋容埋阻的绿色制造革命,如何实现环保与性能双赢
java·服务器·制造