博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Redis介绍和安装
阅读量:5885 次
发布时间:2019-06-19

本文共 4321 字,大约阅读时间需要 14 分钟。

一. Redis的介绍

  Redis 是一个Key-Value存储的系统;它支持存储的value类型有string(字符串),list(列表),set(集合),zset(有序集合);为了保证效率;数据都缓存在内存中;它也周期性将内存数据写入磁盘或者把读写操作写入记录文件。Redis使用单线程模型;还有其他特性:例如健过期,发布/订阅,事务功能等等。

  相比其他个Key-Value存储的系统;有这些优势:

  1. 数据的持久性;Redis会周期性将内存数据写入磁盘和将读写操作写入记录文件。保证数据库在重启之后数据不丢失
  2. 支持master-slave模式;主从复制
  3. 支持存储value类型多样性;有list(列表),set(集合),zset(有序集合),bitmap等等。
  4. 在3.0版本正式提供了高可用分布式架构Redis Cluster集群;提供了高可用性,读写和容量的扩展。

二. Redis的安装与部署

2.1 下载地址

  

2.2 安装

tar -zxvf redis-5.0.0.tar.gzcd redis-5.0.0make cd srcmake install PREFIX=/usr/local/redismkdir -p /usr/local/redis/etcmv ../redis.conf /usr/local/redis/etc

2.3 创建redis用户

  习惯了使用非root用户来管理数据库;前提我们需要创建redis用户和相关目录

useradd redismkdir -p /data/redis/{logs,conf,pid,data}chown -R redis:redis /data/redis

  配置redis;在/data/redis/conf目录下创建redis-6379.conf文件;内容如下

###基本参数###daemonize yespidfile /data/redis/pid/redis-6379.pidport 6379tcp-backlog 65535bind 0.0.0.0timeout 0tcp-keepalive 0loglevel noticelogfile /data/redis/logs/redis-6379.logdatabases 16lua-time-limit 5000maxclients 10000protected-mode yesdir /data/redis/data/###慢日志参数###slowlog-log-slower-than 10000slowlog-max-len 128###内存参数####maxmemory 1G#maxmemory-policy volatile-lru###RDB持久化参数###save 3600 1stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename "dump-6379.rdb"###AOF持久化参数###no-appendfsync-on-rewrite yesappendonly yesappendfilename "appendonly-6379.aof"appendfsync noauto-aof-rewrite-min-size 512mbauto-aof-rewrite-percentage 100aof-load-truncated yesaof-rewrite-incremental-fsync yes###客户端Buffer参数### client-output-buffer-limit normal 0 0 0client-output-buffer-limit slave 256mb 64mb 60client-output-buffer-limit pubsub 32mb 8mb 60###其他参数###hash-max-ziplist-entries 512hash-max-ziplist-value 64list-max-ziplist-entries 512list-max-ziplist-value 64set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64hll-sparse-max-bytes 3000activerehashing yeslatency-monitor-threshold 0hz 10###安全参数###requirepass li0924# masterauth 123456789rename-command KEYS REDIS_KEYSrename-command FLUSHDB REDIS_FLUSHDBrename-command FLUSHALL REDIS_FLUSHALL###复制参数(从库)######集群参数###

相关配置参数:

  • daemonize:如需要在后台运行,把该项的值改为yes
  • pdifile:把pid文件放在/var/run/redis.pid,可以配置到其他地址
  • bind:指定redis只接收来自该IP的请求,如果不设置,那么将处理所有请求,在生产环节中最好设置该项
  • port:监听端口,默认为6379
  • timeout:设置客户端连接时的超时时间,单位为秒
  • loglevel:等级分为4级,debug,revbose,notice和warning。生产环境下一般开启notice
  • logfile:配置log文件地址,默认使用标准输出,即打印在命令行终端的端口上
  • database:设置数据库的个数,默认使用的数据库是0
  • save:设置redis进行数据库镜像的频率
  • rdbcompression:在进行镜像备份时,是否进行压缩
  • dbfilename:镜像备份文件的文件名
  • dir:数据库镜像备份的文件放置的路径
  • slaveof:设置该数据库为其他数据库的从数据库
  • masterauth:当主数据库连接需要密码验证时,在这里设定
  • requirepass:设置客户端连接后进行任何其他指定前需要使用的密码
  • maxclients:限制同时连接的客户端数量
  • maxmemory:设置redis能够使用的最大内存
  • appendonly:开启appendonly模式后,redis会把每一次所接收到的写操作都追加到appendonly.aof文件中,当redis重新启动时,会从该文件恢复出之前的状态
  • appendfsync:设置appendonly.aof文件进行同步的频率
  • vm_enabled:是否开启虚拟内存支持
  • vm_swap_file:设置虚拟内存的交换文件的路径
  • vm_max_momery:设置开启虚拟内存后,redis将使用的最大物理内存的大小,默认为0
  • vm_page_size:设置虚拟内存页的大小
  • vm_pages:设置交换文件的总的page数量
  • vm_max_thrrads:设置vm IO同时使用的线程数量
  • stop-writes-on-bgsave-error 强制关闭Redis快照导致不能持久化;默认为yes

  配置用户环境变量

export REDIS_HOME=/usr/local/redisexport PATH=$PATH:$REDIS_HOME/binalias rds_start="redis-server /data/redis/conf/redis-6379.conf"alias rds_stop="redis-cli -a li0924 shutdown &> /dev/null"alias rsql="redis-cli"

2.4 启动redis

redis-server /data/redis/conf/redis-6379.conf# 或者rds_start

2.5 关闭redis

redis-cli shutdown# 或者rds_stop

  当然还有一种更直接,更粗暴的方式 kill进程 。不建议这样操作;因为这样不会做持久化操作;

pkill redis-server

2.6 redis命令行

redis-cli # 或者 rsql

2.7 redis工具箱

redis-benchmark:redis性能测试工具redis-check-aof:检查aof日志的工具redis-check-dump:检查rdb日志的工具redis-cli:连接用的客户端redis-server:redis服务进程

2.8 消除Redis启动提醒

  当然这也许需要根据日志如何提醒;做对应的修改。

# 在/etc/sysctl.conf文件添加vm.overcommit_memory = 1net.core.somaxconn = 65536# 在/etc/rc.local文件添加echo never > /sys/kernel/mm/transparent_hugepage/enabled

   现在可以愉快玩耍redis

# 1. 启动redis数据库[redis@Postgres ~]$ rds_start # 2. 连接redis数据库[redis@Postgres ~]$ rsql# 3. 密码安全认证127.0.0.1:6379> AUTH li0924OK# 4. 查看所有健;原命令是KEYS *;127.0.0.1:6379> redis_keys *1) "name"# 5. 设置K-V127.0.0.1:6379> set hello worldOK127.0.0.1:6379> redis_keys *1) "hello"2) "name"# 6. 获取健hello的值127.0.0.1:6379> get hello"world"# 7. 退出redis客户端127.0.0.1:6379> exit# 8. 关闭redis数据库[redis@Postgres ~]$ rds_stop[redis@Postgres ~]$ rsqlCould not connect to Redis at 127.0.0.1:6379: Connection refused

 

转载于:https://www.cnblogs.com/lottu/p/10108831.html

你可能感兴趣的文章
Hessian通讯协议【附PHP源代码】
查看>>
Shell读取文件内容
查看>>
面对我们喜欢的和我们需要的,应该何去何从?
查看>>
list集合绑定在datagridview上时如何实现排序
查看>>
Codeforces Round #346 (Div. 2) G. Fence Divercity dp
查看>>
SCOJ 4493: DNA 最长公共子串 后缀自动机
查看>>
python random
查看>>
AfxMessageBox和MessageBox区别
查看>>
通过Typings为Visual Studio Code增强智能提示功能
查看>>
5天不再惧怕多线程——第二天 锁机制
查看>>
互联网推送服务原理:长连接+心跳机制(MQTT协议)
查看>>
Android 系统ID介绍
查看>>
Know How And When To Use System.Message_Level To Control Messages In Oracle Forms
查看>>
Atitit 验证 数字验证 非空验证的最佳算法 h5
查看>>
ASP.NET Core 发布
查看>>
cocos2d-x-lua基础系列教程五(lua单例)
查看>>
升级_开阔视野之Oracle图形化升级(dbca建库后升级)—10.2.0.1.0升为10.2.0.5.0
查看>>
深入浅出 - Android系统移植与平台开发(七)- 初识HAL【转】
查看>>
初探linux子系统集之timer子系统(三)
查看>>
利用VisualVM监视远程JVM
查看>>