时隔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<String> 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可以执行没有问题的原子性操作,而对于错误操作它会报错不执行。