最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

多种方式测试redis入库性能

来源:动视网 责编:小采 时间:2020-11-09 13:20:51
文档

多种方式测试redis入库性能

多种方式测试redis入库性能: Transaction Pipeline 耗时(s) 测试一: N N 311 测试二: N Y 10 测试三: Y Y 7 测试四: Y N 10 结论:Pipeline + Transaction方式是几种插入方式中性能最好的。虽然有点意外,但测试多次仍然是这个结论。 测试代码如下: import
推荐度:
导读多种方式测试redis入库性能: Transaction Pipeline 耗时(s) 测试一: N N 311 测试二: N Y 10 测试三: Y Y 7 测试四: Y N 10 结论:Pipeline + Transaction方式是几种插入方式中性能最好的。虽然有点意外,但测试多次仍然是这个结论。 测试代码如下: import


? ? Transaction Pipeline 耗时(s) 测试一: N N 311 测试二: N Y 10 测试三: Y Y 7 测试四: Y N 10 ? 结论:Pipeline + Transaction方式是几种插入方式中性能最好的。虽然有点意外,但测试多次仍然是这个结论。 ? 测试代码如下: ? import org.apache.

?

? Transaction Pipeline 耗时(s)
测试一: N N 311
测试二: N Y 10
测试三: Y Y 7
测试四: Y N 10

?

结论:Pipeline + Transaction方式是几种插入方式中性能最好的。虽然有点意外,但测试多次仍然是这个结论。

?

测试代码如下:

?

import org.apache.commons.lang.RandomStringUtils;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.Pipeline;
import redis.clients.jedis.Transaction;
public class RedisTransactionTest {
	private static String host = "xx.xx.xx.xx";
	private static JedisPool pool = new JedisPool(new JedisPoolConfig(), host);
	private long rowCount = 1000000; // 100万
	public static void main(String[] args) {
	long start = System.currentTimeMillis();
	new RedisTransactionTest().noTransactionNoPipeline();
	System.out.println("noTransactionNoPipeline use " + (System.currentTimeMillis() - start) / 1000);
	pool = new JedisPool(new JedisPoolConfig(), host);
	start = System.currentTimeMillis();
	new RedisTransactionTest().pipelineWithoutTransaction();
	System.out.println("pipelineWithoutTransaction use " + (System.currentTimeMillis() - start) / 1000);
	pool = new JedisPool(new JedisPoolConfig(), host);
	start = System.currentTimeMillis();
	new RedisTransactionTest().pipelineWithTransaction();
	System.out.println("pipelineWithTransaction use " + (System.currentTimeMillis() - start) / 1000);
	pool = new JedisPool(new JedisPoolConfig(), host);
	start = System.currentTimeMillis();
	new RedisTransactionTest().transactionNoPipeline();
	System.out.println("transactionNoPipeline use " + (System.currentTimeMillis() - start) / 1000);
	}
	public void pipelineWithoutTransaction() {
	Jedis jedis = pool.getResource();
	try {
	Pipeline p = jedis.pipelined();
	for (int i = 0; i < rowCount; i++) {
	String key = RandomStringUtils.randomAlphabetic(8);
	p.set(key, RandomStringUtils.randomNumeric(5));
	p.expire(key, 5 * 60);
	}
	p.sync();
	} catch (Exception e) {
	pool.returnResource(jedis);
	}
	}
	public void pipelineWithTransaction() {
	Jedis jedis = pool.getResource();
	try {
	Pipeline p = jedis.pipelined();
	p.multi();
	for (int i = 0; i < rowCount; i++) {
	String key = RandomStringUtils.randomAlphabetic(8);
	p.set(key, RandomStringUtils.randomNumeric(5));
	p.expire(key, 5 * 60);
	}
	p.exec();
	p.sync();
	} catch (Exception e) {
	pool.returnResource(jedis);
	}
	}
	public void noTransactionNoPipeline() {
	Jedis jedis = pool.getResource();
	try {
	for (int i = 0; i < rowCount; i++) {
	String key = RandomStringUtils.randomAlphabetic(8);
	jedis.set(key, RandomStringUtils.randomNumeric(5));
	jedis.expire(key, 5 * 60);
	}
	} catch (Exception e) {
	pool.returnResource(jedis);
	}
	}
	public void transactionNoPipeline() {
	Jedis jedis = pool.getResource();
	try {
	Transaction tx = jedis.multi();
	for (int i = 0; i < rowCount; i++) {
	String key = RandomStringUtils.randomAlphabetic(8);
	tx.set(key, RandomStringUtils.randomNumeric(5));
	tx.expire(key, 5 * 60);
	}
	tx.exec();
	} catch (Exception e) {
	pool.returnResource(jedis);
	}
	}
}

?--end

?

?



已有 0 人发表留言,猛击->> 这里<<-参与讨论


ITeye推荐
  • —软件人才免语言低担保 赴美带薪读研!—



  • 文档

    多种方式测试redis入库性能

    多种方式测试redis入库性能: Transaction Pipeline 耗时(s) 测试一: N N 311 测试二: N Y 10 测试三: Y Y 7 测试四: Y N 10 结论:Pipeline + Transaction方式是几种插入方式中性能最好的。虽然有点意外,但测试多次仍然是这个结论。 测试代码如下: import
    推荐度:
    标签: 方法 测试 方式
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top