热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

即时通讯宝塔安装mongodb_Redis安装与使用

介绍Redis是可基于内存亦可持久化的Key-Value数据库(nosql数据库)NoSQL,泛指非关系型的数据库1.redisserver安装yuminstallr

ddb44a1ebf1a80fdaaa0ad13e640720d.png

介绍

Redis是可基于内存亦可持久化的Key-Value数据库(nosql数据库)
NoSQL,泛指非关系型的数据库

1. redis server 安装

yum install redis # 安装
systemctl enable redis # 设置开机启动
service redis start | stop | restart # 相关操作

2. redis server 安全配置

vim /etc/redis.conf

bind 127.0.0.1 注释掉
requirepass XXX密码 #初始为注释代码
protected-mode no # 初始为yes
daemonize yes # 如果为no,则改为yes
重启后生效,再操作就会要求登陆验证

3. 测试连接server

redis-cli -h 127.0.0.1 -p 6379
auth XXX密码

验证了密码后,就可以进行相关操作

4. 安装php redis扩展

我是用的宝塔:对应PHP版本-> 插件安装-> redis安装
使用宝塔安装方式,前3个步骤可省略,因为宝塔会自动安装其客户端软件。
目录在/www/server/redis,配置文件以及相关命令都在里面。

redis持久化前沿

AOF和RDB的区别

RDB:dump完整的db进行持久化,用save m n进行周期持久,性能消耗小,速度快,并且dump出的db可以转存到其它地方使用。
官方默认开启:save 900 1,save 300 10,save 60 10000,设置了这三项,分别代表900s 有1次更改操作则写入rdb
AOF:存储写日志的方式进行持久,appendfsync everysec:每秒同步一次,性能消耗大,安全系数高。

AOF和RDB如何取舍

对数据安全性要求比较高,可以两者同时使用。
要求不是那么高的话,可以只开RDB,因为RDB是备份数据库文件方式,所以方便我们进行备份工作。

开启持久化后,是否影响客户端读取性能?

两者的持久化方式都是异步方式(单独开启了一个守护进程),所以不会影响客户端的性能。

自动触发的场景

  1. save:根据我们的save m n / appendfsync everysec配置规则自动触发:save 900 1 (900s周期,如果有1条更改操作(新增或修改),则进行持久化)

  2. slave:节点之间全量复制时,主节点发送rdb文件给从节点完成复制操作,主节点会触发bgsave

  3. shutdown:执行shutdown时,如果没有开启aof,也会触发

持久化的方式

RDB:redis db

在指定的save m n周期性对数据进行持久化。

RDB的2种执行方式

save:会阻塞当前Redis服务器,直到持久化完成,线上应该禁止使用。
bgsave:另开启一条bgsave主进程异步守护redis数据变化情况,会触发会多个子fork进程进行持久化,fork子进程会阻塞bgsave主进程,影响redis的少许性能。

AOF:appendonly filelog

记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据。

1. AOF的2种执行方式

参考RDB方式。
appendfsync everysec:每秒同步一次,意味着有最多1秒的
他们在进行持久化的时候,都会生成2个文件(新文件/旧文件),保证在进行持久化过程中,有新的数据写入时,保持完整性,持久化完成后,新文件删除,继续用旧文件。

Redis数据类型

String(字符串)

  1. set:实例set / get。键为 name,对应的值为 wangkun。

  2. get:如上

redis 127.0.0.1:6379> set name "wangkun"
OK
redis 127.0.0.1:6379> get name
"wangkun"

Hash(哈希)

  1. hmset:实例中 hmset 设置了两个 field=>value 对

  2. hget:获取对应 field 对应的 value

redis> hmset myhash field1 "Wk" field2 "Wx"
"OK"
redis> hget myhash field1
"Wk"
redis> hget myhash field2
"Wx"

List(列表)

  1. lpush key value:左插入,添加一个元素到列表的头部

  2. rpush key value:右插入,添加一个元素到列表的尾部

  3. lrange key start stop:显示列表的指定内容,格式:lrange mylist 0 10

  4. lpop key:移出并获取列表的第一个元素

  5. rpop key:移除并获取列表最后一个元素

  6. blpop key timeout:移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

  7. brpop key timeout:移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

  8. blpop和brpop,因为是阻塞式的,连接中的超时时间设置为0时,即可无限等待,直到弹出消息

redis 127.0.0.1:6379> lpush mylist redis
(integer) 1
redis 127.0.0.1:6379> lpush mylist mongodb
(integer) 2
redis 127.0.0.1:6379> lpush mylist rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange mylist 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"

Set(无序集合)

  1. sadd:向集合添加元素

  2. smembers:显示列表的所有元素内容

redis 127.0.0.1:6379> sadd myset redis
(integer) 1
redis 127.0.0.1:6379> sadd myset mongodb
(integer) 1
redis 127.0.0.1:6379> sadd myset rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd myset rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers myset

1) "redis"
2) "rabitmq"
3) "mongodb"

Zset(Sorted Set:有序集合)

  1. zadd:向集合添加元素,格式:zadd key score member

  2. zrange / zrangebyscore:显示集合的所有元素内容(根据score进行排序)

redis 127.0.0.1:6379> zadd myzset 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > zrangebyscore myzset 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"

设置 key 过期时间

expire keyname 5(单位秒)

列出所有的key

命令:KEYS pattern
列出所有的key

keys *

列出匹配的key

redis>keys apple*
1) apple1
2) apple2

删除 key

del keyname

Redis 发布订阅

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

订阅

开启客户端client1...5

redis 127.0.0.1:6379> subscribe channel1

Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "redisChat"
3) (integer) 1

发布消息

redis 127.0.0.1:6379> publish channel1 "Redis is a great caching technique"

(integer) 1

redis 127.0.0.1:6379> publish channel1 "Learn redis by runoob.com"

(integer) 1

# 订阅者的客户端会显示如下消息
1) "message"
2) "channel1"
3) "Redis is a great caching technique"
1) "message"
2) "channel1"
3) "Learn redis by www.zhuifanba.com"

Redis实现消息队列

可利用“List的阻塞功能” 或 “发布订阅” 功能实现消息队列功能。

List的阻塞功能

worker进行blpop某个List,只要有要处理的信息,立即处理。

发布订阅

客户端请求redis入队List数据,同时发布(PUBLISH)消息A到频道channel,此时已经订阅channel的worker就接收到了消息A,知道了List中有消息A进入,即可循环lpop或rpop来消费List中的消息。




推荐阅读
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
author-avatar
ccer
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有