PHP开发大型网站的优化方案详解

一、memcached

memcached 是一个高效的分布式的内存对象缓存系统 ,他可以支持把各种php的数据(array,对象,基本数据类型)放入到它管理的内存中.注:需通过脚本定时清除缓存,防止缓存过大影响网站性能。

示例代码:
conn.php
<?php
    $link=mysql_connect("localhost","root",null);
    mysql_select_db("bbs",$link);
    mysql_query("set names utf8");
?>
memcache_getid.php
<?php
include_once 'conn.php';
$id=$_GET['id'];
$memcache = new memcache;
$memcache->connect('127.0.0.1', 11211) or die ("连接失败");
//$memcache->flush();  清除缓存
if($info=$memcache->get($id))
{  
    echo $info;
    exit;
}
else
{
    $result=mysql_query("select * from user where id=$id");
    if($result)
    {
        $arr=mysql_fetch_array($result);
        echo "need mysql query";
        $memcache->add($id,$arr['id'],MEMCACHE_COMPRESSED,60*60*24);
    }
}
?>

二、页面静态化技术

1、真静态化
(1)创建模板文件template.html
(2)通过模板文件,创建静态页面的 php文件 xx.php
(3) 用户访问生成的静态页面 xx.html

newsAction.php
<?php
 
 
    header("content-type:text/html;charset=utf-8");
 
 
    function replace($row,$title,$content){
            //含义是 用 $title的内容替换 $row中的 %title%
            $row=str_replace("%title%",$title,$row);
            $row=str_replace("%content%",$content,$row);
            return $row;
 
    }
 
 
    //处理添加、修改、删除请求
    //1.接收一下oper
    $oper=$_REQUEST['oper'];
 
     
    if($oper=="add"){
         
 
            //接收title,content
            $title=$_POST['title'];
            $content=$_POST['content'];
 
            //1.把数据放入到mysql, 同时创建一个html
 
            //添加到数据库 SqlHelper.class.php
 
            $conn=mysql_connect("localhost","root","root");
         
            if(!$conn){
                die("连接失败");
            }
 
            //构建html_filename
            //$file=
 
            mysql_select_db("spdb1",$conn);
 
            $sql="insert into  news (title,content) values('$title','$content')";
 
            if(mysql_query($sql,$conn)){
                 
                //获取刚刚插入数据的id号
                $id=mysql_insert_id();
                $html_filename="news_id".$id.".html";
                //echo "文件名=".$html_filename;
 
                //创建html文件
                $fp_tmp=fopen("template.tpl","r");
                $fp_html_file=fopen($html_filename,"w");
                //思路->tmp->html 逐行读取template.tpl文件,然后逐行替换
                   
                while(!feof($fp_tmp)){
                     
                        //读取一行.
                        $row=fgets($fp_tmp);
                        //替换(小函数)
                        $new_row=replace($row,$title,$content);
 
                        //把替换后的一行写入到html文件
                        fwrite($fp_html_file,$new_row);
                }
 
                //关闭文件流
                fclose($fp_tmp);
                fclose($fp_html_file);
 
                echo "添加到数据库并成功创建html文件<a href='news_list.php'>返回列表</a>";
 
            }
 
             
            mysql_close($conn);
 
    }
 
 
?>
show_news.php
<?php
 
 
    //接受id
    $id=@$_GET['id'];
 
        //看看如何使用html静态页面
        //思路,看看html页面是否有,如果有,直接访问,没有就创建
        //构建一个文件名.
        $html_filename="news_id".$id.".html";
 
        echo file_get_contents($html_filename);
        //filemtime()=>获取文件的最后修改时间
        //filemtime($html_filename)+30>time() 表示静态文件,
//      if(file_exists($html_filename)&& filemtime($html_filename)+30>time()){
//         
//          //直接访问html页面(把html页面的内容 echo 浏览器)
//          echo file_get_contents($html_filename);
//          exit;
//      }
//
//      $conn=mysql_connect("localhost","root","root");
//     
//      if(!$conn){
//          die("连接失败");
//      }
//
//      mysql_select_db("spdb1",$conn);
//
//     
//      $sql="select * from news where id=$id";
//      $res=mysql_query($sql);
//      //开启ob缓存
//      ob_start();
//      if($row=mysql_fetch_assoc($res)){
//
//          header("content-type:text/html;charset=utf-8");
//          echo "<table  border='1px' bordercolor='green' cellspacing='0' width=400px height=200px>";
//          echo "<tr><td>新闻详细内容</td></tr>";
//          echo "<tr><td>{$row['title']}</td></tr>";
//          echo "<tr><td>{$row['content']}</td></tr>";
//          echo "</table>";
//      }else{
//          echo "没有结果";
//      }
//
//      $html_content=ob_get_contents();
//      $my_hader="<head><meta http-equiv='content-type' content='text/html;charset=utf-8'/></head>";
//      //把ob->$html_filename (必要时,需要考虑路径)
//      file_put_contents($html_filename,$my_hader.$html_content);
//
//      mysql_free_result($res);
//      mysql_close($conn);
 
 
?>

2、伪静态化
环境配置:#LoadModule rewrite_module modules/mod_rewrite.so 在httpd.conf去掉改项#,并项目目录下配置.htaccess文件

.htaccess
<IfModule rewrite_module>
#写你的rewrite规则
RewriteEngine On
#news-id(d+).html$ 是规则  news.php?id=$1 是转发的页面
#正则 子表达式 捕获 反向引用
#  "news-id33.html"
# 可以配置多个规则,匹配的顺序是从上到下
RewriteRule  news-id(d+).html$   news.php?id=$1
RewriteRule  news-id(d+).html$     error.php
</IfModule>

①真静态访问效率高,利于seo.可以减少对数据库的操作。但是会占用大量的磁盘。
②伪静态一、可以方便的实现对搜索引擎的优化;二、占空间比较小;三、通过生成不同view-id2.hmtl 可以实现内容的变化;四有效的防止了注入攻击;
注:但是两者在启用页面缓存时(ob_start)需要注意一个问题,不要需要经常修改的html文件放入页面缓存,否则会造成页面无法刷新得到最新结果,页面缓存一般存放经常被查询的html且不会被更新。

3、mysql优化技巧
配置慢查询日志:
在my.ini最下面配置

log-slow-queries = e:/wamp/logs/mysql_slow_query.log
long_query_time=2

通过 show status/variables like '%query%'' 查看是否配置成功(即slow_query_log=ON)
分析慢查询日志
通过select sleep(4);测试
通过explain 慢sql语句或mysqldumpslow 慢查询日志
查询sql语句状态

set profilling=on;
show profiles;
show profile for query id;
  1. 使用order by null 禁用排序(默认为filesort)
    比如 select * from dept group by ename order by null
  2. 在精度要求高的应用中,建议使用定点数(decimal)来存储数值,以保证结果的准确性

3.表的水平划分/垂直分割
来源:http://www.jsdaima.com/blog/145.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,723评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,485评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,998评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,323评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,355评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,079评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,389评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,019评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,519评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,971评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,100评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,738评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,293评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,289评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,517评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,547评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,834评论 2 345

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,600评论 18 139
  • 大型网站数据库优化及浅析大型网站的架构 2015-03-27 09 千万人同时访问的网站,一般是有很多个数据库同时...
    wokeman阅读 1,639评论 1 22
  • 读一个故事只需几分钟,然而写故事的人却没有那么轻松,所以撇开知名度,我觉得那些写小说,写文章,写诗歌等的作家都很优...
    西柚子茶LM阅读 197评论 0 6
  • ROSE 0419 在我出生的那个小村子,住着一位满头白发的老人,从我记事起直到他离开村子一直都是满头白发,我和村...
    挤地铁去上班阅读 491评论 0 0
  • 林语堂:怎样才能叫受过教育? 2016-01-07 教师博览 教育或文化的目的不外是在发展知识上的鉴赏力和行为上的...
    Life答案阅读 813评论 0 1