红薯 Linux 下 Redis 安装详解
来源:互联网 发布:手机轰炸软件 编辑:程序博客网 时间:2024/05/17 07:00
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
推荐下载redis-1.2.6.tar.gz,之前这个版本同事已经有成功安装运行的经验,redis-2.0.4.tar.gz这个版本我安装后无法操作缓存数据,具体原因后续再说
2:安装redis
下载后解压 tar zxvf redis-1.2.6.tar.gz到任意目录,例如/usr/local/redis-1.2.6
解压后,进入redis目录
cd/usr/local/redis-1.2.6
make
拷贝文件
cp redis.conf /etc/ 这个文件时redis启动的配置文件
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(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)
开启redis端口,修改防火墙配置文件
vi/etc/sysconfig/iptables
加入端口配置
-ARH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379-j ACCEPT
重新加载规则
serviceiptables restart
3:启动redis服务
[root@Architect redis-1.2.6]# pwd
/usr/local/redis-1.2.6
[root@Architect redis-1.2.6]# redis-server/etc/redis.conf
查看进程,确认redis已经启动
[root@Architect redis-1.2.6]# ps -ef | grepredis
root 401 29222 0 18:06pts/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 defaultRedis does not run as a daemon. Use 'yes' if you needit.
# Note thatRedis will write a pid file in /var/run/redis.pid whendaemonized.
daemonizeyes
4:测试redis
[root@Architect redis-1.2.6]# redis-cli
redis> set name songbin
OK
redis> getname
"songbin"
5:关闭redis服务
redis-clishutdown
redis服务关闭后,缓存数据会自动dump到硬盘上,硬盘地址为redis.conf中的配置项dbfilenamedump.rdb所设定
强制备份数据到磁盘,使用如下命令
redis-clisave 或者 redis-cli -p 6380 save(指定端口)
1:下载redis
下载地址 http://code.google.com/p/redis/downloads/list
推荐下载redis-1.2.6.tar.gz,之前这个版本同事已经有成功安装运行的经验,redis-2.0.4.tar.gz这个版本我安装后无法操作缓存数据,具体原因后续再说
2:安装redis
下载后解压 tar zxvf redis-1.2.6.tar.gz到任意目录,例如/usr/local/redis-1.2.6
解压后,进入redis目录
拷贝文件
cp redis.conf /etc/ 这个文件时redis启动的配置文件
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(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)
开启redis端口,修改防火墙配置文件
加入端口配置
重新加载规则
3:启动redis服务
查看进程,确认redis已经启动
如果这里启动redis服务失败,一般情况下是因为redis.conf文件有问题,建议检查或找个可用的配置文件进行覆盖,避免少走弯路,这里建议,修改redis.conf,设置redis进程为后台守护进程
4:测试redis
5:关闭redis服务
redis服务关闭后,缓存数据会自动dump到硬盘上,硬盘地址为redis.conf中的配置项dbfilenamedump.rdb所设定
强制备份数据到磁盘,使用如下命令
0 0
- 红薯 Linux 下 Redis 安装详解
- Linux 下安装nginx 详解(新手)
- Windows/Linux 环境下安装 Apache …
- linux下 firefox安装flash debug …
- linux setup yum 安装
- Linux下Oracle安装 详解
- linux 下 /bin /sbin 的区别
- linux 下 opencv2.0 的编译与安装 …
- linux 下 opencv2.0 的编译与安装 …
-  
- Linux 下安装jdk
- Hive安装 …
-
- 在Linux 环境下安装 Mysql(一)
- 在Linux 环境下安装 Mysql(二)
- 在Linux 环境下安装 Mysql(三)
- Linux 下安装配置 JDK7(2)
- Linux(ubuntu) 下安装Boost 库
- 简单的php多线程开发例子
- php接口使用
- Linux 知识宝典
- php队列进程
- redis和 redis的php扩展
- 红薯 Linux 下 Redis 安装详解
- 用php操作redis队列实例讲解
- MyISAM InnoDB 区别
- LSD:一种直线检测算法简介
- HTTP响应头信息和请求头信息详解
- 我的博客今天1岁141天了,我领取了…
- PHP CURL 的用法
- Static 作用详述
- stream_set_blocking让程序无阻塞