欢迎光临散文网 会员登陆 & 注册

CentOs7 Redis6.0.6安装

2021-05-06 14:07 作者:汇智知了堂  | 我要投稿

1、什么是redis

redis是一种nosql数据库,他的数据是保存在内存中,同时redis可以定时把内存数据同步到磁盘,即可以将数据持久化,并且他比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合] hash(hash表))

2、为什么要使用redis

当我们做了一个项目,比方说个人博客,我们把这个项目发布到自己的服务器,一般来说,我们做的这个项目没有商用,访问量会很小,这个时候,我们不使用redis也可以,可以要访问量直接经过mysql,我们都知道,mysql是在磁盘上面,读取需要一点时间,访问量小的时候,这些时间我们可以忽略不及。 但是,当我们做了一个大型的商用项目,例如淘宝,那么访问量就会成几何数上升,特别是双十一的时候,并发量更是达到顶峰,这个时候,如果我们还是用mysql,那么大量的访问会让服务器处理速度非常的慢,甚至宕机,所以这个时候我们就要使用redis redis是在内存上面,我们知道内存读取数据非常的快,当大量的访问量余姚访问某一个数据的时候,我们把这个数据存放在redis里面,那么这样,我们的服务器就不会宕机。

3、CentOs7下安装Redis

3.1、安装wget下载工具

yum -y install wget

3.2、使用wget工具下载相应版本的Redis:download.redis.io/relea

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.gz mv redis-5.0.5 /usr/local/

进入Redis解压文件夹编译Redis源码(注意没有 gcc ,make以后会出错,make完自愿 make install 测试 如果都是install 就没问题)

cd /usr/local/redis-5.0.5/ make

  • 注意.redis.conf 配置文件默认在redis的根目录

  • 启动redis,进入redis的src目录 java ./redis-server ../redis.conf会 这时候涉及到后台启动 还是前台启动,也就是会不会出现redis 的经典logo,只需要在redis.conf配置文件中更改,这边建议修改redis.conf配置留到最后一起修改,我只是在这里给大家提议一下

# 修改配置文件可以改变改变启动方式 daemonize no\yes

查看Redis的进程信息

ps -ef | grep  redis

  • 如果启动了,会显示如下:

  • [root@localhost src# ps -ef |grep redis

  • root 58043 1 0 14:47 ? 00:00:00 ./redis-server *:6379

  • root 58080 9737 0 14:47 pts/0 00:00:00 grep —color=auto redis

4、进入redis

cd到redis的src目录执行如下操作 

# 本机可简写为 ./redis-cli 

上述情况 如果存入中文,中文回显会乱码 

./redis-cli --raw (这样就不会乱码)

5、Jedis介绍

Redis不仅是使用命令来操作,现在基本上主流的语言都有客户端支持,比如java,C.C#、C++.php. Node.js. Go 等。 在官方网站里列一些Java的客户端,有Jedis, Redisson、 Jredis、 JDBC-Redis、等其中官方推荐使用Jedis和 Redisson。在企业中用的最多的就是Jedis,下面我们就重点学习下Jedis。Jedis同样也是托管在github上,地址:github.com/xetorthio/je

==此时就需要开放我们CentOS系统的端口号!,重点,不开放6379端口 ping是通不了的 后台想去通过Jedis操作redis 链接不上==

6、CentOS开放端口

  • 1、运行命令:firewall-cmd --get-active-zones

  • 2、执行如下命令命令:firewall-cmd --zone=public --add-port=6379/tcp --permanent

  • 3、重启防火墙,运行命令:firewall-cmd --reload

  • 4、查看端口号是否开启,运行命令:firewall-cmd --query-port=6379/tcp 做完以上操作 就会把CentOS的防火墙打开6379的端口

7、Java连接Redis

导入jar包

  • jedis-2.9.0.jar

  • commons-pool2-2.6.2.jar 这里的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.jar public 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~~

记得点赞+关注哦!


CentOs7 Redis6.0.6安装的评论 (共 条)

分享到微博请遵守国家法律