LAMP系统优化是很是必要的,一个好的优化能使系统运做的越快,从而提升工做效率,下面我将从几方面给你们详细介绍下LAMP系统优化的内容。php
1、硬件优化linux
一、升级硬件的通常规则:对于 PHP 脚本而言,主要的瓶颈是 CPU ,对于静态页面而言,瓶颈是内存和网络。一台 400 Mhz 的普通奔腾机器所下载的静态页面就能让 T3 专线(45Mbps)饱和。数据库
二、采用 hdparm 来优化磁盘,通常能提高 IDE 磁盘读写性能 200%,可是对 SCSI 硬盘也有效果。(不一样类型的硬盘对比)缓存
策略优化服务器
三、Apache 处理 PHP 脚本的速度要比静态页面慢 2-10 倍,所以尽可能采用多的静态页面,少的脚本。网络
四、PHP 脚本若是不作缓冲,每次调用都须要编译,所以,安装一个 PHP 缓冲产品能提高 25-100% 的性能。session
五、若是你采用了 Linux 系统,建议升级内核到 2.4,由于静态页面由内核服务。负载均衡
六、另一项缓冲技术是把不常修改的 PHP 页面采用 HTML 缓冲输出。工具
七、不要在 Web 服务器上运行 X-Windows ,关掉没有必要运行的进程。性能
八、若是可以用文本就不要用图像,尽可能减少图片的尺寸。
九、分散负载,把数据库服务器放到另外的机器上去。采用另外低端的机器服务图片和 HTML 页面,若是全部的静态页面在另一台服务器上处理,能够设置 httpd.conf 中的 KeepAlives 为 off ,来减小断开链接的时间。
十、以上全部的方法都是针对单机而言的,若是你以为系统仍是不够快,能够采用集群,负载均衡,缓冲技术。采用 Squid 做为缓冲,配置 Squid 的方法。
2、编译优化
十一、把基于文件的会话切换到基于共享内存的会话。编译 PHP 时采用 --with-mm 选项,在 php.ini 中设置 set session.save_handler=mm 。这个简单的修改能让会话管理时间缩短一半。
十二、采用最新版本的 Apache ,并把 PHP 编译其中,或者采用 DSO 模式,不要采用CGI方式。
1三、编译 PHP 时,建议采用以下的参数:
--enable-inline-optimization --disable-debug
3、配置优化
1四、修改 httpd.conf :
# 关闭 DNS lookups,PHP 脚本只拿 IP 地址
HostnameLookups off
1五、若是网络拥挤,CPU 资源不够用,采用 PHP 的 HTML 压缩功能:
output_handler = ob_gzhandler
PHP 4.0.4 的用户请不要使用,由于存在内存泄漏问题。
1六、修改 httpd.conf 中的 SendBufferSize 为你最大的页面文件的大小。加大内核的 TCP/IP 写缓冲大小。
1七、采用数据库的持久链接时,不要把 MaxRequestsPerChild 设置得太大。
4、第三方软件优化
1八、若是喜欢从修改 Apache 源码入手,能够安装 lingerd。在页面产生和发送后,每一个 Apache 进程都会浪费一段时光在客户链接上,Lingerd 能接管这项工做,让 Apache 迅速服务下一个客户请求。
1九、若是你足够勇敢的话,还能够采用 Silicon Graphics 的 Accelerated Apache 补丁。这个工程能使 Apache 1.3 快 10 倍,使 Apache 2.0 快 4 倍。
安装一个 PHP 缓冲产品能提高 25-100% 的性能。
5、Linux系统优化
1.清理服务器磁盘碎片:
不论Linux文件系统采用什么文件格式(ext三、JFS、XFS、ReiserFS )、何种类型的硬盘(IDE 、SCSI),随着时间的推移文件系统都会趋向于碎片化。ext三、JFS等高级文件系统能够减小文件系统的碎片化,可是并无消除。在繁忙的数据库服务器中,随着时间的过去,文件碎片化将下降硬盘性能,硬盘性能从硬盘读出或写入数据时才能注意到。时间长了会发现每一个磁盘上确实积累了很是多的垃圾文件,释放磁盘空间能够帮助系统更好地工做。Linux最好的整理磁盘碎片的方法是作一个彻底的备份,从新格式化分区,而后从备份恢复文件。可是对于7×24小时工做关键任务服务器来讲是比较困难的。Kleandisk是一个高效的磁盘清理工具,它能把磁盘上的文件分红不一样的"组",好比把全部的"core"文件归成一组(Group),这样要删除全部core文件时只要删除这个组就好了。core文件是当软件运行出错时产生的文件,它对于软件开发人员比较有用,对于其余用户(好比电子邮件服务器)却没有任何意义。所以,若是没有软件开发的须要,见到core文件就能够将其删除。
二、开启硬盘DMA
如今使用的IDE硬盘基本支持DMA66/100/133(直接内存读取)可是Linux发行版本安装后通常没有打开,能够 /etc/rc.d/rc.local 最後面加上一行: /sbin/hdparm -d1 –x66 -c3 -m16 /dev/hda 这样之后每次开机,硬盘的 DMA 就会开启,没必要每次手动设定。添加先后你可使用命令:hdparm -Tt /dev/hda 来测试对比一下。
三、调整缓冲区刷新参数
Linux内核中,包含了一些对于系统运行态的可设置参数。缓冲刷新的参数能够经过调整 /proc/sys/vm/bdflush文件来完成,这个文件的格式是这样的:
# cat /proc/sys/vm/bdflush 30 64 64 256 500 3000 60 0 0
每一栏是一个参数,其中最重要的是前面几个参数。第一个数字是在"dirty"缓冲区达到多少的时候强制唤醒bdflush进程刷新硬盘,第二个数字是每次让bdflush进程刷新多少个dirty块。所谓dirty块是必须写到磁盘中的缓存块。接下来的参数是每次容许bd flush将多少个内存块排入空闲的缓冲块列表。 以上值为RHEL 4.0中的缺省值。可使用两种方法修改:
(1)使用命令
# echo "100 128 128 512 5000 3000 60 0 0">/proc/sys/vm/bdflush并将这条命令加到/etc/rc.d/rc.local文件中去。
(2)在/etc/sysctl.conf 文件中加入以下行:
vm.bdflush = 100 128 128 512 5000 3000 60 0 0
以上的设置加大了缓冲区大小,下降了bdflush被启动的频度,VFS的缓冲刷新机制是Linux文件系统高效的缘由之一。
四、优化输入输出
I/O程序对Linux系统性能也是至关重要的,网络硬件I/O对服务器尤为重要。如今大多数Linux服务器使用10/100 Mb以太网。若是有较重的网络负载,则能够考虑千兆以太网卡。若是没有能力购买千兆网卡的话:可使用多块网卡虚拟成为一块网卡,具备相同的IP地址。这项技术,在Linux中,这种技术称为Bonding。Bonding在Linux2.4以上内核中已经包含了,只须要在编译的时候把网络设备选项中的 Bonding driver support选中见图1。固然利用Bonding技术配置双网卡绑定的前提条件是两块网卡芯片组型号相同,而且都具有独立的BIOS芯片。
而后,从新编译核心,从新起动计算机,执行以下命令:
#ismod bonding #ifconfig eth0 down #ifconfig eth1 down
#ifconfig bond0 ipaddress#ifenslave bond0 eth0#ifenslave bond0 eth1
如今两块网卡已经象一块同样工做了。这样能够提升集群节点间的数据传输.bonding对于服务器来是个比较好的选择,在没有千兆网卡时,用两块100兆网卡做bonding,可大大提升服务器到交换机之间的带宽.可是须要在交换机上设置链接bonding网卡的两个子口映射为同一个虚拟接口。编辑 /etc/modules.conf文件,加入以下内容,以使系统在启动时加载Bonding模块。 alias bond0 bonding options bond0 mode=0
“mode”的值表示工做模式,共有0、一、2和3四种模式,这里设定为0。Bonding工做在负载均衡(Load Balancing (round-robin))方式下,即两块网卡同时工做,这时理论上Bonding能提供两倍的带宽。Bonding运行在网卡的混杂(Promisc)模式下,并且它将两块网卡的MAC地址修改成同样的。混杂模式就是网卡再也不只接收目的硬件地址是自身MAC地址的数据帧,而是能够接收网络上全部的帧。
五、减小虚拟终端机的数量。
Linux安装后系统默认是6个虚拟终端机,也就是 CTRL+ALT F1~F6 那六个,做为服务器使用能够关掉其中四个,只留下 CTRL+ALT F1~F2,大约省下 4 Mbytes 的内存,可是这样一来,X-Window 会从原来的 CTRL+ALT F7 变成 CTRL+ALT F3 。 修改 /etc/inittab 中,将 mingetty 3 ~6 所有加上 # 字号 。
6. 关闭一些不用的服务
Linux服务器在启动时须要启动不少系统服务,它们向本地和网络用户提供了Linux的系统功能接口,直接面向应用程序和用户。提供这些服务的程序是由运行在后台的守护进程(daemons)来执行的。守护进程是生存期长的一种进程。它们独立于控制终端而且周期性的执行某种任务或等待处理某些发生的事件。他们经常在系统引导装入时启动,在系统关闭时终止。linux系统有不少守护进程,大多数服务器都是用守护进程实现的。如Web服务http等。同时,守护进程完成许多系统任务,好比,做业规划进程crond、打印进程lqd等。有些书籍和资料也把守护进程称做:“服务”。关闭服务方法请查看笔者的文章:深刻理解Linux守护进程。