Redis系列(一):Redis简介及环境安装
提到Redis,大家肯定都听过,并且应该都在项目中或多或少的使用过,也许你觉得Redis用起来挺简单的呀,但如果有人问你下面的几个问题(比如同事或者面试官),你能回答的上来吗?
- 什么是Redis?
- Redis能存储哪几种数据结构?
- Redis有几种持久化机制?它们的优缺点分别是什么?
- 哪些场景需要使用Redis?
- 什么是缓存雪崩,如何避免?
- 什么是缓存穿透,如何避免?
- 什么是缓存击穿,如何避免?
如果你都能回答的上来,恭喜你,说明你对Redis有一定的了解,如果回答不上来,也没关系,本系列博客会对Redis进行一系列的讲解,欢迎关注!
所谓工欲善其事,必先利其器,既然要学习Redis,首先我们至少得知道什么是Redis以及如何安装Redis环境,这也是本篇博客的主要内容。
1. Redis简介
什么是Redis呢?
Redis是一个开源(BSD许可)的内存数据结构存储,用作数据库、缓存和消息代理。它支持诸如字符串、散列、列表、集合、有序集合等数据结构。-- Redis官网
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的高性能的key-value数据库。-- 百度百科
Redis是一款依据BSD开源协议发行的高性能key-value存储系统,通常被称为数据结构服务器。-- 其它网友
Redis是一个远程内存数据库,它不仅性能强劲,而且还具有复制特性以及为解决问题而生的独一无二的数据模型。Redis提供了5种不同类型的数据结构,各式各样的问题都可以很自然地映射到这些数据结构上。 -- 《Redis实战》
Redis是一个速度非常快的非关系型数据库,它可以存储键(key)与5种不同类型值(value)之间的映射(mapping),可以将存储在内存的键值对数据持久化到硬盘,可以使用复制特性来扩展读性能,还可以使用客户端分片来扩展写性能。-- 《Redis实战》
2. Redis环境安装(Windows)
说明:Redis官方并没有提供Windows版本的Redis,也不建议在生产环境使用Windows版本的Redis,我目前所在的公司生产环境Redis是部署在Linux服务器的。
虽然Redis官方不支持Windows版本,但是微软Microsoft Open Tech Group提供了1个Windows版本的Redis,下载地址:https://github.com/microsoftarchive/redis/releases。

将下载好的文件解压到你喜欢的目录,我这里是E:\Tools\Redis-x64-3.0.504,如下所示:

双击上图中红色标记的redis-server.exe即可启动Redis服务:

也可以打开一个cmd窗口,切换到Redis所在目录,然后执行如下命令启动:
redis-server.exe redis.windows.conf

通过这2种方式打开,需要保证cmd窗口一直保持打开状态,关闭后客户端就无法连接,如果服务器重启了,需要再次打开Redis服务端,为了解决该问题,我们可以把Redis安装成Windows服务:
cd E:\Tools\Redis-x64-3.0.504
redis-server --service-install redis.windows.conf


你可以直接在界面上启动/停止该服务,也可以执行cmd命令来启动/停止/卸载该服务:
启动服务:
redis-server --service-start

停止服务:
redis-server --service-stop

卸载服务:
redis-server --service-uninstall

3. Redis环境安装(Linux)
首先,我们需要将Linux环境下Redis的安装包放到服务器上去,这里有2种方法,第1种方法是,打开Redis官网的下载地址:https://redis.io/download,下载稳定版本到本机:

然后通过工具,比如Xftp,将本地下载的文件上传至Linux服务器的某目录下,比如我这里要上传的目录是/mnt。
第2种方式是通过命令直接下载Redis的安装包到服务器的/mnt目录下,具体命令如下所示:
cd mnt/
wget -q http://download.redis.io/releases/redis-5.0.7.tar.gz



然后,执行如下命令解压文件:
tar -xzf redis-5.0.7.tar.gz


然后,执行如下命令将解压好的文件移动到/usr/local目录下,并进行编译:
mv redis-5.0.7 /usr/local/
cd /usr/local/redis-5.0.7
make

注意事项:执行完make命令后,屏幕会输出好多信息,大概有2~3屏的样子
当看到如下信息时,代表编译完成:

然后,切换到/usr/local/redis-5.0.7/src目录,执行make install命令进行安装:
cd src/
make install

然后,切换到/usr/local/redis-5.0.7目录,新建文件夹bin和etc,并将该目录下的redis.conf文件移动到etc目录,
将/usr/local/redis-5.0.7/src目录下的mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-server
移动到刚刚创建的bin目录:
cd ..
mkdir bin
mkdir etc
mv redis.conf etc/
cd src
mv mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-server /usr/local/redis-5.0.7/bin/

然后,切换到/usr/local/redis-5.0.7/etc目录,修改下Redis的配置文件redis.conf:
cd ..
cd etc/
vi redis.conf

redis.conf主要修改以下4点:
将daemonize no改为daemonize yes,表示需要在后台运行

将bind 127.0.0.1这一行注释掉
这里的bind指的是只有指定的网段才能远程访问这个redis,注释掉后,就没有这个限制了。

将protect-mode yes改为protect-mode no
默认是protect-mode yes,不能远程访问,改为no之后,可以远程访问

添加
requirepass 123456设置密码(默认密码为空)
最后,切换到/usr/local/redis-5.0.7/bin目录,执行如下命令启动Redis服务:
cd ..
cd bin/
redis-server /usr/local/redis-5.0.7/etc/redis.conf
启动后,可以执行如下命令查看Redis是否启动以及进程ID:
ps aux | grep redis-server

4. Redis Hello World示例
打开cmd窗口,打开一个redis-cli交互窗口来简单使用下Redis:
redis-cli.exe -h 127.0.0.1 -p 6379
设置一个key-value缓存,其中key为hello,value为hello world!:
set hello "hello world!"
获取key为hello的值:
get hello

5. Redis Desktop Manager使用
虽然我们可以通过命令的方式来查看Redis存储的数据,但毕竟不太友好,这里推荐个比较流行的工具:Redis Desktop Manager。
官网地址:https://redisdesktop.com/。
官网现在的版本2019.5需要付费才能使用,否则只有14天的试用期。

在2019年6份打开还是下面这样的,貌似涨价了啊,哈哈。

不过我们仍然可以下载之前不付费的版本,下载地址:https://github.com/uglide/RedisDesktopManager/releases/tag/0.8.8。

安装过程比较简单,这里不再赘述,安装完成后,连接本机Windows环境下的Redis服务器:

连接成功后,可以看到之前设置的值:

也可以连接远程Linux环境下的Redis服务器:



有些同学可能使用的工具是Another.Redis.Dsektop.Manager,这里只贴下下载地址:http://electronjs.org/apps/anotherredisdesktopmanager,有兴趣的同学可以自行下载。
6. 源码及参考
Redis系列(一):Redis简介及环境安装的更多相关文章
- Redis系列(一):Redis的简介与安装
原文链接(转载请注明出处):Redis系列(一):Redis的简介与安装 什么是 Redis Redis 是一个使用ANSI C 编写的开源.支持网络协议.基于内存.可选持久性的键值对数据库,它是一个 ...
- Redis系列一 Redis安装
Redis系列一 Redis安装 1.安装所使用的操作系统为Ubuntu16.04 Redis版本为3.2.9 软件一般下载存放目录为/opt,以下命令操作目录均为/opt root@ubunt ...
- Redis系列(二):Redis的数据类型及命令操作
原文链接(转载请注明出处):Redis系列(二):Redis的数据类型及命令操作 Redis 中常用命令 Redis 官方的文档是英文版的,当然网上也有大量的中文翻译版,例如:Redis 命令参考.这 ...
- Memcached简介及环境安装
Memcached简介及环境安装 author:SimpleWu 简介 Memcached是一个自由开源的,高性能,分布式内存对象缓存系统. Memcached是以LiveJournal旗下Danga ...
- scala语言简介及其环境安装
scala语言简介及其环境安装 简介: 1.运行在JVM 上,兼容java语言 Scala的代码,都需要经过编译为字节码,然后交由Java虚拟机来运行.所以Scala和Java是可以无缝互操作的.Sc ...
- Bootstrap:教程、简介、环境安装
ylbtech-Bootstrap:教程.简介.环境安装 1. Bootstrap 教程返回顶部 1. Bootstrap 教程 Bootstrap,来自 Twitter,是目前最受欢迎的前端框架.B ...
- python学习笔记1之-python简介及其环境安装
python学习笔记之-python简介及其环境安装 最近几年python之火不用多说,最近开始利用时间自学python,在学习的过程中,按照自己的思路和理解记录下学习的过程,并分享出来,如果正好你也 ...
- Redis实战(一)Redis简介及环境安装(Windows)
提到Redis,大家肯定都听过,并且应该都在项目中或多或少的使用过,也许你觉得Redis用起来挺简单的呀,但如果有人问你下面的几个问题(比如同事或者面试官),你能回答的上来吗? 什么是Redis? R ...
- redis系列之1----redis简介以及linux上的安装
redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...
随机推荐
- Java反射机制(二):通过反射取得类的结构
在反射运用过程中,如果你想得到一个类的完整结构,那么就要使用到java.lang.reflect包中的几个类: · Constructor 表示类中的构造方法 · Field 表示类中的属性 · ...
- 从规则引擎到复杂事件处理(CEP)
Drools Fusion既是规则引擎,又可以作为CEP.除了事件定义和时间推理之外,对于引擎本身也会有一些不同的使用.主要体现在会话时钟.流模式.滑动窗口和对事件的内存管理. 会话时钟 由于事件的时 ...
- [转]SpringBoot整合Swagger2以及生产环境的安全问题处理
1.创建springboot项目 https://www.cnblogs.com/i-tao/p/8878562.html 这里我们使用多环境配置: application-dev.yml(开发环境) ...
- sorted排序算法
- Linux创建用户、设置密码、修改用户、删除用户命令
与大家分享下Linux系统中创建用户.设置密码.修改用户.删除用户的命令,希望对你有所帮助. useradd testuser 创建用户testuserpasswd testuser 给已创建的用 ...
- fatal: Not a git repository (or any of the parent directories)
当从github.com上面下载下了Firmware后,无意中删除了Firmware目录下的.git文件夹,再去编译就会出现: fatal: Not a git repository (or an ...
- linux 原子变量
有时, 一个共享资源是一个简单的整数值. 假设你的驱动维护一个共享变量 n_op, 它告 知有多少设备操作目前未完成. 正常地, 即便一个简单的操作例如: n_op++; 可能需要加锁. 某些处理器可 ...
- Linux 内核中的数据类型
在我们进入更高级主题之前, 我们需要停下来快速关注一下可移植性问题. 现代版本的 Linux 内核是 高度可移植的, 它正运行在很多不同体系上. 由于 Linux 内核的多平台特性, 打算做认真使用的 ...
- SpringBoot使用Junit测试 防止事物自动回滚
问题:我在测试类中的save方法测试成功通过,但数据库没有插入数据 测试方法如下: @Test @Transactional // @Rollback(false) public voi ...
- 装饰器&偏函数与作用域与异常处理与文件读写
装饰器 概念:是一个闭包,把一个函数当做参数返回一个替代版的函数,本质上就是一个返回函数的函数 简单的装饰器 def func1(): print("sunck is a good man& ...