c语言操作redis数据库
参考网址:
https://blog.csdn.net/hyb612/article/details/78170728
https://blog.csdn.net/lihao21/article/details/70339494
https://www.cnblogs.com/sunsky303/p/8117181.html
https://github.com/redis/hiredis
hiredis-0.14.0.tar.gz
http://redisdoc.com/key/scan.html#scan
Redis Scan命令
https://www.cnblogs.com/tekkaman/p/4887293.html
VisualGDB 如何使用第三方库(例:SQLITE3)
https://blog.myzony.com/visualgdb-ru-he-shi-yong-di-san-fang-ku-li-sqlite3/
c语言实现Redis遍历所有key
https://blog.csdn.net/king_jie0210/article/details/80410556
Redis遍历所有key的两个命令 – KEYS 和 SCAN
https://blog.csdn.net/zhang197093/article/details/74615717
处理redis连接数过多
https://blog.csdn.net/u013050593/article/details/56480358
系统安装 hiredis-0.14.0
tar xvf v0.14.0.tar.gz
make
sudo make install
mkdir -p /usr/local/include/hiredis /usr/local/include/hiredis/adapters /usr/local/lib
cp -pPR hiredis.h async.h read.h sds.h /usr/local/include/hiredis
cp -pPR adapters/*.h /usr/local/include/hiredis/adapters
cp -pPR libhiredis.so /usr/local/lib/libhiredis.so.0.14
cd /usr/local/lib && ln -sf libhiredis.so.0.14 libhiredis.so
cp -pPR libhiredis.a /usr/local/lib
mkdir -p /usr/local/lib/pkgconfig
cp -pPR hiredis.pc /usr/local/lib/pkgconfig
sudo ldconfig #使动态库在系统中更新生效
代码
写好代码后,我们对上面的代码进行编译。
gcc -o testhiredis testhiredis.c -L/usr/local/lib -lhiredis
1
其中的-L参数指定 gcc 的库文件的搜索路径,在这里为/usr/local/lib。/usr/local/lib包含了 hiredis 的库文件。-l参数则指明使用的库文件,-lhiredis的意思即是搜索libhiredis.a的库文件。libhiredis.a实际上已安装在/usr/local/lib目录下了,有兴趣的可以查证一下。
处理redis连接数过多
https://blog.csdn.net/u013050593/article/details/56480358
redis服务器默认设置的最大连接数maxclients是10000,但是受服务器最大文件数影响,服务器默认最大文件数是1024,所以redis最大连接也为1024-32=992,由于网络原因或连接未正常关闭导致redis服务器连接数接近990左右,应用程序连不上redis。
多线程环境中使用redis
不能在不同的线程中使用同一个实例,因为你将会有奇怪的错误。有时创建多个jedis的实例也不是很好,因为也会发生奇怪的错误。一个jedis实例线程不安全。为了避免上述奇怪的错误,你应该使用jedisPool,它是网络连接线程安全池。你可以使用pool静态的创建几个jedis实例,这种方式可以克服那些奇怪的错误而收获巨大的性能。
为了使用它,初始化一个pool:
JedisPool pool=new JedisPool(new JedisPoolConfig(),“localhost”);
JedisPoolConfig包含很多有用的Redis-specific默认连接。JedisPool是基于Commons Pool 2,所以你也许想看看Commons Pool’s 配置。Please see http://commons.apache.org/proper/commons-pool/apidocs/org/apache/commons/pool2/impl/GenericObjectPoolConfig.html for more details.
You use it by: