NutzCN Logo
分享 干货,分享适合nutz的Redis类,支持多数据源注入
发布于 2543天前 作者 文涛(wentao) 2581 次浏览 复制 上一个帖子 下一个帖子
标签:

代码

package tool.wentao.utils;

import org.nutz.ioc.impl.PropertiesProxy;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.util.List;
import java.util.Map;

/**
 * Created by wentao on 2018/2/1.
 */
public class Redis {
    private static final String host_prefix = "redis.host.";
    private static final String pass_prefix = "redis.password.";
    private static final String max_total_prefix = "redis.pool.max.total.";
    private static final String max_idle_prefix = "redis.pool.max.idle.";
    private static final String max_wait_millis_prefix = "redis.pool.max.wait.millis.";
    private static final String test_on_borrow_prefix = "redis.pool.test.on.borrow.";

    private JedisPool defualtPool;
    private JedisPool masterPool;
    private JedisPool slavePool;
    private boolean isMasterSlave;

    public Redis(String redisName, PropertiesProxy conf) {
        System.out.println("创建了新的redis对象");
        /**
         * redis.host.local=localhost:6379|localhost:6380
         * redis.password.local=123123
         * redis.pool.max.total.local=50
         * redis.pool.max.idle.local=5
         * redis.pool.max.wait.millis.local=100000
         * redis.pool.test.on.borrow.local=true
         */
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(conf.getInt(max_total_prefix + redisName, 50));
        config.setMaxIdle(conf.getInt(max_idle_prefix + redisName, 5));
        config.setMaxWaitMillis(conf.getInt(max_wait_millis_prefix + redisName, 100000));
        config.setTestOnBorrow(conf.getBoolean(test_on_borrow_prefix + redisName, true));

        // 读取IP集
        String hosts = conf.get(host_prefix + redisName);
        // 读取密码
        String password = conf.get(pass_prefix + redisName);
        // 如果是主从
        this.isMasterSlave = hosts.contains("|"); //如果host配置带有"|"符号, 则视为主从结构
        if(this.isMasterSlave) {
            // 切分地址
            String[] hostArray = hosts.split("\\|");
            // 解析主redis信息
            String masterHost = hosts.split("\\|")[0].split(":")[0];
            int masterPort = Integer.parseInt(hosts.split("\\|")[0].split(":")[1]);
            // 解析从redis信息
            String slaveHost = hosts.split("\\|")[1].split(":")[0];
            int slavePort = Integer.parseInt(hosts.split("\\|")[1].split(":")[1]);
            // 配置主redis池
            if(password.isEmpty()){
                this.masterPool = new JedisPool(config, masterHost, masterPort);
            } else {
                this.masterPool = new JedisPool(config, masterHost, masterPort, 2000, password);
            }
            // 配置从redis池
            if(password.isEmpty()){
                this.slavePool = new JedisPool(config, slaveHost, slavePort);
            } else {
                this.slavePool = new JedisPool(config, slaveHost, slavePort, 2000, password);
            }

        } else {
            String host = hosts.split(":")[0];
            int port = Integer.parseInt(hosts.split(":")[1]);
            if(password.isEmpty()){
                this.defualtPool = new JedisPool(config, host, port);
            } else {
                this.defualtPool = new JedisPool(config, host, port, 2000, password);
            }
        }
    }

    private Jedis getMasterRedis() {
        if(this.isMasterSlave) {
            return this.masterPool.getResource();
        } else {
            return this.defualtPool.getResource();
        }
    }

    private Jedis getSlaveRedis() {
        if(this.isMasterSlave) {
            return this.slavePool.getResource();
        } else {
            return this.defualtPool.getResource();
        }
    }

    public String get(String key) {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.get(key);
        } finally {
            redis.close();
        }
    }

    public String set(String key, String value) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.set(key, value);
        } finally {
            redis.close();
        }
    }

    public Long dbsize() {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.dbSize();
        } finally {
            redis.close();
        }
    }

    public Long del(String... keys) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.del(keys);
        } finally {
            redis.close();
        }
    }

    public Long hset(String key, String field, String value) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.hset(key, field, value);
        } finally {
            redis.close();
        }
    }

    public String hget(String key, String field) {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.hget(key, field);
        } finally {
            redis.close();
        }
    }

    public Map<String, String> hgetall(String key) {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.hgetAll(key);
        } finally {
            redis.close();
        }
    }

    public Long hdel(String key, String... fields) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.hdel(key, fields);
        } finally {
            redis.close();
        }
    }

    public Boolean exists(String key) {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.exists(key);
        } finally {
            redis.close();
        }
    }

    public String lpop(String key) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.lpop(key);
        } finally {
            redis.close();
        }
    }

    public String rpop(String key) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.rpop(key);
        } finally {
            redis.close();
        }
    }

    public List<String> blpop(int timeout, String key) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.blpop(timeout, key);
        } finally {
            redis.close();
        }
    }

    public List<String> brpop(int timeout, String key) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.brpop(timeout, key);
        } finally {
            redis.close();
        }
    }

    public Long lpush(String key, String... values) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.lpush(key, values);
        } finally {
            redis.close();
        }
    }

    public Long rpush(String key, String... values) {
        Jedis redis = null;
        try {
            redis = getMasterRedis();
            return redis.rpush(key, values);
        } finally {
            redis.close();
        }
    }

    public Long llen(String key) {
        Jedis redis = null;
        try {
            redis = getSlaveRedis();
            return redis.llen(key);
        } finally {
            redis.close();
        }
    }
}

配置项

redis.host.local=localhost:6379|localhost:6380
redis.password.local=123456
redis.pool.max.total.local=50
redis.pool.max.idle.local=5
redis.pool.max.wait.millis.local=100000
redis.pool.test.on.borrow.local=true

注入

@IocBean
public class IocBeans {
    @Inject
    protected PropertiesProxy conf;

    @IocBean(name="redisLocal")
    public Redis redisLocal() {
       return new Redis("local", conf);
    }
}

使用

@Inject
protected Redis redisLocal;

public String getUser(String passport) {
    return redisLocal.get(passport); // 查询帐号信息
}
添加回复
请先登陆
回到顶部