codeigniter 3.X使用redis

学习redis正好用codeigniter来练习

CI3.X自带redis库并且在两个地方使用了这个功能,前提系统安装phpredis 这个PHP扩展

1、储存session的驱动支持redis

http://codeigniter.org.cn/user_guide/libraries/sessions.html?highlight=redis

设置application/config/config.php

$config[‘sess_driver‘] = ‘redis‘;
$config[‘sess_save_path‘] = ‘tcp://localhost:6379‘;

使用同session的使用,具体见手册

$this->load->library(‘session‘);

这种方法只是使用redis来储存session

2、CI的缓存驱动器(Caching Driver)

http://codeigniter.org.cn/user_guide/libraries/caching.html?highlight=redis#redis

CI3.X支持多种缓存方式,redis只是其中一种,不过CI将redis和其他缓存方式都放到“cache”这个驱动模块中

$this->load->driver(‘cache‘, array(‘adapter‘ => ‘apc‘, ‘backup‘ => ‘file‘));

CI缓存使用方法见手册

具体说说redis缓存的使用

修改 application/config/redis.php 设置

$config[‘socket_type‘] = ‘tcp‘; //`tcp` or `unix`
$config[‘socket‘] = ‘/var/run/redis.sock‘; // in case of `unix` socket type
$config[‘host‘] = ‘127.0.0.1‘;
$config[‘password‘] = NULL;
$config[‘port‘] = 6379;
$config[‘timeout‘] = 0;

使用

$this->load->driver(‘cache‘);
$this->cache->redis->save(‘foo‘, ‘bar‘, 10);

redis缓存在CI中的设置十分简单,BUT,

可能是因为redis只是缓存驱动的一种,CI能实现的功能也十分简单。

源码 system/libraries/Cache/drivers/Cache_redis.php的111行

$this->_redis = new Redis();

CI并没继承phpredis的类,所以cache对redis的操作进行了封装,看封装的几个方法,CI的redis驱动只支持简单的字符串类型

codeigniter-redis第三方驱动

https://github.com/joelcox/codeigniter-redis

看更新时间,还是CI 2.X时候开发的,不过phpredis没有太大升级,CI 3.X用起来应该也没什么影响

安装也很简单

将Redis.php类库放到system/libraries下

application/config/autoload.php 加载类库,添加

$autoload[‘libraries‘] = array(‘redis‘);

在 application/config/redis.php

添加配置

$config[‘redis_default‘][‘host‘] = ‘127.0.0.1‘;        // IP address or host
$config[‘redis_default‘][‘port‘] = ‘6379‘;            // Default Redis port is 6379
$config[‘redis_default‘][‘password‘] = ‘‘;            // Can be left empty when the server does not require AUTH

$config[‘redis_slave‘][‘host‘] = ‘127.0.0.1‘;
$config[‘redis_slave‘][‘port‘] = ‘6379‘;
$config[‘redis_slave‘][‘password‘] = ‘‘;

现在就可以用CI类库的方式使用redis了

测试

    $this->load->driver(‘redis‘);
    $array_mset=array(
                    ‘first_key‘=>‘first_val‘,
                    ‘second_key‘=>‘second_val‘,
                    ‘third_key‘=>‘third_val‘
    );
    $this->redis->mset($array_mset); #用MSET一次储存多个值
    $array_mget=array(‘first_key‘,‘second_key‘,‘third_key‘);
    var_dump($this->redis->mget($array_mget)); 
    #一次返回多个值 //array(3) { [0]=> string(9) "first_val" [1]=> string(10) "second_val" [2]=> string(9) "third_val" }

不过这里有个冲突,加载第三方redis类库后,原生的cache无法使用redis模块,

因为第三方redis类库的config和CI 3.X的redis驱动config的结构不同,加载方式也不同

第三方autoload时

$this->_ci->load->config(‘redis‘);

而Cache_redis.php是

$CI->config->load(‘redis‘, TRUE, TRUE)

所以造成cache无法使用redis模块。

(测试CI的autoload加载模块先加载,默认模块是调用时候加载)

解决方案,修改cache的redis配置,放到一个redis数组中

$config[‘redis‘][‘socket_type‘] = ‘tcp‘; //`tcp` or `unix`
$config[‘redis‘][‘socket‘] = ‘/var/run/redis.sock‘; 
$config[‘redis‘][‘host‘] = ‘127.0.0.1‘;
$config[‘redis‘][‘password‘] = NULL;
$config[‘redis‘][‘port‘] = 6379;
$config[‘redis‘][‘timeout‘] = 0;

其实个人觉得没这个必要,如果使用了第三方redis类库没必要同时使用cache模块。

时间: 2024-12-04 20:08:33

codeigniter 3.X使用redis的相关文章

**【ci框架】精通CodeIgniter框架

http://blog.csdn.net/yanhui_wei/article/details/25803945 一.大纲 [php] view plaincopy 1.codeigniter框架的授课内容安排 2.codeigniter框架的简介 |-----关于框架的概念 |-----使用CI框架的好处 |-----为什么选择CI框架 3.codeigniter框架的具体安装步骤 |-----官网下载:http://www.codeigniter.com/ |-----httpd.conf配

ci 集成redis

希望在CI中使用redis作为缓存驱动,发现官方github上已经有了,貌似要到3.0才正式发布,先用上吧,省事了 为了保持框架可升级操作如下 1.将system\libraries\Cache\Cache.php复制为application\libraries\Cache\Cache.php 增加配置 protected $valid_drivers = array(     'cache_apc', 'cache_file', 'cache_memcached', 'cache_dummy'

Redis+keepalived实现双机热备

一. 简介 安装使用centos 5.6(64) Master 192.168.2.235 Slave 192.168.2.236 Vip 192.168.2.200 编译环境 yum -y install gcc gcc+ gcc-c++ openssl openssl-devel pcre pcre-devel 当 Master 与 Slave 均运作正常时, Master负责服务,Slave负责Standby: 当 Master 挂掉,Slave 正常时, Slave接管服务,同时关闭主从

Python操作数据库(mysql redis)

一.python操作mysql数据库: 数据库信息:(例如211.149.218.16   szz  123456) 操作mysql用pymysql模块 #操作其他数据库,就安装相应的模块 import  pymysql ip='211.149.218.16' port=3306 passwd='123456' user='root' db='szz' conn=pymysql.connect(host=ip,user=user,port=port,passwd=passwd,db=db,cha

Redis在Linux中安装使用

一.安装$ wget http://download.redis.io/releases/redis-x.x.x.tar.gz $ tar xzf redis-x.x.x.tar.gz $ cd redis-x.x.x $ make sudo cp mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-check-rdb redis-trib.rb redis-sentinel redis-server /usr/loca

redis 学习 四 队列

<?php /** * redis实战 * * 利用列表list实现简单队列 * * @example php cache.php */ header('content-type:text/html;chaeset=utf-8'); $redis = new \Redis(); $redis->connect('127.0.0.1', 6379); // 进队列 $userId = mt_rand(000000, 999999); $redis->rpush('QUEUE_NAME',j

Redis实战(三)Redis主从复制

从架构 1.主从架构图 2.通过命令 mkdir redisCluster创建redis集群文件夹 3.通过命令mkdir 6380   mkdir 6381   mkdir 6382在redisCluster文件夹下创建三个文件夹 4.通过以下命令将redis.conf分别拷贝到6380.6381. 6382文件夹下 cp /usr/local/redis/redis-3.0.2/redis.conf  ./6380 cp /usr/local/redis/redis-3.0.2/redis.

Redis Cluster集群部署搭建

在Oracle的路上走了许多年,换换感觉,尝试一下新的知识,也是一个不错的感觉.Redis,一个超轻量化的内存数据库,只做一小块数据库功能实现,却非常优秀的一个产品.今天,就分享一下安装Redis集群的过程. 搭建redis集群,建议至少需要准备3台服务器,共搭建6个节点,3个master,3个slave,并且要求3个master节点不能全部跑到同一台服务器上,保证节点安全,3台服务器的配置相同,使用redistest账号搭建,对应的端口是7000/7001/7002端口 我的集群分配如下,每个

redis的单机安装与配置以及生产环境启动方案

简单介绍一下redis的单机安装与配置,方便自己记录安装步骤的同时方便他人获取知识. 首先,从官网下载最新版的(稳定版)的redis安装包.官网地址如下:https://redis.io/download 下载源码包后,redis需要编译安装.需要安装gcc和tcl,gcc用于编译tcl用于测试. 使用命令安装gcc,yum install gcc,一路选择yes,gcc就可以安装成功. 接下来安装tcl,首先获取tcl源码包(见百度云盘)或者使用命令:wget http://downloads