一、安装
1、redis的下载及安装:
引用
mkdir /usr/local/redis
cd /usr/local/redis
wget http://redis.googlecode.com/files/redis-2.4.2.tar.gz
tar xzf redis-2.4.2.tar.gz
cd redis-2.4.2
make
./src/redis-server
2、redis测试命令:
src/redis-cli
redis> set foo bar
OK
redis> get foo
“bar”;
3、接下来需要进行redis配置:
引用
daemonize yes
pidfile /usr/local/redis/var/redis.pid
port 6379
timeout 300
loglevel verbose
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
slave-serve-stale-data yes
appendonly no
appendfsync everysec
no-appendfsync-on-rewrite no
vm-enabled no
vm-swap-file /tmp/redis.swap
vm-max-memory 0
vm-page-size 32
vm-pages 134217728
vm-max-threads 4
hash-max-zipmap-entries 512
hash-max-zipmap-value 64
list-max-ziplist-entries 512
list-max-ziplist-value 64
set-max-intset-entries 512
activerehashing yes
4、Redis中文配置文档:
引用
1,是否以后台进程运行,默认为no,生产环境中肯定要设置成yes,并设置为自动启动
daemonize no
2,如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid
pidfile /var/run/redis.pid
3,监听端口,默认为6379
port 6379
4,绑定主机IP,默认值为127.0.0.1(注释),生产环境中一般是内外网的IP
bind 127.0.0.1
5,超时时间,默认为300(秒)
timeout 300
6,日志记录等级,有4个可选值,debug,verbose(默认值),notice,warning
loglevel verbose
7,日志记录方式,默认值为stdout
logfile stdout
8,可用数据库数,默认值为16,默认数据库为0
databases 16
9,指出在多长时间内,有多少次更新操作,就将数据同步到数据文件。这个可以多个条件配合,比如默认配置文件中的设置,就设置了三个条件。
900秒(15分钟)内至少有1个key被改变
save 900 1
300秒(5分钟)内至少有10个key被改变
save 300 10
10,存储至本地数据库时是否压缩数据,默认为yes
rdbcompression yes
11,本地数据库文件名,默认值为dump.rdb
dbfilename /root/redis_db/dump.rdb
12,本地数据库存放路径,默认值为 ./
dir /root/redis_db/
13,当本机为从服务时,设置主服务的IP及端口(注释)
slaveof
14,当本机为从服务时,设置主服务的连接密码(注释)
masterauth
15,连接密码(注释)
requirepass foobared
16,最大客户端连接数,默认不限制(注释)
maxclients 128
17,设置最大内存,达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,任到达最大内存设置,将无法再进行写入操作。(注释)
maxmemory
18,是否在每次更新操作后进行日志记录,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认值为no
appendonly yes
19,更新日志文件名,默认值为appendonly.aof(注释)
appendfilename /root/redis_db/appendonly.aof
20,更新日志条件,共有3个可选值。no表示等操作系统进行数据缓存同步到磁盘,always表示每次更新操作后手动调用fsync()将数据写到磁盘,everysec表示每秒同步一次(默认值)。
appendfsync everysec
21,是否使用虚拟内存,默认值为no
vm-enabled yes
22,虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享
vm-swap-file /tmp/redis.swap
23,将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的 (Redis的索引数据就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0。
vm-max-memory 0
24,虚拟内存文件以块存储,每块32bytes
vm-page-size 32
25,虚拟内在文件的最大数
vm-pages 134217728
26,可以设置访问swap文件的线程数,设置最好不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的.可能会造成比较长时间的延迟,但是对数据完整性有很好的保证.
vm-max-threads 4
27,把小的输出缓存放在一起,以便能够在一个TCP packet中为客户端发送多个响应,具体原理和真实效果我不是很清楚。所以根据注释,你不是很确定的时候就设置成yes
glueoutputbuf yes
28,在redis 2.0中引入了hash数据结构。当hash中包含超过指定元素个数并且最大的元素没有超过临界时,hash将以一种特殊的编码方式(大大减少内存使用)来存储,这里可以设置这两个临界值
hash-max-zipmap-entries 64
29,hash中一个元素的最大值
hash-max-zipmap-value 512
30,开启之后,redis将在每100毫秒时使用1毫秒的CPU时间来对redis的hash表进行重新hash,可以降低内存的使用。当你的使 用场景中,有非常严格的实时性需要,不能够接受Redis时不时的对请求有2毫秒的延迟的话,把这项配置为no。如果没有这么严格的实时性要求,可以设置 为yes,以便能够尽可能快的释放内存
activerehashing yes
5、php-Redis模块安装:
如果你的机器上没有phpize,则需要先安装php-devel这个包
sudo apt-get install php-devel
引用
cd /usr/local/src
wget --no-check-certificate http://github.com/owlient/phpredis/tarball/master -O phpredis.tar.gz
tar zxvf phpredis.tar.gz
cd phpredis*
phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make
sudo make install
安装完成以后重启web服务
6、Redis的界面管理工具
一个PHP版的Redis WEB可视化管理软件
这里可以下载https://github.com/ErikDubbelboer/phpRedisAdmin/downloads
放到web目录里既可以访问
7、php代码的使用
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->set('key', 'val');
echo $redis->get('key');
分享到:
相关推荐
开发者可以通过社区获取帮助,解决在使用过程中遇到的问题,同时也可以分享自己的经验和技巧。 总之,`phpredis_5.4_vc9_nts`扩展包是为PHP 5.4环境设计的高效Redis客户端,特别适用于非多线程环境。它提供了丰富的...
此外,书中还会涵盖Redis与其他技术的集成,如与Spring框架的整合,以及如何在Python、Java、PHP等常见编程语言中使用Redis客户端。这部分内容将帮助开发者更好地在实际项目中部署和使用Redis。 在性能优化方面,...
【描述】"PHP大咖们的精彩分享,受益匪浅"表明了大会的高质量内容,参与者从技术大牛的经验分享中收获颇丰。这些分享可能涉及实际项目经验、解决复杂问题的策略、以及对PHP技术未来的展望,为参会者提供了丰富的学习...
通达OA运行维护与调优经验分享主要涵盖了OA系统的日常运维、问题解决、系统配置、运行服务、巡检策略以及数据备份与恢复等多个方面。以下是对这些知识点的详细阐述: 1. **OA日常运维工作**:包括确保OA的基础运行...
10. **缓存机制**:为了提升性能,论坛可能会使用缓存技术,如Redis、Memcached等,对热门数据进行缓存,减少数据库查询压力。 11. **部署与配置**:论坛系统部署通常涉及到服务器环境配置(如Apache、Nginx等),...
7. **PHP性能优化**:内存管理、代码执行效率、缓存策略(如APC、Memcached、Redis)、PHP配置优化等。 8. **PHP框架**:如果涉及框架,可能会考察Laravel、Symfony、Yii等的使用和理解。 9. **版本控制**:Git的...
2. **数据处理与存储**:利用MySQL数据库,PHP可以处理用户的分享记录、点击统计、推广效果等数据,实现数据的增删改查和查询优化。 3. **URL路由与页面渲染**:PHP的URL路由机制可以将不同的URL映射到相应的处理...
这可能涉及缓存策略(如使用Redis或Memcached)、数据库索引优化、CDN服务、负载均衡等技术,确保系统在高并发情况下仍能保持稳定运行。 “悬赏问答源码v1.2”作为一款成熟的问答系统源码,它集成了上述诸多功能,...
【PHP大学生校园交流论坛】是一个基于PHP编程语言和MySQL数据库技术构建的在线交流平台,专为大学生...通过研究这个项目,不仅可以掌握PHP与MySQL的配合,还能了解到前端Vue.js的实践,以及如何利用Redis优化应用性能。
8. PHP性能优化:通过缓存技术(如APC、Memcached、Redis)、优化数据库查询、减少HTTP请求等方式,可以提升PHP应用的性能。 9. PHP开发工具:像PhpStorm这样的IDE可以提供代码提示、自动完成、错误检查等功能,...
这可能涉及到PHP的计划任务功能(如cron job)或者使用队列服务(如RabbitMQ、Redis)来处理异步任务。 7. **安全性**:考虑到此类平台可能存在滥用风险,开发者必须关注安全问题,比如防止SQL注入、XSS攻击,以及...
"默笙工具箱"这个名字可能是指该工具箱的作者或开发团队,他们通过此项目分享了他们的经验和技巧。 【描述】描述中的"PHP实例开发源码—默笙工具箱 PHP版.zip"进一步确认了这是一个用PHP编写的开源项目,包含了可...
最后,嘉宾们分享了他们在实际项目中的经验和教训,包括如何处理故障、如何进行容量规划、如何应对突发流量增长等。他们鼓励参会者积极参与开源社区,借助社区的力量解决遇到的问题,并通过贡献代码来回馈社区。 ...
7. **性能优化**:为了处理大量文件和用户,系统可能会采用缓存技术,如PHP的APC或Redis,减少数据库访问压力。同时,合理的文件存储结构,如目录层级划分,可以提升文件检索速度。 8. **负载均衡与扩展性**:随着...
10. **性能优化**:缓存技术(如Redis或Memcached)的应用、数据库查询优化、代码效率提升都是提高系统性能的重要手段。 11. **部署与维护**:了解如何在Linux服务器上配置Apache或Nginx、PHP和MySQL,以及如何进行...
8. **缓存技术**:为了提高性能,论坛可能使用缓存(如APC, Memcached, Redis),减少对数据库的直接访问。 9. **SEO优化**:了解如何生成SEO友好的URL,添加元标签,以及如何利用Sitemap提升搜索引擎可见性。 10....
1. **缓存技术**:使用APC、Memcached或Redis进行数据缓存,减少数据库查询压力。 2. **代码优化**:避免使用全局变量,减少不必要的数据库查询,优化算法,提高代码执行效率。 3. **PHP配置优化**:合理设置`...
这个压缩包由知名PHP开发者熊海提供,他可能通过这个博客分享了他的编程经验和技术洞察。 "使用须知.txt"很可能包含了关于如何正确使用这些源码,以及可能存在的版权信息、许可协议或使用限制等内容。在开始研究和...
9. **缓存技术**:为了提升性能,源码可能使用了PHP的APC、Memcached或Redis等缓存机制,减少对数据库的直接访问。 10. **响应式设计**:作为图片分享站,源码可能会考虑不同设备的显示效果,采用响应式设计,确保...
7. **用户认证与授权**:PHP可能使用了如OAuth、JWT等机制进行用户身份验证和权限控制,确保只有合法用户才能访问和操作系统资源。 8. **前端技术**:尽管主要关注PHP,但社区系统前端可能使用HTML、CSS和...