本文共 4059 字,大约阅读时间需要 13 分钟。
redis是一种nosql数据库,它的数据是保存在内存中,同时redis可以定时把内存数据同步到磁盘,即可以将数据持久化,并且它比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合] hash(hash表))
当我们做了一个项目,比方说个人博客,我们把这个项目发布到自己的服务器,一般来说,我们做的这个项目没有商用,访问量会很小,这个时候,我们不使用redis也可以,可以要访问量直接经过mysql,我们都知道,mysql是在磁盘上面,读取需要一点时间,访问量小的时候,这些时间我们可以忽略不及。 但是,当我们做了一个大型的商用项目,例如淘宝,那么访问量就会成几何数上升,特别是双十一的时候,并发量更是达到顶峰,这个时候,如果我们还是用mysql,那么大量的访问会让服务器处理速度非常的慢,甚至宕机,所以这个时候我们就要使用redis redis是在内存上面,我们知道内存读取数据非常的快,当大量的访问量余姚访问某一个数据的时候,我们把这个数据存放在redis里面,那么这样,我们的服务器就不会宕机。
3.1、安装wget下载工具
yum -y install wget
3.2、使用wget工具下载相应版本的Redis:http://download.redis.io/releases/
wget http://download.redis.io/releases/redis-5.0.5.tar.gz
3.3、这里也可以用下好的redis压缩包
yum install gcc-c++
解压下载的Redis软件,并移动到/use/local下
tar -zxvf redis-5.0.5.tar.gzmv redis-5.0.5 /usr/local/
进入Redis解压文件夹编译Redis源码(注意没有 gcc ,make以后会出错,make完自愿 make install 测试 如果都是install 就没问题)
cd /usr/local/redis-5.0.5/make
# 修改配置文件可以改变改变启动方式daemonize no\yes
查看Redis的进程信息
ps -ef | grep redis
cd到redis的src目录执行如下操作# 本机可简写为 ./redis-cli上述情况 如果存入中文,中文回显会乱码./redis-cli --raw (这样就不会乱码)
Redis不仅是使用命令来操作,现在基本上主流的语言都有客户端支持,比如java,C.C#、C++.php. Node.js. Go 等。 在官方网站里列一些Java的客户端,有Jedis, Redisson、 Jredis、 JDBC-Redis、等其中官方推荐使用Jedis和 Redisson。在企业中用得最多的就是Jedis,下面我们就重点学习下Jedis。Jedis同样也是托管在github上,地址:https://github.com/xetorthio/jedis
==此时就需要开放我们CentOS系统的端口号!,重点,不开放6379端口 ping是通不了的 后台想去通过Jedis操作redis 链接不上==
导入jar包
java连接测试
public class Testredis { public static void main(String[] args) { //建立连接 Jedis jedis = new Jedis("ip地址",6379); System.out.println(jedis.ping()); //关闭资源 jedis.close(); }}
单实例连接
//这里使用 的是jedis-2.9.0.jarpublic class TestRedis { public static void main(String[] args) { //建立连接 Jedis jedis = new Jedis("ip地址",6379); //获取数据 String test = jedis.get("test"); System.out.println("test = " + test); //设置属性 jedis.set("test","hi,这是第一次设置的key值"); //获取数据 test = jedis.get("test"); System.out.println("test = " + test); //关闭资源 jedis.close(); }}
连接池连接
public class TestRedis01 { public static void main(String[] args) { //1 获得连接池配置对象,设置配置项 JedisPoolConfig config = new JedisPoolConfig(); // 1.1 最大连接数 config.setMaxTotal(30); //1.2 最大空闲连接数 config.setMaxIdle(10); //获得连接池 JedisPool jedisPool = new JedisPool(config,"ip地址",6379); Jedis jedis=null; //3.获得核心对象 jedis = jedisPool.getResource(); //4.设置数据 jedis.set("name","这是连接池设置的key值"); //5.获得数据 String name = jedis.get("name"); System.out.println("name = " + name); //6.关闭资源 jedis.close(); }}
测试连接
安装可能会遇到的坑
如果是启动失败,检查下redis的conf配置文件
因为redis默认bind 127.0.0.1,所以你会理所当然地想到去redis的配置文件redis.conf将“bind127.0.0.1”注释掉。认为这样就可以顺利访问了,其实还真不能解决,我们仍然会得到异常,异常的信息给我们提示了很多方法,其中有一个方法就是让我们将protected mode关闭掉。原来是redis默认开启了protected mode,保证只有主机才能访问到。
所以正确解决jedis conneciton refused的解决方案如下:
首先关掉redis-server,打开redis的配置文件redis.conf,将bind 127.0.0.1注释掉。 这里别注释错了 因为配置文件往下翻的时候会有个已经注释了的bind 127.0.0.1,不要理,继续往下翻就会出现正主,果断注释掉。 找到配置文件中protected-mode,默认protected mode yes,需要将其改为protected mode no 此时在重新启动redis。用在运行java文件 就会发现 可以获取到redis的key了。
这里如果redis那边正确的配置了,那么打印的System.out.println(jedis.ping());会打印PONG也就代表没问题了,之所以写这些 并不是安装redis会有问题,而是配置redis出问题会导致 java链接不上redis,网上很多教程是都不是使用的默认的防火墙,这里我使用的是默认的防火墙添加6379端口。
end~~
记得点赞+关注哦!
转载地址:http://hrlsz.baihongyu.com/