首页 > 其他 > 详细

redis远程连接

时间:2021-03-14 13:55:07      阅读:30      评论:0      收藏:0      [点我收藏+]

简单的连接方式

技术分享图片

 

 

步骤

一,更改配置文件     vim /etc/redis.conf

  1. 密码去掉注释,远程连接需要密码
  2. 把 bind 注释掉。

    对于Redis中bind的理解是:

    bind:是绑定本机的IP地址,(准确的是:本机的网卡对应的IP地址,每一个网卡都有一个IP地址),而不是redis允许来自其他计算机的IP地址。

    如果指定了bind,则说明只允许来自指定网卡的Redis请求。如果没有指定,就说明可以接受来自任意一个网卡的Redis请求。

    举个例子:如果redis服务器(本机)上有两个网卡,每一个网卡对应一个IP地址,例如IP1和IP2。(注意这个IP1和IP2都是本机的IP地址)。

    我们的配置文件:bind IP1。  只有我们通过IP1来访问redis服务器,才允许连接Redis服务器,如果我们通过IP2来访问Redis服务器,就会连不上Redis。

技术分享图片技术分享图片

 

 二,添加依赖包 这里我们使用

jedis
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>3.2.0</version>
        </dependency>
public static void main(String[] args) {
        Jedis jedis = new Jedis("39.97.241.18");
       // jedis.auth("foobared");
        System.out.println(jedis.ping());
    }

三,连接问题

创建对象时报错

技术分享图片

 

  1.  可能端口安全组没开,我们开一下。

技术分享图片

 

 

  1. 或则使用firewalld开启一下6379的端口

  firewall-cmd --add-port=6379/tcp --permanent

密码认证错误

技术分享图片

 

 看下配置文件的密码,传递密码试试

技术分享图片

 

 看一个完整的Deno

package demo;

import redis.clients.jedis.Jedis;

/**
 * @author Liruilong
 * @Date 2020/9/5 17:56
 * @Description: 函数接口,
 * 传递一个Redis对象,类似于 Runnable -> Thread
 * 类似策略模式,CallWithJedis可以看着为策略模板,
 */
@FunctionalInterface
public interface CallWithJedis {
    void call(Jedis jedis);

}
package demo;

import org.apache.commons.pool2.impl.GenericObjectPoolConfig;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

import java.util.Objects;

/**
 * @author Liruilong
 * @Date 2020/9/5 17:49
 * @Description: 线程安全的Redis池(单例)
 */

/**
 * @author Liruilong
 * @Date 2021/3/14 17:49
 * @Description: 线程安全的Redis池(单例)
 */
public final class Redis {
    private  volatile JedisPool pool;
    private static   volatile Redis redis = null;
    private  Redis() {
        GenericObjectPoolConfig config = new GenericObjectPoolConfig();
        //连接池最大空闲数
        config.setMaxIdle(300);
        //最大连接数
        config.setMaxTotal(1000);
        //连接等待时间,-1 表示没限制
        config.setMaxWaitMillis(30000);
        //空闲时检查有效性
        config.setTestOnBorrow(true);
        // 地址,端口,超时时间,密码
        this.pool = new JedisPool(config,"39.97.241.18",6379,30000,"foobared");
    }
    public void execute(CallWithJedis callWithJedis){
        try (Jedis jedis = pool.getResource()){
            callWithJedis.call(jedis);
        }
    }

    public static Redis builder() {
        if (Objects.isNull(redis)) {
            synchronized (Redis.class) {
                if (Objects.isNull(redis)) {
                    return new Redis();
                }
            }
        }
         return  redis;
    }
    
}

 

redis远程连接

原文:https://www.cnblogs.com/liruilong/p/14531885.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!