Redis开发 - 1. 认识redis-阿里云开发者社区

开发者社区> master_haku> 正文

Redis开发 - 1. 认识redis

简介: 1. 什么是Redis? Redis is a very fast non-relational database that stores a mapping of keys to five different types of values. (Redis是一种速度非常快的非关系型数据库,NoSql的一种,它存储着以键值对为形式的数据,值的类型5种。
+关注继续查看

1. 什么是Redis?

Redis is a very fast non-relational database that stores a mapping of keys to five different types of values.

(Redis是一种速度非常快的非关系型数据库,NoSql的一种,它存储着以键值对为形式的数据,值的类型5种。)

Redis是Remote Dictionary Server(远程字典服务器)的缩写。 

 

Redis supports in-memory persistent storage on disk, replication to scale read performance, and client-side sharding to scale write performance. 

(Redis支持内存持久化到磁盘,以复制的形式来扩展读取的性能,以客户端碎片化(client-side sharding)的方式来扩展写的性能。)

 

Sharding is a method by which you partition your data into different pieces.

In this case, you partition your data based on IDs embedded in the keys, based on the hash of keys, or some combination of the two.

Through partitioning your data, you can store and fetch the data from multiple machines, which can allow a linear scaling in performance for certain problem domains. 

(碎片化是一项技术,这项技术将你的数据分割成不同的部分。

这样一来,每个数据碎片将以ID作为它的键,根据哈希码的形式,这样就能把你的数据存储在不同的机器,然后以线性的方式对性能进行扩展。)

 

2. Redis支持的数据类型

字符串(String)

列表(List)

集合(Set)

散列(Hash)

有序集合(ZSet)

 

3. 存储形式

Redis数据库中所有数据都存储在内存中。

优势:由于内存的读写速度远快于硬盘,所以Redis在性能上比其他基于硬盘存储的数据库有明显优势。

eg:

在一台普通的PC上Redis可以每秒读写10万+个键值。

缺点:由于数据存储在内存中,程序退出后内存中的数据会丢失。

为了弥补这一缺点,Redis提供了持久化功能,用于将内存中的数据通过异步的方式写入到硬盘。

由于是异步的,因此不会影响其继续提供其他服务。

 

4. 应用场景

很多情况下,Redis被应用于缓存队列系统等。

当应用于缓存的场景,Redis为每个键值设置生存时间(TTL - Time to Live),生存时间到期后该键值

会自动被删除。

 

5. 安装Redis

Redis兼容大部分POSIX系统(Linux, OS X, BSD)

下载地址:

http://download.redis.io/

1) Linux下安装

首先下载安装包

tar xzf redis-stable.tar.gz

cd redis-stable

make (先编译源代码)

make test (测试源代码是否编译成功)

make install (安装程序)

安装程序实际过程是将可执行程序复制到/usr/local/bin目录,这样以后执行程序的时候不用输入完整的路径。

 

2) OS X下安装

OS X下通过软件包管理工具Homevrew进行。

a. 安装Homebrew

进入终端:

ruby -e"$(curl -fsSKL raw.github.com/mxcl/homebrew/go)"

b. 通过Homebrew安装Redis

brew install redis

c. 配置launchd让Redis岁系统自动运行

终端下输入以下命令:

ln -sfv /usr/local/opt/redis/*.plist ~/Library/LaunchAgents

launchctl load ~/Library/LaunchAgents/homebrew.mxcl.redis.plist

 

6. 启动Redis

1) 直接启动

$ redis-server

启动后Redis服务器默认使用6379端口

也可以自定义启动端口,如下:

$ redis-server --port 8918

 

2) 通过初始化脚本启动Redis

在生产环境中,我们推荐用该方法启动Redis(为了稳定)

a. 首先,进入Redis源码目录的utils目录

b. 找到叫redis_init_script的初始化脚本文件

c. 将初始化脚本复制到/etc/init.d目录并且重命名为redis_端口号

    该端口号表示Redis将要监听的端口号

d. 修改脚本中REDISPORT变量的值为你设置的端口号

e. 建立需要的文件夹

    /etc/redis           这里存放Redis的配置文件

   /var/redis/端口号  这里存放Redis的持久化文件

f. 修改配置文件

   网上下载文件模板,将它复制到/etc/redis目录

   将该文件命名为端口号.conf

   然后按照如下信息对配置文件中的部分参数进行配置

   daemonize   yes                                       使Redis以守护进程的模式运行

   pidfile         /var/run/redis_端口号.pid         这是Redis的PID文件位置

   port           端口号                                    设置Redis监听的端口号

   dir             /var/redis/端口号                      设置持久化文件存放位置

g. 使用如下命令启动Redis

   /etc/init.d/redis_端口号 start

h. 使Redis随系统自动启动

   $ sudo update-rc.d redis_端口号 defaults

 

7. 停止Redis

$ redis-cli shutdown

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Redis开发与运维一书-勘误
Redis开发与一书勘误列表如下:https://cachecloud.github.io/2017/02/17/%E3%80%8ARedis%E5%BC%80%E5%8F%91%E4%B8%8E%E8%BF%90%E7%BB%B4%E3%80%8B%E5%8B%98%E8%AF%AF/ ...
1358 0
Redis在游戏开发中的典型应用
Redis作为目前最流行的键值对存储数据库,有着丰富的数据结构支持,在民生、金融、游戏、直播等诸多领域都有广泛的应用,大大提升了开发者的开发效率。今天我们主要介绍Redis在游戏开发中的几个典型应用场景:用户数据缓存、持久化功能的消息队列、乐观锁功能。
6031 0
怎么设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程
8478 0
一份完整的阿里云 Redis 开发规范,值得收藏!
一份完整的阿里云 Redis 开发规范,值得收藏!
23 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
12077 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
11819 0
Redis开发 - 1. 认识redis
1. 什么是Redis? Redis is a very fast non-relational database that stores a mapping of keys to five different types of values. (Redis是一种速度非常快的非关系型数据库,NoSql的一种,它存储着以键值对为形式的数据,值的类型5种。
634 0
Redis开发规范
1.冷热数据分离,不要将所有数据全部都放到Redis中 虽然Redis支持持久化,但是Redis的数据存储全部都是在内存中的,成本昂贵。建议根据业务只将高频热数据存储到Redis中【QPS大于5000】,对于低频冷数据可以使用MySQL/ElasticSearch/MongoDB等基于磁盘的存储方式,不仅节省内存成本,而且数据量小在操作时速度更快、效率更高! 2.不同的业务数据要分开存储 不要将不相关的业务数据都放到一个Redis实例中,建议新业务申请新的单独实例。
1511 0
+关注
master_haku
Master HaKu
502
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载