Redis安装与(php-redis)扩展

一、redis简介

Redis是一种高级key-value数据库。它跟memcached类似不过数据可以持久化而且支持的数据类型很丰富。有字符串链表集 合和有序集合。支持在服务器端计算集合的并交和补集(difference)等还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务器。

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

二、安装部署

mkdir /soft 
cd /soft

安装插件

wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz 
tar zxvf tcl8.6.1-src.tar.gz 
cd tcl8.6.1
./configure
make && make install

安装redis

wget http://redis.googlecode.com/files/redis-2.6.14.tar.gz
tar zxvf redis-2.6.14.tar.gz 
cd redis-2.6.14
make test
make --prefix=/storage/redisdb
make intsall

三、安装完成后在src目录下生成5个可执行文件redis-server、redis-cli、redis-benchmark、redis-check-aof、redis-check-dump它们的作用如下redis-serverRedis服务器的daemon启动程序redis-cliRedis命令行操作工具。当然你也可以用telnet根据其纯文本协议来操作redis-benchmarkRedis性能测试工具测试Redis在你的系统及你的配置下的读写性能redis-check-aof更新日志检查

redis-check-dump用于本地数据库检查

redis启动

cd src
./redis-server
[5056] 04 Apr 03:33:50.744 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add ‘vm.overcommit_memory = 1‘ to /etc/sysctl.conf and then reboot or run the command ‘sysctl vm.overcommit_memory=1‘ for this to take effect.
[5056] 04 Apr 03:33:50.744 * The server is now ready to accept connections on port 6379

四、设置内存分配策略

可选值0、1、2。0 表示内核将检查是否有足够的可用内存供应用进程使用如果有足够的可用内存内存申请允许否则内存申请失败并把错误返回给应用进程。1 表示内核允许分配所有的物理内存而不管当前的内存状态如何。2 表示内核允许分配超过所有物理内存和交换空间总和的内存值得注意的一点是redis在dump数据的时候会fork出一个子进程理论上child进程所占用的内存和parent是一样的比如parent占用的内存为8G这个时候也要同样分配8G的内存给child,如果内存无法负担往往会造成redis服务器的down机或者IO负载过高效率下降。所以这里比较优化的内存分配策略应该设置为 1表示内核允许分配所有的物理内存而不管当前的内存状态如何

echo "vm.overcommit_memory = 1" >> /etc/sysctl.conf
sysctl -p

验证

src/redis-cli 
redis> set foo bar 
OK 
redis> get foo 
bar
shutdown

Redis远程连接

telnet 127.0.0.1 6379

安全设置

关闭掉selinux

/usr/sbin/setenforce 0 立刻关闭 SELINUX
#/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT
#/etc/rc.d/init.d/iptables save

五、配置自启动

cp redis.conf /etc

mkdir -p /storage/redis db文件放在这里要修改redis.conf

mkdir -p /var/log/redislog log文件放在这里要修改redis.conf

修改redis.conf db文件位置

cp redis.conf /etc/
vim /etc/redis
# The working directory.
# The DB will be written inside this directory, with the filename specified
# above using the ‘dbfilename‘ configuration directive.
# Also the Append Only File will be created inside this directory
#
daemonize yes  //改为后台启动
# Note that you must specify a directory here, not a file name.
dir /storage/redis  // db文件位置
logfile=/var/log/redislog   //修改redis.conf log文件位置

配置自启动:vi /etc/init.d/redis

startup脚本代码如下所示将其建立为/etc/init.d/redis文件

#!/bin/bash 
# 
# Init file for redis 
# 
# chkconfig: - 80 12 
# description: redis daemon 
# 
# processname: redis 
# config: /etc/redis.conf 
# pidfile: /var/run/redis.pid 
source /etc/init.d/functions 
#BIN="/usr/local/bin" 
BIN="/usr/local/bin" 
CONFIG="/etc/redis.conf" 
PIDFILE="/var/run/redis.pid" 
### Read configuration 
[ -r "$SYSCONFIG" ] && source "$SYSCONFIG" 
RETVAL=0 
prog="redis-server" 
desc="Redis Server" 
start() { 
        if [ -e $PIDFILE ];then 
             echo "$desc already running...." 
             exit 1 
        fi 
        echo -n $"Starting $desc: "
daemon $BIN/$prog $CONFIG 
        RETVAL=$? 
        echo 
        [ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog 
        return $RETVAL 
} 
stop() { 
        echo -n $"Stop $desc: " 
        killproc $prog 
        RETVAL=$? 
        echo 
        [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$prog $PIDFILE 
        return $RETVAL 
} 
restart() { 
        stop 
        start 
} 
case "$1" in 
  start) 
        start 
        ;; 
  stop) 
        stop 
        ;; 
  restart) 
        restart 
        ;; 
  condrestart) 
        [ -e /var/lock/subsys/$prog ] && restart
    RETVAL=$? 
        ;; 
  status) 
        status $prog 
        RETVAL=$? 
        ;; 
   *) 
        echo $"Usage: $0 {start|stop|restart|condrestart|status}" 
        RETVAL=1 
esac 
exit $RETVAL
chmod +x /etc/init.d/redis

重新启动

/etc/init.d/redis restart

Stop Redis Server:                                         [  OK  ]

Starting Redis Server:                                     [  OK  ]

六、配置php扩展支持redis

1、下载php-redis zip安装包

https://github.com/nicolasff/phpredis

2、找到PHP安装路径

命令whereis phpize和whereis php-config 找到phpize和php-config路径

3、生成configure

# /usr/bin/phpize

4、编译安装

# ./configure --with-php-config=/usr/bin/php-config
# make && make install

5、加入安装的redis.so模块

# vim /etc/php.ini
extension=redis.so

6、重启apache或nginx

7、测试

<?php
$redis = new Redis();
$redis->connect(‘127.0.0.1‘,6379);
$redis->set(‘test‘,‘hello world!‘);
echo $redis->get(‘test‘);
?>

Redis安装与(php-redis)扩展

时间: 2024-10-28 21:17:06

Redis安装与(php-redis)扩展的相关文章

Redis安装与配置Redis安装与配置

今天在使用Redis的时候遇到了一些问题,这个问题的解决,发现很多人使用Redis的时候没有一点安全意识.所以又重温了一下Redis,觉得应该写一下Redis的安全和配置. Redis安装与配置Redis安装与配置 安装 下载,解压,编译: $ wget http://download.redis.io/releases/redis-4.0.10.tar.gz $ tar xzf redis-4.0.10.tar.gz $ mv redis-4.0.10 /usr/local/redis $ c

21.9 redis介绍 21.10 redis安装 21.11 redis持久化 21.12 re

21.9 redis介绍Redis和Memcached类似,也属于k-v数据存储Redis官网redis.io, 当前最新稳定版4.0.1支持更多value类型,除了和string外,还支持hash.lists(链表).sets(集合)和sorted sets(有序集合)redis使用了两种文件格式:全量数据(RDB)和增量请求(aof).全量数据格式是把内存中的数据写入磁盘,便于下次读取文件进行加载.增量请求文件则是把内存中的数据序列化为操作请求,用于读取文件进行replay得到数据,这种类似

Redis安装与调试

?? Redis安装与调试 Redis安装与调试linux版本:64位CentOS 6.5 Redis版本:2.8.17  (更新到2014年10月31日) Redis官网:http://redis.io/ Redis常用命令:http://redis.io/commands 1.安装Redis # wget http://download.redis.io/releases/redis-2.8.17.tar.gz # tar xzf redis-2.8.17.tar.gz # cd redis

php redis安装

一.redis安装 1 下载redis安装包 wget http://redis.googlecode.com/files/redis-2.4.17.tar.gz (若无法下载请手动下载) 2 编译安装 Linux代码   $ tar zxvf redis-2.4.17.tar.gz $ cd redis-2.4.17 $ make $ make PREFIX=/usr/local/webserver/redis install 3 配置redis Linux代码   $ mkdir /etc/

memcached 和 redis 安装

memcached 1.搭建好lnmp 2.安装依赖包 yum install -y libevent-devel 3.安装memcached $ cd /usr/local/src $ wget http://memcached.org/files/memcached-1.4.33.tar.gz $ tar -zxvf memcached-1.4.33.tar.gz $ cd memcached-1.4.33 $ ./configure --prefix=/usr/local/memcache

Redis安装(单机及各类集群,阿里云)

Redis安装(单机及各类集群,阿里云) 前言 上周,我朋友突然悄悄咪咪地指着手机上的一篇博客说,这是你的博客吧.我看了一眼,是之前发布的<Rabbit安装(单机及集群,阿里云>.我朋友很哈皮地告诉我,我的博客被某个Java平台进行了微信推送.看到许多人阅读,并认同了我的博客,心理还是很开心的. 好了,话题收回来.这次就Redis在实际服务器中的各种安装,进行详细描述. 另外由于内容较多,并不一定能涵盖各个方面,万望见谅.如果存在什么问题,或者有什么需要添加的,请私信或@我. 最后,由于打马赛

redis安装与使用

Redis是一个基于内存的数据库,其不仅读写速度快,每秒可以执行大约110000的写操作,81000的读取操作,而且其支持存储字符串,哈希结构,链表,集合丰富的数据类型.所以得到很多开发者的青睐.加之其支持主从.持久化等功能,3.0版本开始正式提供分片技术.让其在大型互联网应用中大显身手,本文通过实际操作和理论相配合,对redis进行详细地阐述. 一.redis安装 1.redis的安装与使用 下载直接去redis的官网http://redis.io/进行不同操作系统对应的版本.本文中采用的re

redis 安装配置及持久化详解

一.redis简介 二.redis安装 三.redis配置文件详解 四.redis持久化详解 1.redis 简介 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询. Redi

Redis安装与入门

一.Redis安装 1.-安装虚拟机 下载地址:http://rj.baidu.com/soft/detail/13808.html?ald 2.搭建linux系统(Centos 7) 安装地址:http://jingyan.baidu.com/article/75ab0bcbe8bc4dd6864db28f.html 如图: 二.Redis安装 1.Resis 简介 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库. 安装Redi

CentOS 6.5下Redis安装详细步骤

CentOS 6.5下Redis安装详细步骤 Redis简介: Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发工作由VMware主持. redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set –有序集合)和hash(哈希类