redis

转载请注明出处: http://blog.youkuaiyun.com/jmppok/article/details/18085181

redis相比很多人都知道,是一个内存式的key-value数据库,存取速度极快,使用非常简单,支持多种语言。本文对其使用进行一个简要说明,并进行简单测试。

1.下载与编译

可以从redis官网下载最新的源码包:http://www.redis.io/

编译十分简单make既可。

2.redis安装与配置

实际上并不需要安装。redis编译后会在src目录下生成redis-server,它是一个可执行文件,即启动redis服务。不过它需要一个配置文件。配置文件写法网上很多了,这里直接给出一个示例:

  1. daemonize yes  
  2. pidfile /tmp/redis/var/redis.pid  
  3. port 6379  
  4. timeout 300  
  5. loglevel debug  
  6. logfile /tmp/redis/var/redis.log  
  7. databases 16  
  8. save 900 1  
  9. save 300 10  
  10. save 60 10000  
  11. rdbcompression yes  
  12. dbfilename dump.rdb  
  13. dir /tmp/redis/var/  
  14. appendonly no  
  15. appendfsync always  
  16. #glueoutputbuf yes  
  17. #shareobjects no  
  18. #shareobjectspoolsize 1024  
daemonize yes
pidfile /tmp/redis/var/redis.pid
port 6379
timeout 300
loglevel debug
logfile /tmp/redis/var/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /tmp/redis/var/
appendonly no
appendfsync always
#glueoutputbuf yes
#shareobjects no
#shareobjectspoolsize 1024
将其保存为redis.conf
然后直接运行./redis-server redis.conf就可以启动redis服务了,是不是很方便呢?

3.C/C++访问redis

在redis源码目录下有一个deps目录,下面有一个hiredis目录。redis编译时会自动编译该目录生成libhiredis.a,通过引用hiredis.h 和 libhiredis.a就可以访问redis了。具体步骤如下:

1)创建一个redisContext

2)通过redisContext执行命令

3)从返回redisReply中获取所需数据

代码如下:

  1. redisContext *  c = redisConnect((char *)"192.168.150.135",6379);  
  2. const char * pData = "this is a test";  
  3.   
  4. redisReply *reply1 = (redisReply *)redisCommand(c,"SET 100 %s",pData);  
  5.   
  6. freeReplyObject(reply1);  
  7.   
  8.   
  9. redisReply *reply2 = (redisReply *)redisCommand(c,"GET 100");  
  10.   
  11. printf("%s\n",reply2->str);  
  12. freeReplyObject(reply2);  
redisContext *  c = redisConnect((char *)"192.168.150.135",6379);
const char * pData = "this is a test";

redisReply *reply1 = (redisReply *)redisCommand(c,"SET 100 %s",pData);

freeReplyObject(reply1);


redisReply *reply2 = (redisReply *)redisCommand(c,"GET 100");

printf("%s\n",reply2->str);
freeReplyObject(reply2);
是不是非常简单呢?

不过需要注意的是,redis接受的数据是字符串,对于二进制数据,可以通过base64编码来解决。具体可参看我的另一篇文章。

4.Java访问redis

redis可以支持多种语言,当然也可以支持Java。

首先需要下载redis的java包。jedis.jar。这里提供一个下载地址:redis的Java客户端jedis

使用如下:

  1. Jedis jedis = new Jedis("192.168.150.135");  
  2. jedis.set("100","this is a test");  
  3. String data = jedis.get("100");  
Jedis jedis = new Jedis("192.168.150.135");
jedis.set("100","this is a test");
String data = jedis.get("100");

5.性能测试


测试方法:向redis写一个1M的数据,分别写10次,读10次,计算其耗时。分C++和Java两个版本进行测试。

C++测试代码

  1. #include <stdio.h>  
  2. #include "hiredis.h"  
  3. #include <string.h>  
  4. #include <time.h>  
  5.   
  6. int main(int argc, char **argv)  
  7. {  
  8.     printf("CLOCKS_PER_SEC:%d\n",CLOCKS_PER_SEC);  
  9.     redisContext *c;  
  10.     redisReply *reply;  
  11.   
  12.     c = redisConnect((char *)"one-60",6379);  
  13.   
  14.     char * pData;  
  15.       
  16.     reply = (redisReply *)redisCommand(c,"GET 0");  
  17.     int size = strlen(reply->str);  
  18.     pData = new char[size+1];  
  19.     strcpy(pData,reply->str);  
  20.     freeReplyObject(reply);  
  21.       
  22.     clock_t start, finish;  
  23.     start = clock();  
  24.       
  25.     for(int i=0;i<10; i++)  
  26.     {  
  27.         reply = (redisReply *)redisCommand(c,"GET %d",i);  
  28.         freeReplyObject(reply);  
  29.     }  
  30.       
  31.     finish = clock();  
  32.     double duration = (double)(finish - start) / CLOCKS_PER_SEC*1000;  
  33.     printf("GET Time used:%f ms.\n",duration);  
  34.       
  35.       
  36.     start = clock();  
  37.       
  38.     for(int i=0;i<10; i++)  
  39.     {  
  40.         reply = (redisReply *)redisCommand(c,"SET %d %s",i,pData);  
  41.         freeReplyObject(reply);  
  42.     }  
  43.       
  44.     finish = clock();  
  45.     duration = (double)(finish - start) / CLOCKS_PER_SEC*1000;  
  46.     printf("SET Time used:%f ms.\n",duration);  
  47.                   
  48.     delete []pData;  
  49.     redisFree(c);  
  50. }  
#include <stdio.h>
#include "hiredis.h"
#include <string.h>
#include <time.h>

int main(int argc, char **argv)
{
	printf("CLOCKS_PER_SEC:%d\n",CLOCKS_PER_SEC);
	redisContext *c;
    redisReply *reply;

    c = redisConnect((char *)"one-60",6379);

	char * pData;
    
    reply = (redisReply *)redisCommand(c,"GET 0");
	int size = strlen(reply->str);
	pData = new char[size+1];
	strcpy(pData,reply->str);
    freeReplyObject(reply);
	
	clock_t start, finish;
	start = clock();
	
	for(int i=0;i<10; i++)
	{
		reply = (redisReply *)redisCommand(c,"GET %d",i);
		freeReplyObject(reply);
	}
	
	finish = clock();
	double duration = (double)(finish - start) / CLOCKS_PER_SEC*1000;
	printf("GET Time used:%f ms.\n",duration);
	
	
	start = clock();
	
	for(int i=0;i<10; i++)
	{
		reply = (redisReply *)redisCommand(c,"SET %d %s",i,pData);
		freeReplyObject(reply);
	}
	
	finish = clock();
	duration = (double)(finish - start) / CLOCKS_PER_SEC*1000;
	printf("SET Time used:%f ms.\n",duration);
				
	delete []pData;
	redisFree(c);
}
测试结果:

  1. CLOCKS_PER_SEC:1000000  
  2. GET Time used:190.000000 ms.  
  3. SET Time used:70.000000 ms.  
CLOCKS_PER_SEC:1000000
GET Time used:190.000000 ms.
SET Time used:70.000000 ms.

Java测试代码

  1. import java.io.BufferedReader;  
  2. import java.io.File;  
  3. import java.io.FileReader;  
  4. import java.util.Date;  
  5.   
  6. import redis.clients.jedis.Jedis;  
  7.   
  8.   
  9. public class JedisTest {  
  10.     public static void main(String[] args)  
  11.     {  
  12.         Jedis jedis = new Jedis("10.100.211.232");  
  13.           
  14.         String f = "/tmp/e2.txt.backup";  
  15.           
  16.         try  
  17.         {  
  18.             File file = new File(f);  
  19.             BufferedReader reader = new BufferedReader(new FileReader(file));  
  20.             String data = reader.readLine();  
  21.             reader.close();  
  22.               
  23.             Date start = new Date();  
  24.             for(int i=0; i<10; i++)  
  25.             {  
  26.                 jedis.set(i+"", data);  
  27.             }  
  28.             Date end = new Date();  
  29.             System.out.println("Set used(ms):"+(end.getTime()-start.getTime()));  
  30.               
  31.             start = new Date();  
  32.             for(int i=0; i<10; i++)  
  33.             {  
  34.                 String v = jedis.get(i+"");  
  35.             }  
  36.             end = new Date();  
  37.             System.out.println("Get used(ms):"+(end.getTime()-start.getTime()));  
  38.               
  39.         }catch (Exception e)  
  40.         {  
  41.             e.printStackTrace();  
  42.         }  
  43.         jedis.disconnect();  
  44.     }  
  45. }  
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.Date;

import redis.clients.jedis.Jedis;


public class JedisTest {
	public static void main(String[] args)
	{
		Jedis jedis = new Jedis("10.100.211.232");
		
		String f = "/tmp/e2.txt.backup";
		
		try
		{
			File file = new File(f);
			BufferedReader reader = new BufferedReader(new FileReader(file));
			String data = reader.readLine();
			reader.close();
			
			Date start = new Date();
			for(int i=0; i<10; i++)
			{
				jedis.set(i+"", data);
			}
			Date end = new Date();
			System.out.println("Set used(ms):"+(end.getTime()-start.getTime()));
			
			start = new Date();
			for(int i=0; i<10; i++)
			{
				String v = jedis.get(i+"");
			}
			end = new Date();
			System.out.println("Get used(ms):"+(end.getTime()-start.getTime()));
			
		}catch (Exception e)
		{
			e.printStackTrace();
		}
		jedis.disconnect();
	}
}
测试结果

  1. Set used(ms):1212  
  2. Get used(ms):1437  
Set used(ms):1212
Get used(ms):1437

6.总结


redis效率还是非常高的,读写1M数据的数据,耗时都在10ms左右。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值