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

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队