LAMP: この言葉の起源は、1990 年にドイツの雑誌「c't Magazine」が最初にこれらのプロジェクトを組み合わせて LAMP の略語を作成したことに始まりました。これらのコンポーネントは最初から一緒に使用するように設計されたわけではありませんが、これらのオープン ソース ソフトウェアはすぐに入手でき、無料で入手できます。そのため、これらのコンポーネントは一緒に使用されることがよくあります。過去数年間にわたって、これらのコンポーネントの互換性は向上し続けており、それらを組み合わせて使用することが非常に一般的になりました。異なるコンポーネント間の連携を改善するために、特定の拡張機能が作成されています。
現在、ほぼすべての Linux ディストリビューションには、デフォルトで「LAMP スタック」製品が含まれています。これらの製品は、強力な Web アプリケーション プラットフォームを形成します。
LAMP プラットフォームは、階層構造を持つ 4 つのコンポーネントで構成されます。各レイヤーは、ソフトウェア スタック全体の重要な部分を提供します。
Linux: Linux は最下位レベルにあり、オペレーティング システムを提供します。他のすべてのコンポーネントも実際には Linux 上で実行されます。ただし、必ずしも Linux に限定されるわけではなく、必要に応じて他のコンポーネントも Microsoft® Windows®、Mac OS X、UNIX® 上で実行できます。
Apache: その次の下位レベルは、Web サーバーである Apache です。 Apache は、ユーザーが Web ページを取得できるメカニズムを提供します。 Apache は、インターネット上の Web サイトの 65% 以上で Web サーバーとして使用されている、安定したミッションクリティカルなサーバーです。 PHP コンポーネントは実際には Apache にあり、動的ページは Apache と PHP を通じて作成できます。
MySQL: MySQL は、LAMP システムのデータ ストレージ端を提供します。 MySQL を使用すると、大規模で複雑なサイトの実行に適した非常に強力なデータベースが得られます。 Web アプリケーションでは、すべてのデータ、製品、アカウント、その他の種類の情報がこのデータベースに保存され、SQL 言語を使用して簡単にクエリできます。
PHP: PHP は、LAMP システムの他のすべてのコンポーネントをまとめる接着剤のように機能する、シンプルかつ効果的なプログラミング言語です。 PHP を使用すると、MySQL データベース内のデータや Linux が提供する一部の機能にアクセスする動的コンテンツを作成できます。
[検出ツール]
完全なデバッグ結果を得るには、ApacheBenchやhttperfなどのソフトウェアを使用することをお勧めします。非 LAMP アーキテクチャのサーバー テストに興味がある場合は、Microsoft の無料ソフトウェアである Web Application Stress Tool (NT または 2000 が必要) を使用することをお勧めします。 (その他のサーバー テスト ツール)
Apache を検出し、top d 1 を使用してすべてのプロセスの CPU とメモリのステータスを表示します。さらに、apachectl status コマンドも使用されます
[ハードウェアの最適化]
1. ハードウェアをアップグレードするための一般的なルール: PHP スクリプトの場合、主なボトルネックは CPU であり、静的ページの場合、ボトルネックはメモリとネットワークです。通常の 400 Mhz Pentium マシンでは、静的ページのダウンロードにより T3 回線 (45Mbps) が飽和状態になる可能性があります。
2. hdparm を使用してディスクを最適化すると、通常、IDE ディスクの読み取りおよび書き込みパフォーマンスが 200% 向上しますが、SCSI ハードディスクにも影響します。 (さまざまなタイプのハードドライブの比較)
[戦略の最適化]
3. Apache は静的ページよりも PHP スクリプトを処理する速度が 2 ~ 10 倍遅いため、使用する静的ページを増やし、スクリプトの数を減らすようにしてください。
4. PHP スクリプトがバッファリングされていない場合、呼び出されるたびにコンパイルする必要があるため、PHP バッファリング製品をインストールするとパフォーマンスが 25 ~ 100% 向上します。
5. Linux システムを使用している場合は、静的ページがカーネルによって提供されるため、カーネルを 2.4 にアップグレードすることをお勧めします。
6. もう 1 つのバッファリング テクノロジは、頻繁に変更されない PHP ページに HTML バッファリング出力を使用することです。
7. Webサーバー上でX-Windowsを実行したり、不要なプロセスを閉じたりしないでください。
8. テキストを使用できる場合は、画像を使用せず、画像のサイズを小さくしてください。
9. 負荷を分散し、データベース サーバーを別のマシンに配置します。別のローエンド マシンを使用して画像と HTML ページを提供します。すべての静的ページが別のサーバーで処理される場合は、httpd.conf の KeepAlives をオフに設定して、切断時間を短縮できます。
10. 上記の方法はすべて単一マシン向けのものであり、システムの速度がまだ十分ではないと思われる場合は、クラスタリング、負荷分散、およびバッファリングのテクノロジを使用できます。 Squidをバッファとして使用し、Squidを設定します。
[コンパイルの最適化]
11. ファイルベースのセッションを共有メモリベースのセッションに切り替えます。 PHP をコンパイルするときに --with-mm オプションを使用し、php.ini で set session.save_handler=mm を設定します。この簡単な変更により、セッション管理時間を半分に短縮できます。
12. 最新バージョンの Apache を使用して PHP をコンパイルするか、CGI の代わりに DSO モードを使用します。
13. PHP をコンパイルするときは、次のパラメーターを使用することをお勧めします:
--enable-inline-optimization --disable-debug
[構成の最適化]
14. httpd.conf を変更します:
# 閉じるDNS ルックアップ、PHP スクリプトは IP アドレスのみを取得します
HostnameLookups をオフにします
15、如果网络拥挤,CPU 资源不够用,采用 PHP 的 HTML 压缩功能:
output_handler = ob_gzhandler
PHP 4.0.4 的用户请不要使用,因为存在内存泄漏问题。
16、修改 httpd.conf 中的 SendBufferSize 为你最大的页面文件的大小。加大内核的 TCP/IP 写缓冲大小。
17、采用数据库的持久连接时,不要把 MaxRequestsPerChild 设置得太大。
[第三方软件优化]
18、如果喜欢从修改 Apache 源码入手,可以安装 lingerd。在页面产生和发送后,每个 Apache 进程都会浪费一段时光在客户连接上,Lingerd 能接管这项工作,让 Apache 迅速服务下一个客户请求。
19、如果你足够勇敢的话,还可以采用 Silicon Graphics 的 Accelerated Apache 补丁。这个工程能使 Apache 1.3 快 10 倍,使 Apache 2.0 快 4 倍。
安装一个 PHP 缓冲产品能提升 25-100% 的性能。
[Linux系统优化]
1.清理服务器磁盘碎片:
不论Linux文件系统采用什么文件格式(ext3、JFS、XFS、ReiserFS )、何种类型的硬盘(IDE 、SCSI),随着时间的推移文件系统都会趋向于碎片化。ext3、JFS等高级文件系统可以减少文件系统的碎片化,但是并没有消除。在繁忙的数据库服务器中,随着时间的过去,文件碎片化将降低硬盘性能,硬盘性能从硬盘读出或写入数据时才能注意到。时间长了会发现每个磁盘上确实积累了非常多的垃圾文件,释放磁盘空间可以帮助系统更好地工作。Linux最好的整理磁盘碎片的方法是做一个完全的备份,重新格式化分区,然后从备份恢复文件。但是对于7×24小时工作关键任务服务器来说是比较困难的。Kleandisk是一个高效的磁盘清理工具,它能把磁盘上的文件分成不同的"组",比如把所有的"core"文件归成一组(Group),这样要删除所有core文件时只要删除这个组就行了。core文件是当软件运行出错时产生的文件,它对于软件开发人员比较有用,对于其他用户(比如电子邮件服务器)却没有任何意义。因此,如果没有软件开发的需要,见到core文件就可以将其删除。
2、开启硬盘DMA
现在使用的IDE硬盘基本支持DMA66/100/133(直接内存读取)但是Linux发行版本安装后一般没有打开,可以 /etc/rc.d/rc.local 最後面加上一行: /sbin/hdparm -d1 –x66 -c3 -m16 /dev/hda 这样以后每次开机,硬盘的 DMA 就会开启,不必每次手动设定。添加前后你可以使用命令:hdparm -Tt /dev/hda 来测试对比一下。
3、调整缓冲区刷新参数
Linux内核中,包含了一些对于系统运行态的可设置参数。缓冲刷新的参数可以通过调整 /proc/sys/vm/bdflush文件来完成,这个文件的格式是这样的:
<font color="#000000"></font> <font color="#000000"># cat /proc/sys/vm/bdflush 30 64 64 256 500 3000 60 0 0</font> |
每一栏是一个参数,其中最重要的是前面几个参数。第一个数字是在"dirty"缓冲区达到多少的时候强制唤醒bdflush进程刷新硬盘,第二个数字是每次让bdflush进程刷新多少个dirty块。所谓dirty块是必须写到磁盘中的缓存块。接下来的参数是每次允许bd flush将多少个内存块排入空闲的缓冲块列表。 以上值为RHEL 4.0中的缺省值。可以使用两种方法修改:
(1)使用命令
<font color="#000000"><em># echo "100 128 128 512 5000 3000 60 0 0">/proc/sys/vm/bdflush</em></font>
并将这条命令加到/etc/rc.d/rc.local文件中去。
(2)在/etc/sysctl.conf 文件中加入如下行:
<font color="#000000"></font> <font color="#000000">vm.bdflush = 100 128 128 512 5000 3000 60 0 0 </font> |
以上的设置加大了缓冲区大小,降低了bdflush被启动的频度,VFS的缓冲刷新机制是Linux文件系统高效的原因之一。
4、优化输入输出
I/O程序对Linux系统性能也是相当重要的,网络硬件I/O对服务器尤其重要。现在大多数Linux服务器使用10/100 Mb以太网。如果有较重的网络负载,则可以考虑千兆以太网卡。如果没有能力购买千兆网卡的话:可以使用多块网卡虚拟成为一块网卡,具有相同的IP地址。这项技术,在Linux中,这种技术称为Bonding。Bonding在Linux2.4以上内核中已经包含了,只需要在编译的时候把网络设备选项中的 Bonding driver support选中见图1。当然利用Bonding技术配置双网卡绑定的前提条件是两块网卡芯片组型号相同,并且都具备独立的BIOS芯片。
然后,重新编译核心,重新起动计算机,执行如下命令:
<font color="#000000"> </font> <font color="#000000">#ismod bonding #ifconfig eth0 down #ifconfig eth1 down <p style="TEXT-INDENT: 2em">#ifconfig bond0 ipaddress#ifenslave bond0 eth0#ifenslave bond0 eth1</p></font> |
现在两块网卡已经象一块一样工作了。这样可以提高集群节点间的数据传输.bonding对于服务器来是个比较好的选择,在没有千兆网卡时,用两块100兆网卡作bonding,可大大提高服务器到交换机之间的带宽.但是需要在交换机上设置连接bonding网卡的两个子口映射为同一个虚拟接口。编辑 /etc/modules.conf文件,加入如下内容,以使系统在启动时加载Bonding模块。
<font color="#000000"> </font> <font color="#000000">alias bond0 bonding options bond0 mode=0</font> |
“mode”的值表示工作模式,共有0、1、2和3四种模式,这里设定为0。Bonding工作在负载均衡(Load Balancing (round-robin))方式下,即两块网卡同时工作,这时理论上Bonding能提供两倍的带宽。Bonding运行在网卡的混杂(Promisc)模式下,而且它将两块网卡的MAC地址修改为一样的。混杂模式就是网卡不再只接收目的硬件地址是自身MAC地址的数据帧,而是可以接收网络上所有的帧。
5、减少虚拟终端机的数量。
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守护进程。