用了这么久apc还没有研究过它的代码,突然对其内存共享的方式比较感兴趣,apc是一个客户端的内存缓存,它所有的缓存都是存在web服务器本地的,那么我有以下疑问
apc的内存共享是基于进程的吗?如果我是用php-fpm方式运行,那么多个fpm子进程之间是如何共享内存,或者干脆是没有共享内存,而是各自独立分配一块内存做缓存。
回复内容:
用了这么久apc还没有研究过它的代码,突然对其内存共享的方式比较感兴趣,apc是一个客户端的内存缓存,它所有的缓存都是存在web服务器本地的,那么我有以下疑问
apc的内存共享是基于进程的吗?如果我是用php-fpm方式运行,那么多个fpm子进程之间是如何共享内存,或者干脆是没有共享内存,而是各自独立分配一块内存做缓存。
看这里(https://bugs.php.net/bug.php?id=57825),有人说:
sadly (or luckily for some people here), the way php-fpm works
makes all the processes share the same cache, since apc is loaded into the main
process that is forked to spawn children.
但我没做过实验,没有验证。
RPCMS是一款基于PHP+MYSQL的轻量型内容管理/博客系统,支持PHP5.6版本以上,支持win/Linux系统。它自主研发的RP框架(OPP方式),采用MVC架构搭建的高效、稳定的内容管理系统。灵活小巧,但有着强大的扩展性、丰富的插件接口和大量的模板。统一采用模板标签,轻松上手,让开发更方便!智能缓存机制让网站运行方面大幅度提高。系统特点:源码简洁、体积轻巧、功能丰富、安全、灵活等特点,完
立即学习“PHP免费学习笔记(深入)”;
基于共享内存, 可以参看apc的apc_shm.c
PHP-FPM方式下APC的opcode缓存和用户数据缓存是在进程间共享的。









