redis学习 jedis的使用与redis事务

redis学习 jedis的使用与redis事务,第1张

时隔9天,其实我也不是停止学习,而是很多其他的项目任务以及学习javaweb的相关设计模式,对于某些底层的原理目前没有太多的精力研究,学习redis也有很长的时间,9天之中学习过几大数据类型,今天晚上抽时间学了一点jedis模板的使用,实际上与我们之前redis项目实战时使用过的RedisTemplate模板的使用差不远,jedis的API几乎与redis原生提供的命令如出一辙。

jedis测试:
public class JedisDemo {
    @Test
    public void test() {
        /*这里提供端口与主机信息的有参构造以便jedis *** 作redis数据库*/
        Jedis jedis = new Jedis("192.168.20.150", 6379);
        /*身份验证,redis设置密码的话需要有验证密码*/
        jedis.auth("hlc");
        /*测试是否能ping通,通了返回pong!这里如果不通就得修改Linux的防火墙或者修改redis的配置文件。
            String ping = jedis.ping();
            System.out.println(ping);
        */

        /*测试相关配置的API
            jedis.set("name", "huanglinchun");
            String name = jedis.get("name");
            System.out.println(name);
            Boolean exit = jedis.exists("name");
            System.out.println(exit);
        */
        /*获取全部的key*/
        Set keys = jedis.keys("*");
        for (String key : keys) {
            System.out.println(key);
        }

    }
}
jedis模仿手机验证码的接收与发送以及验证:
public class PhoneV {
    public static void main(String[] args) {
//        saveCode("15136701189");
        Boolean comparison = Comparison("15136701189", "057051");
        if (comparison){
            System.out.println("验证成功!");
        }else {
            System.out.println("失败!");
        }
    }
    /*比对验证码*/
    public static Boolean Comparison(String phone,String code){
        Jedis jedis = new Jedis("192.168.20.150", 6379);
        jedis.auth("hlc");
        boolean comparison = jedis.get("C"+phone).equals(code);
        return comparison;
    }
    /*生成验证码的key存储进redis数据库并判断是否正确*/
    public static Boolean saveCode(String phone){
        Jedis jedis = new Jedis("192.168.20.150", 6379);
        jedis.auth("hlc");
        String countKey = "C"+phone;
        Boolean success = false;
        Boolean vPhone = VPhone(phone);
        if(vPhone){
            jedis.setex(countKey,120,getCode());
            success = true;
            System.out.println("发送成功!");
        }else {
            System.out.println("你的手机号并不能发送验证码!");
        }
        return success;
    }
    /*一个手机号一天之内只能发送三次,设置过期时间以及判断手机号对应的value值小于等于3*/
    public static Boolean VPhone(String phone){
        Jedis jedis = new Jedis("192.168.20.150", 6379);
        jedis.auth("hlc");
        String V = "V"+phone+":count";
        Boolean success = false;
        String count = jedis.get(V);
        if(count == null){
            jedis.setex(V,24*60*60, "1");
            success = true;
        }else if(Integer.parseInt(count)<=2){
            jedis.incr(V);
            success = true;
        }else if(Integer.parseInt(count)>2){
            jedis.close();
        }
        jedis.close();
        return success;
    }
    /*生成6位数字的验证码*/
    public static String getCode(){
        String code = "";
        Random random = new Random();
        for(int i=0;i<6;i++){
          code += random.nextInt(0,10);
        }
        return code;
    }
}
redis事务特性:隔离性、永久性,原子性体现在事务中的原子性 *** 作组队的过程中,每一个原子性 *** 作都具备“隔离性、永久性、原子性”。事务就是将一组原子性 *** 作进行有序的组队,一个事务的执行过程中无论其中原子性 *** 作是否成功执行,外部的 *** 作都不允许加入 *** 作队列中。 redis事务基本命令:multi、exec、discard。

discard 放弃组队(组队是事务中的原子性 *** 作进行有序的组合,在队列中依次排列)一般使用在multi与exec之间使用,也就是清空任务队列的作用。
 

multi命令组队的两种错误与默认的处理方式

组队的错误有两种情况:第一种是命令的错误,可能是语法错误,也可能是命令逻辑错误,这样的错误会导致exec完全不能实现事务中原子性 *** 作的进行。第二种错误是命令本身语法确实没有问题,但是在处理的 *** 作上有矛盾的错误。这种exec可以执行没有问题的原子性 *** 作,而对于错误 *** 作它会报错不执行。
 

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/915936.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-16
下一篇 2022-05-16

发表评论

登录后才能评论

评论列表(0条)

保存