redis存储php对象吗,redis中list怎么存储对象

本文探讨了如何使用Jedis将List对象序列化并存储在Redis中,以避免直接使用其提供的操作方法,通过ObjectsTranscoder和ListTranscoder实现。适合处理无需频繁操作的List数据存储。
摘要由CSDN通过智能技术生成

c2bb6479b9f0639dd3302ef9eb2dd7cb.png

如果需要用到Redis存储List对象,而list又不需要进行操作,可以按照MC的方式进行存储,不过Jedis之类的客户端没有提供API,可以有两种思路实现:

1. 分别序列化 elements ,然后 set 存储

2. 序列化List对象,set存储

这两种方法都类似MC的 Object方法存储,运用这种方式意味着放弃Redis对List提供的操作方法。import net.spy.memcached.compat.CloseUtil;

import net.spy.memcached.compat.log.Logger;

import net.spy.memcached.compat.log.LoggerFactory;

import redis.clients.jedis.Client;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.JedisPool;

import redis.clients.jedis.JedisPoolConfig;

import java.io.*;

import java.util.ArrayList;

import java.util.List;

import java.util.Random;

/**

* Created by IntelliJ IDEA.

* User: lifeng.xu

* Date: 12-6-11

* Time: 上午11:10

* To change this template use File | Settings | File Templates.

*/

public class JedisTest {

private static Logger logger = LoggerFactory.getLogger(JedisTest.class);

/**

* Jedis Pool for Jedis Resource

* @return

*/

public static JedisPool buildJedisPool(){

JedisPoolConfig config = new JedisPoolConfig();

config.setMaxActive(1);

config.setMinIdle(50);

config.setMaxIdle(3000);

config.setMaxWait(5000);

JedisPool jedisPool = new JedisPool(config,

"*****", ****);

return jedisPool;

}

/**

* Test Data

* @return

*/

public static List buildTestData(){

User a = new User();

a.setName("a");

User b = new User();

b.setName("b");

List list = new ArrayList();

list.add(a);

list.add(b);

return list;

}

/**

* Test for

*/

public static void testSetElements(){

List testData = buildTestData();

Jedis jedis = buildJedisPool().getResource();

String key = "testSetElements" + new Random(1000).nextInt();

jedis.set(key.getBytes(), ObjectsTranscoder.serialize(testData));

//验证

byte[] in = jedis.get(key.getBytes());

List list = ObjectsTranscoder.deserialize(in);

for(User user : list){

System.out.println("testSetElements user name is:" + user.getName());

}

}

public static void testSetEnsemble(){

List testData = buildTestData();

Jedis jedis = buildJedisPool().getResource();

String key = "testSetEnsemble" + new Random(1000).nextInt();

jedis.set(key.getBytes(), ListTranscoder.serialize(testData));

//验证

byte[] in = jedis.get(key.getBytes());

List list = (List)ListTranscoder.deserialize(in);

for(User user : list){

System.out.println("testSetEnsemble user name is:" + user.getName());

}

}

public static void main(String[] args) {

testSetElements();

testSetEnsemble();

}

public static void close(Closeable closeable) {

if (closeable != null) {

try {

closeable.close();

} catch (Exception e) {

logger.info("Unable to close %s", closeable, e);

}

}

}

static class User implements Serializable{

String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

static class ObjectsTranscoder{

public static byte[] serialize(List value) {

if (value == null) {

throw new NullPointerException("Can't serialize null");

}

byte[] rv=null;

ByteArrayOutputStream bos = null;

ObjectOutputStream os = null;

try {

bos = new ByteArrayOutputStream();

os = new ObjectOutputStream(bos);

for(User user : value){

os.writeObject(user);

}

os.writeObject(null);

os.close();

bos.close();

rv = bos.toByteArray();

} catch (IOException e) {

throw new IllegalArgumentException("Non-serializable object", e);

} finally {

close(os);

close(bos);

}

return rv;

}

public static List deserialize(byte[] in) {

List list = new ArrayList();

ByteArrayInputStream bis = null;

ObjectInputStream is = null;

try {

if(in != null) {

bis=new ByteArrayInputStream(in);

is=new ObjectInputStream(bis);

while (true) {

User user = (User) is.readObject();

if(user == null){

break;

}else{

list.add(user);

}

}

is.close();

bis.close();

}

} catch (IOException e) {

logger.warn("Caught IOException decoding %d bytes of data",

in == null ? 0 : in.length, e);

} catch (ClassNotFoundException e) {

logger.warn("Caught CNFE decoding %d bytes of data",

in == null ? 0 : in.length, e);

} finally {

CloseUtil.close(is);

CloseUtil.close(bis);

}

return list;

}

}

static class ListTranscoder{

public static byte[] serialize(Object value) {

if (value == null) {

throw new NullPointerException("Can't serialize null");

}

byte[] rv=null;

ByteArrayOutputStream bos = null;

ObjectOutputStream os = null;

try {

bos = new ByteArrayOutputStream();

os = new ObjectOutputStream(bos);

os.writeObject(value);

os.close();

bos.close();

rv = bos.toByteArray();

} catch (IOException e) {

throw new IllegalArgumentException("Non-serializable object", e);

} finally {

close(os);

close(bos);

}

return rv;

}

public static Object deserialize(byte[] in) {

Object rv=null;

ByteArrayInputStream bis = null;

ObjectInputStream is = null;

try {

if(in != null) {

bis=new ByteArrayInputStream(in);

is=new ObjectInputStream(bis);

rv=is.readObject();

is.close();

bis.close();

}

} catch (IOException e) {

logger.warn("Caught IOException decoding %d bytes of data",

in == null ? 0 : in.length, e);

} catch (ClassNotFoundException e) {

logger.warn("Caught CNFE decoding %d bytes of data",

in == null ? 0 : in.length, e);

} finally {

CloseUtil.close(is);

CloseUtil.close(bis);

}

return rv;

}

}

}

PS:Redsi中存储list没有封装对Object的API,是不是也是倾向于只存储用到的字段,而不是存储Object本身呢?Redis是一个In-Mem的产品,会觉得我们应用的方式。

更多Redis相关技术文章,请访问Redis教程栏目进行学习!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值