redis作为NoSQL数据库的一种应用,响应速度和命中率上还是比较高效的。项目中需要用集中式可横向扩展的缓存框架,做了一点调研,即便 redis、memcached存在效率上的差异(具体比较参考http://timyang.net/data/mcdb-tt-redis/),但其 实都能满足目前项目的需求;但是redis还是比较风骚的,支持链表和集合操作,支持正则表达式查找key,目前项目缓存的结果大多是链表,如果链表新增 或者修改数据的话,redis就体现出了极大的优势(memcached只能重新加载链表,redis可以对链表新增或者修改)
1:下载redis
下载地址 http://code.google.com/p/redis/downloads/list里
wget http://redis.googlecode.com/files/redis-2.4.2.tar.gz
2:安装redis
1.下载后解压 tar zxvf redis-2.4.2.tar.gz 到任意目录,例如/usr/local/redis-1.2.6
解压后,进入redis目录
2. cd /usr/local/redis-2.4.2
3. make
4.拷贝文件
cp redis.conf /etc/ 这个文件时redis启动的配置文件
进入src
cd ./src
cp redis-benchmark redis-cli redis-server /usr/bin/ #这个倒是很有用,这样就不用再执行时加上./了,而且可以在任何地方执行
设置内存分配策略(可选,根据服务器的实际情况进行设置)
/proc/sys/vm/overcommit_memory
可选值:0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
值 得注意的一点是,redis在dump数据的时候,会fork出一个子进程,理论上child进程所占用的内存和parent是一样的,比如parent 占用的内存为8G,这个时候也要同样分配8G的内存给child,如果内存无法负担,往往会造成redis服务器的down机或者IO负载过高,效率下 降。所以这里比较优化的内存分配策略应该设置为 1(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)
因为/proc里的文件基本用编辑器时不能修改的所以用echo
echo 1>overcommit_memory
linux下 开启redis端口,修改防火墙配置文件
vi /etc/sysconfig/iptables
加入端口配置
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT
重新加载规则
service iptables restart
3:启动redis服务
[root@Architect redis-1.2.6]# redis-server /etc/redis.conf
查看进程,确认redis已经启动
[root@Architect redis-1.2.6]# ps -ef | grep redis
root 401 29222 0 18:06 pts/3 00:00:00 grep redis
root 29258 1 0 16:23 ? 00:00:00 redis-server /etc/redis.conf (此条表示已经运行起来了)
如果这里启动redis服务失败,一般情况下是因为redis.conf文件有问题,建议检查或找个可用的配置文件进行覆盖,避免少走弯路,这里建议,修改redis.conf,设置redis进程为后台守护进程
# By default Redis does not run as a daemon. Use 'yes' if you need it.
# Note that Redis will write a pid file in /var/run/redis.pid when daemonized.
daemonize yes
4:测试redis
[root@Architect redis-1.2.6]# redis-cli
redis> set name songbin
OK
redis> get name
"songbin"
5:关闭redis服务
redis-cli shutdown
redis服务关闭后,缓存数据会自动dump到硬盘上,硬盘地址为redis.conf中的配置项dbfilename dump.rdb所设定
强制备份数据到磁盘,使用如下命令
redis-cli save 或者 redis-cli -p 6380 save(指定端口)
分享到:
相关推荐
在Linux系统中安装Redis是一个常见的任务,特别是在搭建分布式缓存或数据存储环境时。本文将详细阐述Linux安装Redis的步骤,并解决可能出现的错误。 首先,我们需要从Redis官方网站下载Redis的源代码包。在本例中,...
### Linux安装Redis服务详解 #### 一、前言 Redis是一种高性能的键值数据库,它支持多种数据结构,如字符串、哈希、列表等,并具备持久化功能,可用于缓存、消息队列等多种应用场景。本文将详细介绍如何在RedHat/...
linux安装redis,内含安装包及教程
在Linux系统中安装Redis是一个常见的任务,特别是在搭建服务器或开发基于Redis的数据缓存应用时。Redis是一个开源的、高性能的键值对存储系统,适用于数据缓存、消息队列等多种场景。本文将详细介绍如何在Linux上...
在Redis安装文件的`utils`子目录下有一个`redis_init_script`文件,这是官方提供的初始化启动脚本。 2. **脚本配置**: - `REDISPORT`: 运行的端口号 - `EXEC`: 服务启动命令路径 - `CLIEXEC`: 客户端启动命令...
在Linux系统中安装Redis,无论是单机版还是集群配置,都需要遵循一定的步骤。Redis是一款开源、高性能的键值存储数据库,常用于缓存、消息中间件等场景。下面将详细介绍如何在Linux上安装Redis的单机版以及设置Redis...
首先运行`make`来编译源码,然后通过`make install`将Redis安装到系统默认的可执行路径(通常是/usr/local/bin): ```bash make sudo make install ``` 安装完成后,Redis的可执行文件会位于`/usr/local/bin`目录...
Linux安装Redis详细步骤 setTitle: Linux安装Redis详细步骤 setDescription: 该文档详细介绍了在Linux环境下安装Redis的步骤,从安装wget命令到启动Redis服务的整个过程。 setTags: Linux, Redis, 安装, 配置 ...
Linux 安装 Redis Redis 是一种基于内存的 NoSQL 数据库,可以用作数据库、消息队列、缓存等。下面将详细介绍如何在 Linux 系统上安装 Redis。 安装前的准备 在安装 Redis 之前,需要先确保系统中已经安装了必要...
包含linux环境中离线安装redis所有依赖包(redis-3.3.5.gem,redis-4.0.1.tar.gz,ruby-2.2.3.tar.gz,rubygems-2.7.3.tgz,zlib-1.2.8.tar.gz),已经安装步骤文档。
### Linux安装Redis-4.0.8缓存详解 #### 安装背景及意义 Redis是一种广泛使用的开源键值数据库,以其高性能、低延迟而著称。它支持多种数据结构,如字符串、哈希表、列表等,并可以作为缓存、消息队列以及数据库来...
Linux安装Redis
linux 安装redis
### Linux环境下Redis安装与配置详解 #### 一、前言 本文档旨在为初次接触Linux系统的用户详细介绍如何在Linux环境中安装并配置Redis数据库。通过本文的学习,您将能够掌握基本的Linux操作技能,并学会如何在...
本文将详细讲解如何在Linux上安装Redis,包括Redis 4.0.2和5.0.0两个版本,以及如何配合使用Redis Desktop Manager进行图形化管理。 首先,我们来了解Redis的基本概念。Redis是一个基于内存的数据结构存储系统,...
在Redis安装目录下运行`redis-cli`进入交互模式: ```bash ./bin/redis-cli ``` 设置一个键值对,例如: ```bash set test hello ``` 然后获取这个键的值: ```bash get test ``` 如果能够正确返回“hello”,...
资源包括redis-5.0.5.tar.gz安装包和自动安装脚本,把安装包copy到/usr/java/toos/redis-5.0.5.tar.gz目录下,然后执行:./linux_install_redis.sh脚本。