redis环境搭建和java应用
####下载
```bash
wget http://download.redis.io/releases/redis-4.0.9.tar.gz
```
####解压移动
tar -xvf redis-4.0.9.tar.gz
mv redis-4.0.9/ /usr/local/
####编译测试
sudo make test
####启动服务
redis-server
redis-server &
####停止
redis-cli shutdown
####查看版本
redis-server -v
####查看redis运行状态
ps aux|grep redis
lsof -i tcp:6379
####登录redis
cd /usr/local/redis-4.0.9
redis-cli -h 127.0.0.1 -p 6379
####退出连接
quit
####服务器的信息和统计
info
####测试服务器是否存活
ping
####设置key
set foo bar
####取值
get foo
####判断某个key是否存在
exists foo
####删除key
del foo
####key类型
type foo
####加载源
```java
redis.clients
jedis
2.8.2
```
示例
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import java.util.List;
import java.util.Set;
import java.util.Iterator;
import redis.clients.jedis.Jedis;
@Controller
public class RedisController {
public static void main(String[] args) {
//连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
//查看服务是否运行
System.out.println("服务正在运行: " + jedis.ping());
// 清空数据
System.out.println("清空库中所有数据:" + jedis.flushDB());
//key-value
System.out.println("============================================");
jedis.set("a", "day1"); // 存数据
System.out.println("a的value为" + jedis.get("a")); // 取数据
jedis.append("a", "-day2");
System.out.println("追加后a的value为" + jedis.get("a"));
// 输出系统中所有的key
System.out.println("所有的redis-key为:");
Set<String> keys = jedis.keys("*");
Iterator<String> it=keys.iterator();
while(it.hasNext()){
String key = it.next();
System.out.println(key);
}
//判断key是否存在,存在则删除
if(jedis.exists("a")){
jedis.del("a");
System.out.println("key为a的值存在已删除");
}else{
System.out.println("key为a的值不存在");
}
//list,l对应左边队头,r对应右边队尾
System.out.println("============================================");
jedis.del("list1");
//lpush是在队列头部插入元素,rpush是在尾部插入元素
jedis.lpush("list1", "day1");
jedis.lpush("list1", "day2");
jedis.lpush("list1", "day3");
jedis.lpush("list1", "day4");
System.out.println("list:" + jedis.lrange("list1", 0, -1));
System.out.println("list长度为:" + jedis.llen("list1"));
List<String> list = jedis.lrange("list1", 0 ,-1);
for(int i=0; i<list.size();i++){
System.out.println("列表为:" + list.get(i));
}
//删除指定的值
jedis.lrem("list1", 2, "day2");
System.out.println("删除后:" + jedis.lrange("list1", 0, -1));
//lpop是在队列头部移除元素,rpop是在尾部移除元素
jedis.lpop("list1");
System.out.println("lpop队头移除元素后" + jedis.lrange("list1", 0, -1));
jedis.rpop("list1");
System.out.println("rpop从队尾移除元素后" + jedis.lrange("list1", 0, -1));
//set集合(无序)
System.out.println("============================================");
jedis.del("dayset");
jedis.sadd("dayset", "day1");
jedis.sadd("dayset", "day2");
jedis.sadd("dayset", "day3");
System.out.println("dayset无序集合中的全部元素" + jedis.smembers("dayset"));
Set<String> set = jedis.smembers("dayset");
Iterator<String> itset = set.iterator();
while(itset.hasNext()){
Object obj = itset.next();
System.out.println(obj);
}
//zset有序集合
System.out.println("============================================");
jedis.zadd("zsetday" , 3 , "day1");
jedis.zadd("zsetday" , 2 , "day2");
jedis.zadd("zsetday" , 1 , "day3");
System.out.println("有序集合中的所有元素为:" + jedis.zrange("zsetday", 0, -1));
System.out.println("有序集合中的元素个数为:" + jedis.zcard("zsetday"));
System.out.println("day3的权重为:" + jedis.zscore("zsetday", "day3"));
//hash
System.out.println("============================================");
jedis.hset("hashday", "day1", "111");
jedis.hset("hashday", "day2", "222");
jedis.hset("hashday", "day3", "333");
System.out.println("hash中所有的key为" + jedis.hkeys("hashday"));
System.out.println("hash中所有的value为:" + jedis.hvals("hashday"));
jedis.hdel("hashday", "day2");
System.out.println("删除day2后所有的value为:" + jedis.hvals("hashday"));
System.out.println("删除day2后key为day2是否存在:" + jedis.hexists("hashday", "day2"));
System.out.println("key为day3的value为:" + jedis.hget("hashday", "day3"));
}
}
输出
连接成功
服务正在运行: PONG
清空库中所有数据:OK
============================================
a的value为day1
追加后a的value为day1-day2
所有的redis-key为:
a
key为a的值存在已删除
============================================
list:[day4, day3, day2, day1]
list长度为:4
列表为:day4
列表为:day3
列表为:day2
列表为:day1
删除后:[day4, day3, day1]
lpop队头移除元素后[day3, day1]
rpop从队尾移除元素后[day3]
============================================
dayset无序集合中的全部元素[day2, day1, day3]
day2
day1
day3
============================================
有序集合中的所有元素为:[day3, day2, day1]
有序集合中的元素个数为:3
day3的权重为:1.0
============================================
hash中所有的key为[day2, day3, day1]
hash中所有的value为:[111, 222, 333]
删除day2后所有的value为:[111, 333]
删除day2后key为day2是否存在:false
key为day3的value为:333
redis环境搭建和java应用的更多相关文章
- Redis环境搭建和代码测试及与GIS结合的GEO数据类型预研
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 1.1传统MySQL+ Memcached架构遇到的问题 My ...
- redis环境搭建及一主二从三哨兵模式配置
一.单机redis环境搭建 1.安装: OS:linux redhat6.5 下载redis 官网下载链接:https://redis.io/download 把安装包上传到服务器,进行解压 [roo ...
- Redis环境搭建(Linux)
1.简介 redis是一个开源的key-value数据库.它又经常被认为是一个数据结构服务器.因为它的value不仅包括基本的string类型还有 list,set ,sorted set ...
- 一.redis 环境搭建
1.简介 redis是一个开源的key-value数据库.它又经常被认为是一个数据结构服务器.因为它的value不仅包括基本的string类型还有 list,set ,sorted set ...
- nginx + lua +redis环境搭建
环境搭建,其实主要是lua的环境,这个环境够麻烦的,在网上找了很多前辈的文章,终于完成了 ,安装redis wget http://download.redis.io/releases/redis-3 ...
- django+celery+redis环境搭建
初次尝试搭建django+celery+redis环境,记录下来,慢慢学习~ 1.安装apache 下载httpd-2.0.63.tar.gz,解压tar zxvf httpd-2.0.63.tar. ...
- Appium 1.6.4 环境搭建流程(Java, Android+IOS, Windows+Mac)
Appium1.6.4已经出来一段时间了,快速给大家串一下怎么搭建,贴了下载链接 1 基础环境: Windows + Mac: Java JDK 1.8+ (需配置环境变量),Appium1.6.4的 ...
- Redis环境搭建(MacOS)
Redis是一个开源的key-value类型的存储系统,大部分数据存在于内存中,所有读写速度十分快.其支持的存储value数据类型有多种,如:strings.hashes.lists.sets.sor ...
- Redis环境搭建
一.准备的安装包 windows虚拟机软件:VMware Workstation Pro 12 linux安装文件:CentOS-7-x86_64-Minimal-1511.iso 远程登录软件:pu ...
随机推荐
- LeetCode-Max Points on a Line[AC源码]
package com.lw.leet3; import java.util.HashMap; import java.util.Iterator; import java.util.Map; imp ...
- POJ3061 Subsequence 尺取or二分
Description A sequence of N positive integers (10 < N < 100 000), each of them less than or eq ...
- select表单元素详解及下拉列表模拟实现
原文地址:→看过来 写在前面 select 是HTML表单元素中很常用的一个,其中很重要的几个属性常被忽略,但这几个属性却能帮助我们完成很多的功能,当然,select下拉列表默认样式很不友好,所以更多 ...
- Qt undefined reference to ***
错因:某个类声明了一个函数但是没有定义就直接使用.
- Fast File System
不扯淡了,直接来写吧,一天一共要写三篇博客,还有两篇呢. 1. 这篇博客讲什么? Fast File System(FFS)快速文件系统,基本思想已经在在上一篇博客File System Implem ...
- [译]Quartz 框架 教程(中文版)2.2.x 之第二课 Quartz API,Jobs和Triggers简介
第二课:QuartzAPI,Jobs和Triggers简介 Quartz API Quartz API 关键的几个接口: Scheduler:跟任务调度相关的最主要的API接口. Job:你期望任务调 ...
- 云风pbc源码alloc.c
#include <stdlib.h> #include <stdio.h> // 用于统计内存的申请和释放次数匹配 ; void * _pbcM_malloc(size_t ...
- windos下创建软链接,附Linux下创建软链接
用过好多次老是忘记: 写在这里忘了就来看下 Windows下(win7) mklink /D D:\phpStudy\WWW\yii\school\teacher\web\uploads\public ...
- python操作YAML文件之pyyaml库
1. YAML简介 YAML是一种被认为可以超越XML.JSON的配置文件,最早接触是Spring Boot,木有想到python也是支持的,遂研究一下. python解析YAML库叫做pyyaml, ...
- 使用showplan.sql分析sql Performance
在HelloDBA网站找到一个分析sql性能的工具-showplan,记录一下 showplan.sql下载路径:http://www.HelloDBA.com/Download/showplan.z ...