`
kennyluo
  • 浏览: 78418 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

PHP企业级应用之常见缓存技术篇

阅读更多

 

php的缓冲器

有eaccelerator, apc, phpa,xcache,这个这个就不说了吧,搜索一堆一堆的,自己看啦,知道有这玩意就OK

MYSQL缓存

这也算非代码级的,经典的数据库就是用的这种方式,看下面的运行时间,0.09xxx之类的
我贴段根据蓝色那家伙修改后部分my.ini吧,2G的MYISAM表可以在0.05S左右,据说他前后改了有快一年

[client] …… default-character-set=gbk default-storage-engine=MYISAM max_connections=600 max_connect_errors=500 back_log=200 interactive_timeout=7200 query_cache_size=64M …… table_cache=512 …… myisam_max_sort_file_size=100G myisam_max_extra_sort_file_size=100G myisam_sort_buffer_size=128M key_buffer_size=1024M read_buffer_size=512M …… thread_concurrency=8
[Ctrl+A 全部选择 然后拷贝]

基于反向代理的Web缓存:

如Nginx,SQUID,mod_proxy(apache2以上又分为mod_proxy和mod_cache)
NGINX的例子

<nginx.conf>

#user  nobody;

worker_processes  4;

error_log  logs/error.log crit;

pid        logs/nginx.pid;

worker_rlimit_nofile 10240;

events {

    use epoll;

    worker_connections  51200;

}

http {

    include       mime.types;

    default_type  application/octet-stream;

    sendfile    on;

    keepalive_timeout 65;

    tcp_nodelay on;

    # server pool

    upstream bspfrontsvr {

            server 10.10.10.224:80   weight=1;

            server 10.10.10.221:80   weight=1;

    }

   

    upstream bspimgsvr {

            server 10.10.10.201:80   weight=1;

    }

   

    upstream bspstylesvr {

            server 10.10.10.202:80   weight=1;

    }

   

    upstream bsphelpsvr {

            server 10.10.10.204:80   weight=1;

    }

   

    upstream bspwsisvr {

            server 10.10.10.203:80   weight=1;

    }

   

    upstream bspadminsvr {

            server 10.10.10.222:80   weight=1;

    }

   

    upstream bspbuyersvr {

            server 10.10.10.223:80   weight=1;

    }

   

    upstream bspsellersvr {

            server 10.10.10.225:80   weight=1;

    }

    upstream  bsploginsvr  {

            server 10.10.10.220:443  weight=1;

    }

    upstream  bspregistersvr  {

            server 10.10.10.220:80  weight=1;

    }

    log_format  test_com  '$remote_addr - $remote_user [$time_local] "$request" '

                             '$status $body_bytes_sent "$http_referer" "$http_user_agent" ';

    #--------------------------------------------------------------------

    #img.test.com

    server {

        listen       10.10.10.230:80;

        server_name  img.test.com;

        location / {

                        proxy_pass      http://bspimgsvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/img.log  test_com;

    }

   

    #style.test.com

    server {

        listen       10.10.10.230:80;

        server_name  style.test.com;

        location / {

                        proxy_pass      http://bspstylesvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/style.log  test_com;

    }

   

   

    #help.test.com

    server {

        listen       10.10.10.230:80;

        server_name  help.test.com;

        location / {

                        proxy_pass      http://bsphelpsvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/help.log  test_com;

    }

   

   

    #admin.test.com

    server {

        listen       10.10.10.230:80;

        server_name  admin.test.com;

        location / {

                        proxy_pass      http://bspadminsvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/admin.log  test_com;

    }

   

    #buyer.test.com

    server {

        listen       10.10.10.230:80;

        server_name  buyer.test.com;

        location / {

                        proxy_pass      http://bspbuyersvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/buyer.log  test_com;

    }

   

    #seller.test.com

    server {

        listen       10.10.10.230:80;

        server_name  seller.test.com;

        location / {

                        proxy_pass      http://bspsellersvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/seller.log  test_com;

    }

    #wsi.test.com

    server {

        listen       10.10.10.230:80;

        server_name  wsi.test.com;

        location / {

                        proxy_pass      http://bspwsisvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/wsi.log  test_com;

    }

    #www.test.com

    server {

        listen       10.10.10.230:80;

        server_name  www.test.com   *.test.com;

        location ~ ^/NginxStatus/ {

            stub_status on;

            access_log off;

        }

        location / {

                        proxy_pass      http://bspfrontsvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/www.log  test_com;

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

    }  

    #login.test.com

    server {

        listen       10.10.10.230:443;

        server_name  login.test.com;

        ssl                  on;

        ssl_certificate      cert.pem;

        ssl_certificate_key  cert.key;

        ssl_session_timeout  5m;

        ssl_protocols  SSLv2 SSLv3 TLSv1;

        ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;

        ssl_prefer_server_ciphers   on;

        location / {

                        proxy_pass        https://bsploginsvr;

                        include         proxy_setting.conf;

        }

        access_log  logs/login.log  test_com;

    }

    #login.test.com for register

    server {

        listen       10.10.10.230:80;

        server_name  login.test.com;

        location / {

                        proxy_pass        http://bspregistersvr;

                        include         proxy_setting.conf;

        }   

        access_log  logs/register.log  test_com;

    }  

   

}

<conf/proxy_setting.conf>

                        proxy_redirect          off;

                        proxy_set_header        Host $host;

                        proxy_set_header        X-Real-IP $remote_addr;

                        proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;

                        client_max_body_size    10m;

                        client_body_buffer_size 128k;

                        proxy_connect_timeout   90;

                        proxy_send_timeout      90;

                        proxy_read_timeout      90;

                        proxy_buffer_size       4k;

                        proxy_buffers           4 32k;

                        proxy_busy_buffers_size 64k;

                        proxy_temp_file_write_size 64k;

 
[Ctrl+A 全部选择 然后拷贝]

mod_proxy的例子:

<VirtualHost *>
ServerName www.zxsv.com
ServerAdmin admin@zxsv.com
# reverse proxy setting
ProxyPass / http://www.zxsv.com:8080/
ProxyPassReverse / http://www.zxsv.com:8080/
# cache dir root
CacheRoot "/var/www/proxy"
# max cache storage
CacheSize 50000000
# hour: every 4 hour 
CacheGcInterval 4
# max page expire time: hour
CacheMaxExpire 240
# Expire time = (now - last_modified) * CacheLastModifiedFactor 
CacheLastModifiedFactor 0.1
# defalt expire tag: hour
CacheDefaultExpire 1
# force complete after precent of content retrived: 60-90%
CacheForceCompletion 80
CustomLog /usr/local/apache/logs/dev_access_log combined
</VirtualHost>

而SQUID的例子我就不说明了,这方面网上有写的太多,大家自己搜索一下

DNS轮询

BIND是一款开放源码的DNS服务器软件,这个要说起来就大了,自己搜索去,大家知道有这个东西就行了。
我知道的有chinacache等大站就是这样做的,说简单点就是多服务器啦,把同一个页面或文件缓存到不同的服务器上,按南北自动解析到相关的服务器中。

分享到:
评论

相关推荐

    php课程(共100多节)

    php课程(共100多节),让你从小白成神,最主流的PHP技术! 有: 1:环境配置与代码调试 2:PHP的数据类型与源码调试 3:常用PHP运算类型介绍与应用 4: PHP条件语句介绍与应用 5:PHP循环语句的介绍与应用 6:PHP数组...

    php网络开发完全手册

    第2篇 PHP与数据库 第13章 关系型数据库的基础知识 204 13.1 关系型数据库与关系型数据库系统的 13.1 介绍 204 13.2 关系型数据库系统的结构与运行过程 205 13.2.1 关系型数据库系统的层次结构 205 13.2.2 关系型...

    sql anywhere11.0新特点

    移动性 无论能否获得与企业系统的连接,SQL Anywhere 所提供的企业级数据库都能够在前台系统和设备上运行。它的同步技术确保了可通过无线和有线网络与后台数据库、应用程序服务器和消息传递系统有效地交换数据。 ...

    集群好书《高性能Linux服务器构建实战》 试读章节下载

    由国内著名技术社区联合推荐的2012年IT技术力作:《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》,即将上架发行,此书从Web应用、数据备份与恢复、网络存储应用、运维监控与性能优化、集群高级应用等...

    迈思网站内容管理系统(MyStepCMS) 1.0.5.zip

     数据缓存,用于缓存从数据库查询出的结果集,兼容常见的 MemCache、eAccelerator、xCache 等数据缓存加速技术,同时也自建文件和数据库两种模式,方便各类用户;  页面缓存,可将解析好的页面整体缓存到缓存文件...

    MyStepCMS 迈思网站内容管理系统 v1.0.5.zip

    数据缓存,用于缓存从数据库查询出的结果集,兼容常见的 MemCache、eAccelerator、xCache 等数据缓存加速技术,同时也自建文件和数据库两种模式,方便各类用户; 页面缓存,可将解析好的页面整体缓存到缓存文件,在...

    JAVA上百实例源码以及开源项目

     Java非对称加密源程序代码实例,本例中使用RSA加密技术,定义加密算法可用 DES,DESede,Blowfish等。  设定字符串为“张三,你好,我是李四”  产生张三的密钥对(keyPairZhang)  张三生成公钥(publicKeyZhang...

    JAVA上百实例源码以及开源项目源代码

    Java非对称加密源码实例 1个目标文件 摘要:Java源码,算法相关,非对称加密 Java非对称加密源程序代码实例,本例中使用RSA加密技术,定义加密算法可用 DES,DESede,Blowfish等。 设定字符串为“张三,你好,我是李四”...

    基于J2EE框架的个人博客系统项目毕业设计论文(源码和论文)

    在web 2.0应用中,博客(Blog)是web 2.0核心应用中最典型、最流行的代表之一,也是web 2.0技术应用的最直观的表现,是web 2.0精神和理念的具体体现。 1.2. 问题的提出 Blog记载了日常发生的事情和自己的兴趣爱好,把...

Global site tag (gtag.js) - Google Analytics