Linux 之 Redis
Linux 之 Redis
参考教程:【千峰教育】
一、Redis简介:
说明:
1、也是一种类似于Memcached的key-value机制的存储服务
2、是非关系型数据库(NoSQL)的一种
3、官网:www.redis.io,中文网:www.redis.cn
特点:
1、能够持久化存储数据,而Memcached不能
2、value支持更多的数据类型
3、支持数据备份,主从模式
二、Redis安装:
1、解压:
tar -zxvf redis-3.2.8.tar.gz
(我选择的版本:wget http://download.redis.io/releases/redis-5.0.3.tar.gz)
2、移动
cp -R redis-3.2.8 /usr/local/redis
3、安装(无需配置编译)
cd /usr/local/redis
make install
4、redis服务介绍:
安装完成后,/usr/local/redis/src 目录中有两个服务程序
客户端:redis-cli
服务端:redis-server
5、服务端测试:./redis-server
6、将服务添加到环境变量中:
默认配置文件路径:/usr/local/redis/redis.conf
添加环境变量:
vim /etc/profile
export PATH=$PATH:/usr/local/redis/src/
source /etc/profile
7、设置开机启动:
(1)编辑配置文件
cd /usr/local/redis/
cp redis.conf redis.conf.bak #备份一下
vim redis.conf
daemonize yes #默认是no,是否以守护进程的方式运行
(2)编辑启动脚本文件
cd /usr/local/redis/utils/
cp redis_init_script redis_init_script.bak #备份一下
vim redis_init_script
EXEC=/usr/local/redis/src/redis-server
CLIEXEC=/usr/local/redis/src/redis-cli
CONF=/usr/local/redis/redis.conf
(3)测试启动脚本(可以通过ps查看并用redis-cli连接)
./redis_init_script start
(4)开机启动
vim /etc/rc.local
添加:
/usr/local/redis/utils/redis_init_script start
8、服务测试:
(1)查看进程
ps aux | grep redis
(2)使用客户端连接
/usr/local/redis/src/redis-cli
参数:
-h 主机
-p 端口号,默认6379
-a 指定密码
输入:ping,显示pong,表示通了。
9、设置密码
(默认是没有密码的)
(1)单次生效
设置密码:config set requirepass 123456
获取密码:config get requirepass
授权使用:auth 123456
(2)永久生效
修改配置文件:vim redis.conf
取消requirepass行前的注释,后面加上密码即可。
requirepass 123456
说明:启动密码后,无密码也可以连接,但是没有权限进行操作。
10、客户端操作:
常用命令:
ping:查看服务器是否允许(结果显示pong表示允许)
quit:关闭当前连接
auth:验证当前连接(auth 密码)
select:选择库,1-15,共16个,默认使用0(示例:select 2)
flushdb:删除当前数据库数据
flushall:删除所有数据库数据
DEL:删除键
EXISTS:检查键是否存在
11、数据类型介绍:
(1)字符串(String):是最基本的数据类型,与Memcached的Key-Value一样。
设置:SET key value
获取:GET key
(2)哈希(Hash):是一个键值对集合,特别适合存储对象。
设置:HMSET user:1 name zhangsan age 12
获取所有信息:HGETALL user:1
获取单个信息:HGET user:1 name
(3)列表(List):按照插入顺序排序,可以添加一个元素到列表的头部或尾部。
左侧压入:lpush key value [value2 value3 ...]
右侧压入:rpush key value [value2 value3 ...]
左侧弹出:lpop
右侧弹出:rpop
范围显示:lrange key start stop(示例:lrange key 0 -1显示全部)
显示个数:llen key
(4)集合(Set):string类型的无序集合,集合中的数据是唯一的。
添加数据:sadd key value [value2 value3 ...]
显示数据:smembers key
显示总数:scard key
随机移除:spop key [count] 默认随机移除一个
(5)有序集合(zset:zort set)
不同于set的是每个元素都会关联一个double类型的分数。
redis正是通过分数来为集合中的成员进行从小到大的排序。
添加数据:zadd key score value
显示数据:zrange key start stop
显示总数:zcard key
显示范围:zcount key start stop
显示序号:zrank key member
显示分数:zscore key member
三、PHP操作redis:
1、安装php-redis扩展:
教程中的示例:
下载:https://github.com/phpredis/phpredis/tree/php7/phpredis-php7.zip
解压:unzip phpredis-php7.zip
进入:cd phpredis-php7
解压:phpize
配置:./configure --with-php-config=/usr/local/php7/bin/php-config
编译:make
安装:make install
我选择的版本:
下载:wget https://github.com/phpredis/phpredis/archive/4.3.0.tar.gz
解压:tar -zxvf 4.3.0.tar.gz
进入解压后的目录:cd 4.3.0
解压:phpize
配置:./configure --with-php-config=/usr/local/php7/bin/php-config
编译:make
安装:make install
安装完成,结果显示(这里的路径下面要用):
Installing shared extensions: /usr/local/php7/lib/php/extensions/no-debug-non-zts-20180731/
2、修改PHP配置文件php.ini
vim /usr/local/php7/etc/php.ini
将上一步的路径添加进来
extension=/usr/local/php7/lib/php/extensions/no-debug-no-zts-20180731/redis.so
3、重启php-fpm
service php-fpm restart
4、测试扩展库是否安装成功
phpinfo()
5、php代码操作redis
示例一:
//创建对象
$redis = new Redis();
//连接服务器
$redis->connect('127.0.0.1',6379);
//密码认证
$redis->auth('123456');
//设置
$redis->set('name','zhang san');
//获取
$name = $redis->get('name');
var_dump($name);
示例二:
(假设要进行抢购秒杀,lpush.php记录抢到的用户,rpop.php处理队列中的中奖用户。)
lpush.php:
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis->auth('123456');
//记录抢到的用户,为了测试这里用随机的名字代替,实际是记录真实的用户
$redis->lpush('user_id','user_'.mt_rand(1,10000));
rpop.php:
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis->auth('123456');
var_dump($redis->rpop('user_id'));
注意事项:
选择php-redis扩展时,选择不同的版本,可能结果不一样,我开始选择的是,php官网的redis-2.2.5.tgz版本,编译时就报错:
... ...,致命错误:ext/standard/php_smart_str.h:没有那个文件或目录
...
编译中断。
make: *** [redis.lo] 错误 1
在网上搜索后,得到的说法是:
因为最新的 phpredis 分了几大分支,针对最新的PHP稳定发行版 php7 有专门为php7的分支,
所以我们从github拉下phpredis 源码。
然后从github上找了一个版本:https://github.com/phpredis/phpredis/archive/4.3.0.tar.gz。
下载重新安装成功了。
Linux 之 Redis的更多相关文章
- Linux下Redis的安装和部署
一.Redis介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多 ...
- Linux下Redis服务器安装配置
说明:操作系统:CentOS1.安装编译工具yum install wget make gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel ...
- linux下Redis与phpredis扩展安装
++++++++++++++++++++++++++++++++++++++++++++++linux下Redis与phpredis扩展安装++++++++++++++++++++++++++++++ ...
- windows下和linux下 Redis 安装
Redis 是一个高性能的key-value数据库, 使用内存作为主存储,数据访问速度非常快,当然它也提供了两种机制支持数据持久化存储.比较遗憾的是,Redis项目不直接支持Windows,Windo ...
- linux上redis安装配置及其防漏洞配置及其攻击方法
Linux上redis安装: 需先在服务器上安装yum(虚拟机可使用挂载的方式安装) 安装配置所需要的环境运行指令: yum -y install gcc 进入解压文件执行make 指令进行编译 执 ...
- linux安装redis(转)
一.Redis介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多 ...
- linux安装redis标准流程-按这个来
1.将下载好的压缩包放到/usr/local目录下# tar xzf redis-3.2.9.tar.gz # cd redis-3.2.9 # make 提示错误 make: cc: Command ...
- Linux中redis安装配置及使用详解
Linux中redis安装配置及使用详解 一. Redis基本知识 1.Redis 的数据类型 字符串 , 列表 (lists) , 集合 (sets) , 有序集合 (sorts sets) , 哈 ...
- Linux安装redis服务器
Linux安装redis服务器 初次接触,这里简单的说下我遇到的情况以及安装方法,当然也是参考了诸位大神的. 确定虚拟机的主机IP. 1)首先需要一个linux虚拟机,确定虚拟机的ip ,输入命令:# ...
- Linux配置Redis外网访问
下载:redis-3.2.5.tar.gz 拷贝到指定目录解压:tar -xzvf redis-3.2.5.tar.gz 进入到解压目录redis-3.2.5下安装: makemake install ...
随机推荐
- Java 的Throwable、error、exception的区别
1. 什么是异常? 异常本质上是程序上的错误,包括程序逻辑错误和系统错误.比如使用空的引用(NullPointerException).数组下标越界(IndexOutOfBoundsException ...
- Postgres-XL的限制
Postgres-XL是基于PostgreSQL的一个分布式数据库. 相比于PostgreSQL,XL的表的数据是可以分布到不同的datanode上的,对存在于不同的datanode上的数据进行处理, ...
- UVa 12171 题解
英文题面不怎么友好,大家还是自行通过紫书了解题面吧... 解题思路: 1. 面对500 ^ 3的数据范围,我们需要先用离散化解决掉爆空间的问题. 2. 由于我们要求的总体积包括内空部分的体积,我们可以 ...
- SAP HANA
DROP PROCEDURE ""."ZCONCAT_EKKO_EBN"; CREATE PROCEDURE ""."ZCONCA ...
- fread()创建文件和file_exists()文件缓存问题
①fread('','w')调用当文件不存在时创建文件,其中参数使用了fread('',"w")导致无法创建文件,修改单引号之后操作正常. ②项目当中新建日志文件,需要判断日志文件 ...
- Python爬虫系列-Requests库详解
Requests基于urllib,比urllib更加方便,可以节约我们大量的工作,完全满足HTTP测试需求. 实例引入 import requests response = requests.get( ...
- python-numpy-pandas
目录 numpy 模块 创建矩阵方法: 获取矩阵的行列数 切割矩阵 矩阵元素替换 矩阵的合并 通过函数创建矩阵 矩阵的运算 pandas模块 series (一维列表) DataFrame DataF ...
- 20181205(模块循环导入解决方案,json&pickle模块,time,date,random介绍)
一.补充内容 循环导入 解决方案: 1.将导入的语句挪到后面. 2.将导入语句放入函数,函数在定义阶段不运行 #m1.pyprint('正在导入m1') #②能够正常打印from m2 imp ...
- Applied Nonparametric Statistics-lec6
Ref: https://onlinecourses.science.psu.edu/stat464/print/book/export/html/8 前面都是对一两个样本的检查,现在考虑k个样本的情 ...
- 关于C#Debug和Release
在程序调试时的debug和release 网上有如下的描述:Debug 通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序.Release 称为发布版本,它往往是进行了各种优化,使 ...