java学习---Redis安装使用

Posted 易小顺

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java学习---Redis安装使用相关的知识,希望对你有一定的参考价值。

Redis

1、介绍

 1.1、什么是 Redis

  全称:REmote DIctionary Server(远程字典服务器)。是完全开源免费的,用C语言编写的, 遵守BCD协议的一款非关系型数据库。是一个高性能的键值分布式内存数据库,基于内存运行并支持持久化的 NoSQL 数据库,是当前最热门的 NoSql 数据库之一,被人们称为数据结构服务器。

特点:

  • Redis支持 数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
  • Redis不仅仅支持简单的键值类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储,但都是键值方式存储的。
  • Redis支持 数据的备份,即master-slave(主从)模式的数据备份,主机挂掉之后哨兵自动将从机提升。

 1.2、Redis优势

性能极高:Redis能读的速度是110000次/s,写的速度是81000次/s 。

丰富的数据类型:Redis支持多种数据类型操作。

原子:Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行(事务队列)。

丰富的特性:Redis还支持订阅(一发多听), key 过期等等特性。

无锁竞争:采用单线程,避免了不必要的上下文切换和竞争条件。

NIO:使用多路 I/O 复用模型,非阻塞IO。

 1.3、Redis的应用场景

 Redis主要应用在 缓存场景 中,有较高的读取效率。还可以使用在 任务队列数据失效分布式锁 等方面,具体的使用方法还是得看业务场景,也不是都得用缓存来解决,其他的方法也不差。

2、安装

 2.1、环境准备

Redis 是用C语言进行编写的,因此需要有 gcc 的编译环境,直接用 gcc – version 指令,如果失败就没有环境。需要手动的安装一下环境,执行指令即可,遇见选择时直接输入 y ,等待安装完毕。

 yum install gcc-c++

 2.2、上传文件

 将下载好的 Redis 压缩包上传到环境中,Redis 可在下面地址中进行下载。上传目录没有要求,放在平常自己使用的安装目录下即可。

Http://redis.io/ 英文地址

Http://www.redis.cn/ 中文地址

 2.3、编译安装

首先 将压缩包进行解压到当前目录下。

tar -zxvf redis-5.0.5.tar.gz

然后 进入到 Redis 的文件目录下进行编译,如果编译不成功就删掉按照步骤再来一次。

cd redis-5.0.5
make

最后 进行安装,还是在当前 Redis 的目录下进行操作,就是将刚才编译完成的可执行文件安装在系统环境中,安装目录可以随便定义,放在正常的安装目录下即可。

make PREFIX=/home/admin/app/redis install

 2.4、安装配置

 进入到刚才安装的目录下,然后进入下面的 bin 目录下,里面存放了 Redis 的 服务器、客户端 等工具。

可执行文件功能
redis-benchmark性能测试工具
redis-check-aofAOF 文件修复工具(持久化文件)
redis-check-dumpRDB 文件检查工具(持久化文件)
redis-cli客户端启动工具
redis-server服务端启动工具

 将解压目录下的 redis-conf 文件复制到安装目录下,用于启动时的配置加载(注意切换目录),然后就可以把压缩包和解压文件给删掉了,留着碍事还占空间。

cp redis.conf /home/admin/app/redis

3、启动访问

 3.1、前端模式启动

 直接执行 redis-server 文件将使用前端模型进行启动,但是启动之后将不能在当前的界面上再进行其余的操作,必须结束后(ctrl + c)才能切换其他命令操作,这种方法启动没啥鸟用。

./redis-server

 3.2、后端模式启动

首先 需要修改配置文件的信息,打开刚才复制的配置文件,找到 daemonizeno 改为 yes,通过守护进程的方式进行启动,换句话说就是后台进程方式。

vim redis-conf

然后 启动服务并在后面添加上配置文件的地址。

./bin/redis-server ./redis-conf

 这时候查看进程就可以发现 Redis 已经在后台运行了,默认访问端口是 6379

ps -ef | grep redis

 3.3、客户端连接

 直接运行客户端连接工具就可以出现类似 mysql 命令行的一个界面工具,表现为 host:port > 这样的形式。

 也可以通过指定主机端口的形式进行连接。

./redis-cli -h host -p port

 对于大多数的人来说还是比较倾向于使用界面化的操作工具来进行数据的操作和查看,工具可以使用的很多,RedisDesktopManager 软件就可以很好的查看数据库中的数据信息。只需要输入相应的主机地址和端口就可以连接访问进行操作了,如果配置了密码还需要进行密码的输入验证。软件可以连接多个数据库信息,也可以全部显示当前数据库下的所有库信息,默认的是 16 个空间。

 3.4、服务端关闭

  • 可以直接将进程进行杀掉,但是这样可能会导致持久化文件的丢失。
kill -9 pid
  • 在客户端连接的时候发送 shutdown 指令正常关闭
127.0.0.1:6379> shutdowm
  • 但是在使用的时候可能会出现不让你关闭的 异常,那个错误说的是没有配置相应的日志文件进行记录,如果出现这种情况的话就需要直接将进程给杀掉,然后重新修改配置文件。找到 logfile 这个位置,在后面添加对应得日志文件得地址即可,文件要先存在。
logfile  "/home/admin/app/redis/redis.log"
  • 配置完成之后重新启动服务端工具,通过客户端连接之后就可以正常的结束进程了。

 3.5、服务器安装

 如果使用服务器进行安装的话,直接通过宝塔安装就行,配置文件这些都已经配置好了,但是需要注意的是尽量把端口号改掉,而且要添加访问密钥,不然很快就被植入挖矿了,然后服务器宕机重启。

requirepass 123456

 设置完成之后连接进行操作的时候会提输入密钥,输入完就可以正常进行操作。

auth 123456

就行,配置文件这些都已经配置好了,但是需要注意的是尽量把端口号改掉,而且要添加访问密钥,不然很快就被植入挖矿了,然后服务器宕机重启。

requirepass 123456

 设置完成之后连接进行操作的时候会提输入密钥,输入完就可以正常进行操作。

auth 123456

以上是关于java学习---Redis安装使用的主要内容,如果未能解决你的问题,请参考以下文章

java操作redis学习:安装及连接

Java使用Redis学习笔记

java分页查询,附学习笔记+面试整理+进阶书籍

redis在Java开发中的连接使用

Redis的Java使用入门

Redis系列--6Redis Java连接操作