当前位置:网站首页>Redis数据库—定义、特点、安装、如何启动与停止
Redis数据库—定义、特点、安装、如何启动与停止
2022-08-04 18:44:00 【别掉头发啦】
redis定义
Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。 [1]
Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。
redis的官网地址,非常好记,是redis.io。(域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地),Vmware在资助着redis项目的开发和维护。
redis官网地址
Redis特点
高级数据结构:为值提供五种可能的数据类型:字符串,列表,集合,哈希和有序集合。提供了这些数据类型独有的操作,并且具有记录良好的时间复杂度(Big O表示法)。
高性能:由于其内存特性,项目维护者将复杂性保持在最低限度的承诺以及基于事件的编程模型,Redis 在读写操作方面具有出色的性能。
没有依赖关系的轻量级:用ANSI C编写,没有外部依赖关系。适用于所有POSIX环境。Windows不受官方支持,但Microsoft提供了实验性版本。
高可用性: 内置支持异步,非阻塞,主/从复制,以确保数据的高可用性。目前有一种名为Redis Sentinel的高可用性解决方案目前可以使用,但仍被视为正在进行的工作。
Redis与Memcached的相似之处:
● Redis和Memcached都是内存数据存储系统,都用作内存中的键值数据存储。
● Redis和Memcached都属于NoSQL系列数据管理解决方案,两者都基于键值数据模型。
● Redis和Memcached都将所有数据保存在RAM中,这当然使它们作为缓存层非常有用。
Redis与Memcached的区别:
1、类型
Redis是一个开源的内存数据结构存储系统,用作数据库,缓存和消息代理。
Memcached是一个免费的开源高性能分布式内存对象缓存系统,它通过减少数据库负载来加速动态Web应用程序。
2、数据结构
Redis支持字符串,散列,列表,集合,有序集,位图,超级日志和空间索引;而Memcached支持字符串和整数。
3、执行速度
Memcached的读写速度高于Redis。
4、复制
Memcached不支持复制。而,Redis支持主从复制,允许从属Redis服务器成为主服务器的精确副本;来自任何Redis服务器的数据都可以复制到任意数量的从属服务器。
5、密钥长度
Redis的密钥长度最大为2GB,而Memcached的密钥长度最大为250字节。
6、线程
Redis是单线程的;而Memcached是多线程的。
Redis安装
源码安装(推荐)
首先,安装源码编译支持库yum install gcc gcc-c++
下载包:wget https://download.redis.io/releases/redis-6.2.3.tar.gz
解压包:tar xzf redis-6.2.3.tar.gz
解决make test需要tcl8.5以上版本支持
下载包:wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz
指定路径解压:tar xzvf tcl8.6.1-src.tar.gz -C /usr/local/
[[email protected] ~]# cd /usr/local/tcl8.6.1/unix/
[[email protected] unix]# ./configure
[[email protected] unix]# make
[[email protected] unix]# make install
然后cd到~目录下,再进入redis-6.2.3目录下,
[[email protected] unix]# cd
[[email protected] ~]# cd redis-6.2.3
进行编译安装:
[[email protected] redis-6.2.3]# make
编译测试:
[[email protected] redis-6.2.3]# make test
安装成功:
注意: 如果没有安装tcl8.5以上版本就进行安装redis,会报如下错:
如果编译过程中报错缺少某个依赖包,安装好后需要清除之前的编译安装,然后编译安装历史清除:make distclean
启动redis
前台启动与停止
不指定配置文件启动
启动有红色框中的警告,则输入:
echo 1024 > /proc/sys/net/core/somaxconn
vim /etc/sysctl.conf (输入下图中内容)
指定配置文件启动
前端启动Redis后,终端将进入Redis控制台,没办法继续别的Linux命令,即这个终端窗口就”废了”,只能输入Redis自己的命令。
redis.conf 是一个默认的配置文件。我们可以根据需要使用自己的配置文件。
启动 redis 服务进程后,就可以使用测试客户端程序 redis-cli 和 redis 服务交互了。 如下:
前端启动的关闭命令
强制关闭:Ctrl+c
正常关闭:./redis-cli shutdown
•强制关闭只需在Redis控制台直接执行即可(redis可能会丢失部分数据)。
•正常关闭需要另开一个终端窗口才可执行(redis不会丢失数据,推荐使用)。
一旦前端启动的关闭命令执行,则redis控制台关闭,redis服务也会停掉。
后台启动与停止
后端启动是我们开发中绝对会用到的方式,但在使用后端启动命令之后,需要做一些配置。如下:
后端启动的配置
修改redis.conf文件,将daemonize的值改为yes
[[email protected] redis-6.2.3]# vim redis.conf
后端启动命令
在启动完redis后台,终端不会进入redis控制台,这就是将redis运行后台了。
后端启动的关闭命令
强制关闭:kill -9 进程id 或 pkill redis
正常关闭:src/redis-cli shutdown
注意:项目中,建议使用正常关闭。因为redis作为缓存来使用的话,将数据存储到内存中,如果使用正常关闭,则会将内存数据持久化到本地之后,再关闭。如果强制关闭,则不会进行持久化操作,可能会造成部分数据丢失。
边栏推荐
- ATF中断处理的设计模型
- Those things about the curl command
- Route lazy loading
- 如何给MySQL添加自定义语法 ?
- EasyCVR如何通过接口调用设备录像的倍速回放?
- 阿里云国际版使用ROS搭建WordPress教程
- 【填空题】130道面试填空题
- EasyCVR calls the cloud recording API and returns an error and no recording file is generated. What is the reason?
- Babbitt | Metaverse daily must-read: Weibo animation will recruit all kinds of virtual idols around the world and provide support for them...
- 面试官:MVCC是如何实现的?
猜你喜欢
随机推荐
Kubernetes入门到精通- Operator 模式入门
EasyCVR本地接入国标设备映射公网后,本地设备出现无法播放与级联的解决方法
袋鼠云思枢:数驹DTengine,助力企业构建高效的流批一体数据湖计算平台
【简答题】月薪4k和月薪8k的区别就在这里
机器学习——线性回归
方法的重写
当前最快的实例分割模型:YOLACT 和 YOLACT++
The CPU suddenly soars and the system responds slowly, what is the cause?Is there any way to check?
基于 eBPF 的 Kubernetes 可观测实践
The Industrial Metaverse Brings Changes to Industry
【AI+医疗】斯坦福大学最新博士论文《深度学习在医学影像理解中的应用》,205页pdf
Day018 Inheritance
DHCP&OSPF combined experimental demonstration (Huawei routing and switching equipment configuration)
win10 uwp json
Scala104-Spark.sql的内置日期时间函数
GBase8s存储过程
ECCV 2022 | FPN错位对齐,实现高效半监督目标检测(PseCo)
浅谈web网站架构演变过程
margin 塌陷和重合的理解
Homework 8.3 Thread Synchronization Mutex Condition Variables