前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Redis】Redis开篇与如何安装单机版Redis,这次我会了!!

【Redis】Redis开篇与如何安装单机版Redis,这次我会了!!

作者头像
冰河
发布2020-10-29 10:34:50
4640
发布2020-10-29 10:34:50
举报
文章被收录于专栏:冰河技术

作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。自开源半年多以来,已成功为十几家中小型企业提供了精准定时调度方案,经受住了生产环境的考验。为使更多童鞋受益,现给出开源框架地址:

https://github.com/sunshinelyz/mykit-delay

PS: 欢迎各位Star源码,也可以pr你牛逼哄哄的代码。

写在前面

很早之前,就有不少小伙伴微信留言说:冰河,你能不能写一个Redis专栏啊,我最近在学习Redis,看书看不下去,学习视频又觉得视频太长了,还是看你的文章比较给力!哈哈,原来我写的文章能够让小伙伴们有这么强的动力学习啊!终于安排到写【Redis专题】了。今天是【Redis专题】的开篇,写些什么呢?先简单的介绍下Redis并教大家如何在单机环境中安装Redis吧,也算是对【Redis专题】的开篇吧! 如果文章对你有所帮助,请不要吝惜你的点赞、在看、留言和转发,你的支持是我持续创作的最大动力!

Redis介绍

学习一项新技术和一个新的框架之前,大部分的套路都是先对这项技术和框架做一个简单的介绍。这次,我也随波逐流一次吧,对Redis做一个整体的介绍。

基于键值对的存储系统:字典形式。

五种数据结构:字符串(String),Hash(字典),列表(List),集合(Set),有序集合(Sorted Set)。

Redis大部分时间用来做缓存,因为速度快(内存数据库,单线程,单进程,Redis 6.0支持多线程,后面我们会详细讲Redis 6.0的新特性 )。

Redis的使用场景

  • 做缓存:String类型最多,其次是hash(字典),value值使用的最多的是json格式。
  • 计数(自增):点赞数,点踩数,访问数,全局计数等。
  • 消息队列:列表类型,先进先出或者先进后出,bloop。这个可以参考我写的一个开源框架,地址为:https://github.com/sunshinelyz/mykit-delay。
  • 发布订阅(观察者模式)
  • 排行榜:有序集合
  • 分布式锁:可以关注【冰河技术】微信公众号,参考我写的《【高并发】高并发分布式锁架构解密,不是所有的锁都是分布式锁!!》,也可以参考我写的一个分布式锁插件,链接地址为:https://github.com/sunshinelyz/mykit-lock。
  • 做附近的人
  • 布隆过滤器
  • 统计在线人数(Bitmap)等等

以下使用场景也是5大数据类型中的一种:

  • BitMaps位图:布隆过滤器 本质是字符串
  • HyperLogLog:超小内存唯一值计数,12kb HyperLogLog 本质是 字符串
  • GEO:地理信息定位 本质是有序集合

**主从复制:**主服务器和从服务器,Redis中的数据可以从主服务器同步到从服务器上。

高可用和分布式:

  • 2.8版本以后使用redis-sentinel支持高可用(做哨兵)
  • 3.0版本以后支持分布式

Redis的安装和启动

这里,我们在CentOS服务器上安装Redis 5.0.7版本。

1.下载安装Redis

代码语言:javascript
复制
#下载
wget http://download.redis.io/releases/redis-5.0.7.tar.gz
#解压
tar -zxvf redis-5.0.7.tar.gz
#建立软连接(生成一个redis文件夹)
ln -s redis-5.0.7 redis
cd redis
make && make install

我们可以在Redis的src目录下看到如下命令。这里,我也对命令的作用进行了简单的说明

代码语言:javascript
复制
#redis-server--->redis服务器
#redis-cli---》redis命令行客户端
#redis-benchmark---》redis性能测试工具
#redis-check-aof--->aof文件修复工具
#redis-check-dump---》rdb文件检查工具
#redis-sentinel---》sentinel服务器,哨兵

值得说明的是:Redis作者对windows维护不好,window自己有安装包。

2.三种启动Redis服务的方式

(1)最简启动法

Redis中最简单的启动方法就是在命令行中直接输入如下命令。

代码语言:javascript
复制
redis-server  #只要运行这一条命令服务端就启动了

启动效果如下图所示。

可以通过如下几种命令来查看Redis的运行情况。

代码语言:javascript
复制
ps -ef|grep redis  #查看进程
netstat -antpl|grep redis #查看端口
redis-cli -h ip -p port ping #命令查看

(2)动态参数启动法

这里,我们以动态增加Redis的启动端口为例,比如我们将Redis启动后监听的端口设置为6379,如下所示。

代码语言:javascript
复制
#动态参数启动
redis-serve --port 6379 #启动,监听6379端口    默认对应的端口号是6379

这里,我们在Redis启动时,设置了动态端口。当然,我们还可以在Redis启动时,设置其他的动态参数,在【Redis专题】后续的文章中,我们会详细说明Redis的动态参数。

3.配置文件启动法(最常用的启动方式)

Redis启动之后,可以通过redis-cli连接,在服务器命令行输入如下命令可以查询到默认的所有配置。

代码语言:javascript
复制
config get * 

配置文件中一些常用的配置参数如下所示。

代码语言:javascript
复制
daemonize --》是否是守护进程启动(no|yes)
port ---》端口号
bind ---》绑定的主机名或IP地址
logfile --》redis系统日志
dir --》redis工作目录
protected-mode --》是否允许外界访问

例如,我们创建一个redis-6379.conf配置文件,文件的内容如下所示。

代码语言:javascript
复制
daemonize yes      #是否以后台形式运行
port 6379          #绑定端口号
bind 0.0.0.0       #设置地址
protected-mode no    #设置允许外界访问
dir "/data/redis/data"        #工作目录
logfile "./redis-6379.log"    #日志位置

然后,我们可以在服务器的命令行使用如下命令指定Redis的配置文件来启动Redis服务。

代码语言:javascript
复制
redis-server redis-6379.conf

总结三种启动Redis的方式

这里,我们还是对Redis的三种启动方式做一个简单的总结:

  • 直接命令行:redis-server
  • 动态参数方式:redis-server --port 6379 #这里是添加端口参数
  • 配置文件方式:redis-server 启动配置文件名

3.客户端连接方式

(1)最简连接法

如果Redis服务器和Redis客户端在同一台服务器上,并且Redis服务器使用的是默认端口6379,则可以使用最简连接法。此时,只需要在服务器命令行输入如下命令即可。

代码语言:javascript
复制
redis-cli

(2)指定IP和端口连接

无论Redis服务器和Redis客户端是否在同一台服务器,也不管是否修改过Redis的端口号,都可以使用指定IP和端口的方式来连接Redis服务。这种方式可以使用类似如下命令的形式连接Redis服务端。

代码语言:javascript
复制
redis-cli -h 127.0.0.1 -p 6379    #加上ip地址或者端口号

(3)使用可视化工具连接Redis

除了上述使用redis-cli连接Redis的方式,还可以使用可视化工具来连接Redis。例如,我们可以使用RedisDesktopManager这个可视化工具来连接Redis。如下所示。

关闭后台Redis方法

当我们不需要Redis的时候,就可以关闭后台运行的Redis服务,我们可以通过如下命令来关闭后台运行的Redis服务。

(1)查看运行的Redis进程号

使用如下命令查看运行的Redis进程号。

代码语言:javascript
复制
ps -ef | grep redis-server | grep 6379

或者

代码语言:javascript
复制
ps -ef | grep redis-server

或者

代码语言:javascript
复制
ps -ef |grep redis

(2)杀掉查询到的进程号

代码语言:javascript
复制
kill Redis进程号

命令脚本化

当然,上述安装Redis、启动Redis、连接Redis和关闭Redis的命令都可以写成一个脚本文件,我们只需要运行脚本文件即可自动化安装Redis、启动Redis、连接Redis和关闭Redis。这里,如何编写脚本就留给小伙伴们自行思考吧,大家如果有什么问题可以在文末留言!!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-08-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 冰河技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 写在前面
  • Redis介绍
  • Redis的安装和启动
    • 1.下载安装Redis
      • 2.三种启动Redis服务的方式
        • 3.客户端连接方式
        • 关闭后台Redis方法
        • 命令脚本化
        相关产品与服务
        云数据库 Redis
        腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档