CentOS 7 中的Redis的安装 配置 以及 JAVA连接测试

Linux下安装Redis

  1. 安装wget下载工具
yum -y install wget
  1. 使用wget工具下载相应版本的Redis:http://download.redis.io/releases/ 网址
   	 wget http://download.redis.io/releases/redis-5.0.5.tar.gz
 这里也可以用下好的redis压缩

通过第三方工具拉进系统 再去解压,我使用的FinalShell

  1. 检查是否有编译环境(更新或安装)
yum install gcc-c++
  1. 解压下载的Redis软件,并移动到/use/local下
tar -zxvf redis-5.0.5.tar.gz
mv redis-5.0.5 /usr/local/
  1. 进入Redis解压文件夹编译Redis源码(注意没有 gcc ,make以后会出错,make完自愿 make install 测试如果都是install 就没问题)
cd /usr/local/redis-5.0.5/
make
  1. 注意.redis.conf 配置文件默认在redis的根目录, 启动redis,进入redis的src目录
    java ./redis-server …/redis.conf会
    这时候涉及到后台启动 还是前台启动,也就是会不会出现redis 的经典logo,只需要在redis.conf配置文件中更改,这边建议修改redis.conf配置留到最后一起修改,我只是在这里给大家提议一下
# 修改配置文件可以改变改变启动方式
daemonize no\yes
  1. 查看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

进入redis

cd到redis的src目录执行如下操作
# 本机可简写为 ./redis-cli
上述情况 如果存入中文,中文回显会乱码
./redis-cli --raw (这样就不会乱码)

防火墙端口


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的端口

Java连接Redis

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包

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默认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端口。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LC超人在良家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值