用PHP尝试RabbitMQ(amqp扩展)

RabbitMQ是一个开源的基于AMQP(Advanced Message Queuing Protocol)标准,并且可靠性高的企业级消息系统,目前很多网站在用,包括reddit,Poppen.de等。 1. 安装RabbitMQ sudo apt-get install rabbitmq-server sudo /etc/init.d/rabbitmq-server start   代码 2. 安装librabbitmq sudo apt-get install mercurial hg clone http://hg.rabbitmq.com/rabbitmq-c cd rabbitmq-c hg clone http://hg.rabbitmq.com/rabbitmq-codegen codegen autoreconf -i && ./configure && make && sudo make install 3. 安装php-rabbit扩展 wget http://php-rabbit.googlecode.com/files/php-rabbit.r91.tar.gz tar -zxvf php-rabbit.r91.tar.gz cd php-rabbit.r91 /path/to/php/bin/phpize ./configure –with-amqp –with-php-config=/path/to/php/bin/php-config make && sudo make install 编辑 php.ini 添加: extension=rabbit.so 输出phpinfo看下是否扩展已经加载成功,have fun:)  

关于mongodb ,redis,memcache之间见不乱理还乱的关系和作用(转载)

先说我自己用的情况: 最先用的memcache ,用于键值对关系的服务器端缓存,用于存储一些常用的不是很大,但需要快速反应的数据   然后,在另一个地方,要用到redis,然后就去研究了下redis. 一看,显示自己安装了php扩展,因为有服务器上的redis服务端,自己本地就没有安装,其实用法和memcache基本一样,可能就是几个参数有所不同。当然 它们缓存的效果也不一样,具体的哪里不一样,一下就是一些资料,和自己的总结     1、 Redis和Memcache都是将数据存放在内存中,都是内存数据库。不过memcache还可用于缓存其他东西,例如图片、视频等等。 2、 数据类型–Memcache在添加数据时就要指定数据的字节长度,例如: set key3 0 0 8 lxsymcto STORED 而redis不需要,如:redis 127.0.0.1:6379>set key2 “lxsymblog” OK redis 127.0.0.1:6379>get key2 “lxsymblog” 3、虚拟内存–Redis当物理内存用完时,可以将一些很久没用到的value 交换到磁盘 4、过期策略–memcache在set时就指定,例如set key1 0 0 8,即永不过期。Redis可以通过例如expire 设定,例如expire name 10 5、分布式–设定memcache集群,利用magent做一主多从;redis可以做一主多从。都可以一主一从 6、存储数据安全–memcache挂掉后,数据没了;redis可以定期保存到磁盘(持久化) 7、灾难恢复–memcache挂掉后,数据不可恢复; redis数据丢失后可以通过aof恢复

apache 模块开发之输出过滤器

过滤器是apache中一个非常精妙的设计,apache自带的很多模块都是通过过滤器来实现。 对于过滤器,有输入过滤器与输出过滤器两种。 对于输入过滤器,就是在内容生成器之前执行,而输出过滤器则在内容生成器之后。可以有下面的顺序: http请求-》输入过滤器-》内容生成-》输出过滤器-》用户 所有的请求都会经过我们的过滤器,所以我们可以对这些进行操作,比如统计流量,压缩等等。 下面我们讲一个例子,这个例子是apache自带的一个demo,它的功能是把页面中所有的小写字母变成大写字母。 从上面的过滤器流程中我们可以找到,只要我们在输出过滤器中挂一个钩子,然后将所有的字符变成大写就OK了。 代码如下: