Linux下安装Redis数据库,将Oracle表数据导入redis,并编写java测试程序连接redis

本文主要是介绍Linux下安装Redis数据库,将Oracle表数据导入redis,并编写java测试程序连接redis,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 安装及简单验证
  2. 修改防火墙配置文件,配置redis端口6379白名单
  3. 给redis设置口令,增加安全访问机制
  4. Redis 2.6的大数据插入
  5. 编写redis的java测试程序
  6. 常用命令
  7. 参考链接

安装包下载路径:https://redis.io/download

1. 安装及简单验证

1.1 解压安装包

tar zxvf redis-5.0.4.tar.gz

1.2 进入redis目录,执行make命令进行编译

cd redis-5.0.4
make

1.3 编译成功后,执行如下命令启动server端

./src/redis-server

1.4 克隆一个会话,执行如下命令启动client端

src/redis-cli

1.5 通过set命令设置一个key=foo,对应的value="bar",并通过get命令获取

set foo bar
get foo

2. 修改防火墙配置文件,配置redis端口6379白名单

sudo vi /etc/sysconfig/iptables
文件内容添加如下代码-A INPUT -p tcp -m state --state NEW -m tcp --dport 6379 -j ACCEPT
sudo service iptables restart
sudo service iptables save
sudo iptables -L -n

3. 给redis设置口令,增加安全访问机制

3.1 打开redis.conf配置文件,找到requirepass,然后修改口令为123456,将 bind 的IP改为0.0.0.0(此项配置是允许其他服务器访问到redis数据库)

vi redis.conf
修改内容如下:requirepass 123456bind 0.0.0.0

3.2 带配置文件方式启动服务

./src/redis-server redis.conf

3.3 使用口令登录客户端

./src/redis-cli -a 123456 

或者

./src/redis-cli 
127.0.0.1:6379> auth 123456

3.4 停止服务

./src/redis-cli -a 123456 shutdown

4. Redis 2.6的大数据插入

4.1 新的统一请求协议的通用格式如下:

"*3\r\n$3\r\nSET\r\n$5\r\nmykey\r\n$7\r\nmyvalue\r\n"*3表示有3个参数;$3表示第一个参数长度为3SET$5表示第二个参数长度为5mykey$7表示第三个参数长度为7myvalue

综上,可以看出,单独写入一条数据工作量还是不怎么多,但是如果是一张表的数据,工作量就很多,而且重复。
所以从Redis 2.6开始redis-cli支持一种新的被称之为pipe mode的新模式可用于执行大量数据插入工作。

4.2 示例:将Oracle数据库Scott用户下emp表的empno, ename, job三个字段的所有信息迁移存放至 Redis 。

4.2.1 Oracle数据准备:将下面sql执行结果保存至scott_emp.txt中。

SELECT '*4\r\n' ||'$' ||  LENGTH(redis_cmd) || '\r\n' ||redis_cmd || '\r\n'|| '$' ||  LENGTH(redis_key) ||  '\r\n' ||redis_key ||  '\r\n' ||'$' ||  LENGTH(hkey) ||  '\r\n' ||hkey ||  '\r\n'||'$' ||  LENGTH(hval) || '\r\n' ||hval ||  '\r\n'
FROM (SELECT'HSET' as redis_cmd,'emp' AS redis_key,empno AS hkey,empno || ':' || ename || ':'||job AS hvalFROM emp
);

4.2.2 迁移数据至Redis,执行如下命令将scott_emp.txt中的数据导入redis数据库中:

echo -e "$(cat scott_emp.txt)" | redis-5.0.4/src/redis-cli --pipe

4.2.3 登录客户端后,通过如下命令获取所有信息

hgetall emp

5. 编写redis的java测试程序

使用jar包:jedis-2.9.0.jar

public static void main(String[] args) {//连接本地的 Redis 服务Jedis jedis = new Jedis("192.168.246.130", 6379);jedis.auth("123456");System.out.println("连接成功");//查看服务是否运行System.out.println("服务正在运行: "+jedis.ping());System.out.println("redis 存储的字符串为: "+ jedis.get("foo"));System.out.println("redis 存储的字符串为: "+ jedis.hget("emp", "7369"));
}

6. 常用命令

ping             = 检测服务端状态,有链接返回字符串"PONG",反之报错。
keys *           = 查看所有key。
del emp          = 删除key = emp的数据。
hgetall emp      = 返回哈希表 key = emp 中所有的域和值。
type emp         = 查看key = emp 的类型(String, List, Hash, Set, zSet)
hget emp 7369    = 查看key = emp 中标志位7369的信息。
redis-server -v  = 查看redis版本
netstat -tnl     = 查看端口(Linux命令)

7. 参考链接

Redis 命令参考

Redis 教程

最后,谢谢各位读者的耐心阅读,如有语句不通顺或者不准确的地方,大家也可以提提改善的意见!(^__^)

这篇关于Linux下安装Redis数据库,将Oracle表数据导入redis,并编写java测试程序连接redis的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/527842

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例:

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB