热门课程

免费试听

上课方式

开班时间

当前位置: 首页 -   文章 -   新闻动态 -   正文

CentOs7 Redis6.0.6安装

知了堂姐
2024-07-09 11:12:24
0

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: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.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上,地址:https://github.com/xetorthio/jedis

==此时就需要开放我们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~~

记得点赞+关注哦!

大家都在看

网络安全培训五个月能找到工作吗?

2024-07-09 浏览次数:0

转行学java怎么样?到底有没有前途

2024-07-09 浏览次数:0

技术干货:哔哩哔哩(B站)功能框架图

2024-07-09 浏览次数:0

学Java要学数据结构吗?数据结构的重要性总结

2024-07-09 浏览次数:0

防火墙的主要功能是什么?什么是防火墙?

2024-07-09 浏览次数:0

11月就业喜报 | 平均薪资8k+,最高薪资12...

2024-07-09 浏览次数:0
最新资讯
redis主从复制原理是同步还...   redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Valu...
Redis常用命令有哪些?Re...   Redis作为编程人员编程过程中常用的知识模块,redis的常用命令有哪些?Redis有哪几种数...
Redis是单线程吗?为什么单...   近乎所有与Java相关的面试都会问到缓存的问题,redis也是必问题,redis是单线程吗?为什...
redis哨兵机制及其作用是什... Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Va...
redis集群模式和哨兵模式区... redis有三种集群方式:主从复制,哨兵模式和集群,今天和知了小姐姐一起来看看redis集群模式和哨...
Java redis哨兵模式功... 在Java众多知识栈中,有一个知识点叫redis 哨兵模式,那么大家知道哨兵模式它有什么功能吗?其系...
干货来袭!Java小白必看系列... 在大家学习Java过程中,需要掌握很多的知识点,那么大家知道redis的主从复制是什么吗?Resdi...
redis是什么?redis和... 不知道面试Java工程师的人有没有遇到关于redis的相关问题?知道redis是什么吗?Redis和...