我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Redis的介绍及应用

本篇内容主要讲解“redis的介绍及应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis的介绍及应用”吧!

成都创新互联专注于云和企业网站建设,响应式网站,商城网站建设。云和网站建设公司,为云和等地区提供建站服务。全流程按需网站策划,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务

官网下不了,这里找了这个地址,版本比较老

下载驱动,搜索jedis

参考

基本操作

public class RedisTest {

	public static void main(String[] args) {
	
		/**
		 * 地址 端口 超时时间
		 */
		Jedis jedis = new Jedis("localhost", 6379, 100000);
		/**
		 * 测试是否通 
		 */
		System.out.println("服务正在运行: "+jedis.ping());
		
		/** 
		 * set:设置key值 
		 * get:获取key值 
		 * del:删除key 
		 * append:追加key值 
		 * incr:key值自增1 
		 * incrBy:key值自增,指定步长 
		 * decr:key值自减1 
		 * decrBy:key值自减,指定步长 
		 * expire:为key设置过期时间(秒数) 
		 * setex:设置key值,可指定存活时间(秒数) 
		 * setnx:设置key值。key不存在才会设置,如果key存在则回滚操作,结果返回0,表示没有设置成功 
		 * ttl:time to live,获取key的存活时间(秒),-1表示永不过期 
		 * persist:去掉key的expire设置,不再有失效时间 
		 */  
		jedis.set("first", "Hello World!");
		System.out.println(jedis.get("first"));
		
		/** 
		 * LIST
		 * 可以实现队列的功能 
		 * lpush: 从列表头部插入多个元素 
		 * rpush:从列表尾部插入多个元素 
		 * llen:返回列表中的元素的数量 
		 * lpop:从列表头部移除并返回list的第一个元素 
		 * lrem:从头部开始找,删除n个值 
		 * lrange:从列表中获取指定范围的子集 
		 */
		jedis.del("list");
		jedis.lpush("list", "1","2","3");
		jedis.lpush("list", "4");
		Long count=jedis.llen("list");
		List list=jedis.lrange("list", 0, count);
		System.out.println(list.toString());
		
		
		/** 
		 * sadd:往set对象中添加一个值 
		 * smembers:取得set中所有的值 
		 * sismember:判断一个值是否在set中存在 
		 * srandmember:从set中随机取得一个值 
		 * srem:从set中删除一个值 
		 * scard:返回set的item个数 
		 */
		jedis.del("set");
		jedis.sadd("set", "1","2","3");
		jedis.sadd("set", "4");
		jedis.sadd("set", "4");
		Set set=jedis.smembers("set");
		System.out.println(set.toString());
		
		/** 
		 * hmset:设置key值,值类型为map对象 
		 * type:返回key值的类型,可能值有none, string, hash, set, list, zset 
		 * hkeys:获取所有key 
		 * hvals:获取所有key对应的值 
		 * hmget:一次性获取多个field的值 
		 * hexists:判断field是否存在 
		 * hset:设置field的值 
		 * hgetAll:获取全部内容 
		 * hget:获取field的值 
		 * hdel:删除field 
		 * hincrBy:field值自增1 
		 * hlen:计算field的数目 
		 * hsetnx:设置key值。field不存在才会设置,如果field存在则回滚操作,结果返回0,表示没有设置成功。可以用来实现分布式锁 
		 */ 
		 jedis.del("user");  
	      
		    Map map = new HashMap();  
		    map.put("name", "cjm");  
		    map.put("age", "33");  
		    map.put("qq", "123456");  
		      
		    jedis.hmset("user", map);  
		    System.out.println("type: " + jedis.type("user"));   
		      
		    System.out.println("hkeys: " + jedis.hkeys("user"));   
		    System.out.println("hvals: " + jedis.hvals("user"));  
		      
		    System.out.println("hmget: " + jedis.hmget("user", "name", "age"));   
		    System.out.println("hexists: " + jedis.hexists("user", "name"));  
		      
		    jedis.hset("user", "pwd", "123");   
		    System.out.println("hgetAll: " + jedis.hgetAll("user"));   
		    System.out.println("hget: " + jedis.hget("user", "pwd"));   
		    jedis.hdel("user", "qq");   
		    System.out.println("hincrBy: " + jedis.hincrBy("user", "count", 1));   
		    System.out.println("hlen: " + jedis.hlen("user"));   
		      
		    Long r = jedis.hsetnx("user", "pwd2", "456");   
		    System.out.println(r); 
	}
}

消息订阅、

订阅
public class Consumer {

	public static void main(String[] args) {

		/**
		 * 地址 端口 超时时间
		 */
		Jedis jedis = new Jedis("localhost", 6379, 100000);
		 /**
	     * 消息订阅
	     */
	    JedisPubSub jps=new JedisPubSub() {
	    	public void onPMessage(String pattern, String channel, String message) {
	    		System.out.println("onPMessage()," + pattern + "=" + channel + "="
	    				+ message);
	    	}
	     
	    	public void onMessage(String channel, String message) {
	    		System.out.println("onMessage()," + channel + "=" + message);
	    	}
	    };
	    
	    jedis.psubscribe(jps, "test*");
	}
}

//发布
 jedis.publish("test1", "message from test1");
 jedis.publish("test2", "message from test2");

redis分布式锁

public class RedisTool {

    private static final String LOCK_SUCCESS = "OK";
    private static final Long RELEASE_SUCCESS = 1L;
    
    /**
     * 尝试获取分布式锁
     * @param jedis Redis客户端
     * @param lockKey 锁
     * @param requestId 请求标识
     * @param expireTime 超期时间
     * @return 是否获取成功
     */
    public static boolean tryGetDistributedLock(Jedis jedis, String lockKey, String requestId, int expireTime) {
        
        String result = jedis.set(lockKey, requestId,new SetParams().nx().ex(expireTime));
        if (LOCK_SUCCESS.equals(result)) {
            return true;
        }
        return false;

    }
    
    /**
     * 释放分布式锁
     * @param jedis Redis客户端
     * @param lockKey 锁
     * @param requestId 请求标识
     * @return 是否释放成功
     */
    public static boolean releaseDistributedLock(Jedis jedis, String lockKey, String requestId) {

        String script = "if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end";
        Object result = jedis.eval(script, Collections.singletonList(lockKey), Collections.singletonList(requestId));

        if (RELEASE_SUCCESS.equals(result)) {
            return true;
        }
        return false;

    }

}

public class LockTest {

	public static void main(String[] args) {

		Runnable rn = new Runnable() {
			@Override
			public void run() {
				Jedis jedis = new Jedis("localhost", 6379, 100000);
				String uuid = UUID.randomUUID().toString().replaceAll("-", "");
				int tryCount=5;
				while (true) {
					Boolean lock = RedisTool.tryGetDistributedLock(jedis, "lock", uuid, 10);
					if (lock) {
						System.out.println(Thread.currentThread().getName() + "获取锁");
						try {
							Thread.sleep(1000L);
						} catch (InterruptedException e) {
							e.printStackTrace();
						}
						Boolean unlock = RedisTool.releaseDistributedLock(jedis, "lock", uuid);
						if (unlock) {
							System.out.println(Thread.currentThread().getName() + "释放锁");
							break;
						}
					}
					
					if(tryCount<0) {
						break;
					}else {
						try {
							Thread.sleep(2000);
						} catch (InterruptedException e) {
							e.printStackTrace();
						}
						System.out.println(Thread.currentThread().getName() + "尝试次数:"+tryCount);
						tryCount--;
					}
				}
			}
		};
		for (int i = 0; i < 20; i++) {
			Thread t = new Thread(rn);
			t.start();
		}
		LockSupport.park();
	}
}

锁测试

package com.redis;

import java.util.UUID;
import java.util.concurrent.locks.LockSupport;

import redis.clients.jedis.Jedis;

public class ProductServer {

	/**
	 * 向服务端添加货
	 * 
	 * @return
	 */
	public boolean addProduct(Jedis jedis, String key, int i) {
		System.out.println("货物:" + key + "添加库存:" + i);
		if (i > 0) {
			System.out.println("---添加货物:" + key + "数量:" + i + "---");
			// 获取值
			String count = jedis.get(key);
			System.out.println("剩余库存:" + count);
			if (null == count || Integer.valueOf(count) <= 0) {
				System.out.println("---当前货物:" + key + "数量已销售完毕");
				System.out.println("---当前货物:" + key + "添加开始");
				jedis.set(key, i + "");
				System.out.println("---当前货物:" + key + "添加结束");
				return true;
			}
		}
		return false;
	}

	/**
	 * 消费数据
	 */
	public boolean decryProduct(Jedis jedis, String key, String requestID) {

		try {
		Boolean lock = RedisTool.tryGetDistributedLock(jedis, "lock", requestID, 100);
			if (!lock) {
				System.out.println("请稍后重试...");
				return false;
			}

			System.out.println("货物:" + key + "线程:" + Thread.currentThread().getName() + "消费数据:" + requestID);
			String count = jedis.get(key);
			if (null != count && Integer.valueOf(count) > 0) {
				jedis.decr(key);
				count = jedis.get(key);
				System.out.println("剩余库存:" + count);
				return true;
			}
		} catch (Exception e) {

		} finally {
			RedisTool.releaseDistributedLock(jedis, "lock", requestID);
		}
		return false;
	}

	public static void main(String[] args) {
		Jedis jedis = new Jedis("localhost", 6379, 10000);
		ProductServer ps = new ProductServer();
		ps.addProduct(jedis, "shouji", 10);

		Runnable rn = new Runnable() {
			@Override
			public void run() {
				String uuid = UUID.randomUUID().toString().replaceAll("-", "");
				Jedis jedis = new Jedis("localhost", 6379, 10000);
				ps.decryProduct(jedis, "shouji", uuid);
			}
		};

		for (int i = 0; i < 15; i++) {
			Thread td = new Thread(rn);
			td.start();
		}
		LockSupport.park();
	}
}

到此,相信大家对“Redis的介绍及应用”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


当前名称:Redis的介绍及应用
文章网址:http://mswzjz.cn/article/pigcci.html

其他资讯