设为首页 收藏本站
查看: 644|回复: 0

[经验分享] Redis 安装及配置 (转整理)

[复制链接]

尚未签到

发表于 2016-12-18 10:05:40 | 显示全部楼层 |阅读模式
  Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集 合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务 器。

Redis的所有数据都是保存在内存中,然后不定期的通过异步方式保存到磁盘上(这称为“半持久化模式”);也可以把每一次数据变化都写入到一个append only file(aof)里面(这称为“全持久化模式”)。

I.快速运行Redis

一、下载安装
进入redis.io官方网站:

Linux代码 DSC0000.gif   DSC0001.png DSC0002.gif





  • $ wget http://redis.googlecode.com/files/redis-2.4.15.tar.gz   

  • $ tar xzf redis-2.4.5.tar.gz //这里假设解压缩到/usr/local/redis   

  • $ cd redis-2.4.5  
  • $ make   
  • $ make install   
  • $ cd utils   
  • $./install_server  



$ wget http://redis.googlecode.com/files/redis-2.4.15.tar.gz
$ tar xzf redis-2.4.5.tar.gz //这里假设解压缩到/usr/local/redis
$ cd redis-2.4.5
$ make
$ make install
$ cd utils
$./install_server

  

就会自动安装到/usr/local/bin目录下。在该目录下生成几个可执行文件,分别是redis-server、redis-cli、redis-benchmark、redis-stat、redis-check-aof,它们的作用如下:
    redis-server:Redis服务器的daemon启动程序
    redis-cli:Redis命令行操作工具。当然,你也可以用telnet根据其纯文本协议来操作
    redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
    redis-stat:Redis状态检测工具,可以检测Redis当前状态参数及延迟状况
    redis-check-aof:

二.启动服务器
安装时的最后一步install_server脚本会生成启动命令文件(试试就知道),下面就是一个执行例子

Linux代码  





  • Welcome to the redis service installer   
  • This script will help you easily set up a running redis server   
  •   
  •   

  • Please select the redis port for this instance: [6379]   

  • Selecting default: 6379  

  • Please select the redis config file name [/etc/redis/6379.conf]   

  • Selected default - /etc/redis/6379.conf   
  • Please select the redis log file name [/var/log/redis_6379.log]   
  • Selected default - /var/log/redis_6379.log   

  • Please select the data directory for this instance [/var/lib/redis/6379]   

  • Selected default - /var/lib/redis/6379  
  • Please select the redis executable path [/usr/local/bin/redis-server]   

  • Copied /tmp/6379.conf => /etc/init.d/redis_6379   
  • Installing service...   
  • Successfully added to chkconfig!   

  • Successfully added to runlevels 345!   
  • Starting Redis server...   
  • Installation successful!  



Welcome to the redis service installer
This script will help you easily set up a running redis server

Please select the redis port for this instance: [6379]
Selecting default: 6379
Please select the redis config file name [/etc/redis/6379.conf]
Selected default - /etc/redis/6379.conf
Please select the redis log file name [/var/log/redis_6379.log]
Selected default - /var/log/redis_6379.log
Please select the data directory for this instance [/var/lib/redis/6379]
Selected default - /var/lib/redis/6379
Please select the redis executable path [/usr/local/bin/redis-server]
Copied /tmp/6379.conf => /etc/init.d/redis_6379
Installing service...
Successfully added to chkconfig!
Successfully added to runlevels 345!
Starting Redis server...
Installation successful!

  
/etc/init.d/redis_6379 start
将启动服务到默认端口6379

三.客户端访问

Linux代码  





  • $ redis-cli   
  • redis> set foo bar   
  • OK   
  • redis> get foo   

  • "bar"  



$ redis-cli
redis> set foo bar
OK
redis> get foo
"bar"

  

四.关闭服务器

Linux代码  





  • $ /etc/init.d/redis_6379 stop  



$ /etc/init.d/redis_6379 stop
  
以上摘官方文档http://redis.io/download。如果想使用Windows版的Redis请去http://code.google.com/p/servicestack/wiki/RedisWindowsDownload下载(其版本滞后于官方版本,不建议在生产环境使用Win32.)。

II. 定制服务器启动参数
在我们成功安装Redis后,我们直接执行redis-server即可运行Redis,此时它是按照默认配置来运行的(默认配置甚至不是后台运行)。我们希望Redis按我们的要求运行,则我们需要修改配置文件(在redis解压缩目录下有一个redis.con可以作为范本),下面是redis.conf的主要配置参数的意义:

引用

    daemonize:是否以后台daemon方式运行
pidfile:pid文件位置
port:监听的端口号
timeout:请求超时时间
loglevel:log信息级别
logfile:log文件位置
databases:开启数据库的数量
save * *:保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。
rdbcompression:是否使用压缩
dbfilename:数据快照文件名(只是文件名,不包括目录)
dir:数据快照的保存目录(这个是目录)
appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)
  

下面是一个略做修改后的配置文件内容:

Redis.conf代码  





  • daemonize yes   
  • pidfile /usr/local/redis/var/redis.pid   

  • port 6000  

  • timeout 300  
  • loglevel debug   
  • logfile /usr/local/redis/var/redis.log   

  • databases 16  

  • save 900 1  

  • save 300 10  

  • save 60 10000  
  • rdbcompression yes   
  • dbfilename dump.rdb   
  • dir /usr/local/redis/var/   
  • appendonly no   
  • appendfsync always   
  • glueoutputbuf yes   
  • shareobjects no   

  • shareobjectspoolsize 1024  



daemonize yes
pidfile /usr/local/redis/var/redis.pid
port 6000
timeout 300
loglevel debug
logfile /usr/local/redis/var/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /usr/local/redis/var/
appendonly no
appendfsync always
glueoutputbuf yes
shareobjects no
shareobjectspoolsize 1024
  
重启服务器

Linux代码  





  • redis-server /usr/local/redis/redis.conf  



redis-server /usr/local/redis/redis.conf

  
试试看读写是否有问题.如果服务器启动到了指定非默认端口,那么客户端连接则需要-p参数
如:

Linux代码  





  • $redis-cli -p 6380  



$redis-cli -p 6380
  

* 开放服务器端口供其他主机连接
vi /etc/sysconfig/iptables #需要具备其修改权限
可能需要增加一行:
# redis
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT
保存后重启iptables:
service iptables restart (PATH中加入了/sbin/)或者 /etc/init.d/iptables restart

III. PHP客户端
Redis的php客户端库非常之多,code.google.com上就有:
* phpredis
http://code.google.com/p/phpredis/ 是C客户端作为php模块

* php-predis
http://code.google.com/p/php-redis/ 纯php客户端
以上两个都不在Redis官方推荐推荐之列。

Redis推荐客户端链接是:http://redis.io/clients,如下图:
DSC0003.jpg

纯php库Predis(便于hack),但是性能不高。https://github.com/nrk/predis
下载该库文件后运行bin/createSingleFile.php可以生成一个类库文件Predis.php,非常方便使用。下面是最简单的一个Hello World应用:

Php代码  





  • <?php   

  • require('Predis.php');   

  • $single_server = array(   

  •     'host'     => '192.168.1.101',   

  •     'port'     => 6379,   

  •     'database' => 15   
  • );   
  •   

  • $client = new Predis\Client($single_server);   
  •   

  • $client->set('library''predis');   

  • $retval = $client->get('allen ');   
  •   

  • var_dump($retval);  



<?php
require('Predis.php');
$single_server = array(
'host'     => '192.168.1.101',
'port'     => 6379,
'database' => 15
);
$client = new Predis\Client($single_server);
$client->set('library', 'predis');
$retval = $client->get('allen ');
var_dump($retval);

  

我推荐使用的客户端是:phpredis  https://github.com/nicolasff/phpredis
windows版的dll从这里下载https://github.com/char101/phpredis/downloads

IV . Redis管理工具
1. phpRedisAdmin
https://github.com/ErikDubbelboer/phpRedisAdmin/
要求PHP C Module : https://github.com/nicolasff/phpredis
比较弱

2. redis-admin
http://code.google.com/p/redis-admin/
更弱

选phpRedisAdmin是不得不的做法.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-315878-1-1.html 上篇帖子: Redis缓存介绍和使用 下篇帖子: redis之初探
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表