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 ...
随机推荐
- Debian9(8)下python3和python2同时安装如何使用pip
在bash下Python会调用python2.x python3会调用python3.x 如果使用pip install命令安装模块会安装python2的模块. 而python3的pip命令使用的是p ...
- 图论:DFS序
DFS序可以把树转到区间上再用高级数据结构维护,比树链剖分好理解很多 一个闭区间就是一棵子树 POJ3321 #include<cstdio> ; ; int n,m,id,cnt; in ...
- Spark 基本架构及原理
转载自: http://blog.csdn.net/swing2008/article/details/60869183 转自:http://www.cnblogs.com/tgzhu/p/58183 ...
- Netty 入门初体验
Netty简介 Netty是一款异步的事件驱动的网络应用程序框架,支持快速开发可维护的高性能的面向协议的服务器和客户端.Netty主要是对java 的 nio包进行的封装 为什么要使用 Netty 上 ...
- 使用vscode实现git同步
用了git最方便的就是项目同步管理,回到家打开vscode只需要点击一下pull就能全部同步过来.是不是很方便....毕竟之前我都是拿u盘拷贝回家或者存到云盘再下载下来.. 我这里之前用的是国内的 ...
- GCD HDU - 1695 莫比乌斯反演入门
题目链接:https://cn.vjudge.net/problem/HDU-1695#author=541607120101 感觉讲的很好的一个博客:https://www.cnblogs.com/ ...
- var_dump打印出来格式太乱 怎么调
var_dump()和print_r() 输出的都是文本格式,在浏览器中就是这样如果你加载了 xdebug 扩展,那么 var_dump() 就会以 html 格式输出
- redis基础之redis-sentinel(哨兵集群)(六)
前言 redis简单的主从复制在生产的环境下可能是不行的,因为从服务器只能读不能写,如果主服务器挂掉,那么整个缓存系统不能写入了:redis自带了sentinel(哨兵)机制可以实现高可用. redi ...
- oracle命令生成AWR报告
--命令生成AWR报告oracle@linux:~> sqlplus / as sysdba SQL*Plus: Release 11.1.0.7.0 - Production on Fri A ...
- 在rhel7上搭建centos7的yum源
1. 再查看现在主机上的yum源,并将它们删除 [root@localhost ~]# rpm -qa|grep yum | xargs rpm -e --nodeps # --nodeps 不管有没 ...