一.lamp简介

 LAMP 平台由几个组件组成,呈分层结构。每一层都提供了整个软件栈的一个关键部分:

       Linux和windows:Linux和windows  处在最低层,提供操作系统。其他每个组件实际上也在其上运行。但是,并不一定局限于Linux和windows,如有必要,其他组件包括: Mac OS X 或 UNIX。 

      Apache:次低层是 Apache,它是一个 Web 服务器。Apache 提供可让用户获得 Web 页面的机制。Apache 是一款稳定的、支持关键任务的服务器,Internet 上超过 65% 的网站都使用它作为 Web 服务器。PHP 组件实际上是在 Apache 中,动态页面可以通过 Apache 和 PHP 创建。 

      MySQL:MySQL 提供 LAMP 系统的数据存储端。有了 MySQL,便可以获得一个非常强大的、适合运行大型复杂站点的数据库。在 Web 应用程序中,所有数据、产品、帐户和其他类型的信息都存放在这个数据库中,通过 SQL 语言可以很容易地查询这些信息。 

       PHP :PHP 是一门简单而有效的编程语言,它像是粘合剂,可以将 LAMP 系统所有其他的组件粘合在一起。您可以使用 PHP 编写能访问 MySQL 数据库中的数据和 Linux 提供的一些特性的动态内容。  Perl:Perl 是一种脚本语言。这表示它并不编译成可执行程序,而是在运行时进行解释的一组指令(脚本)。 Perl 是代表“实际抽取和报告语言”(practical extraction and report language) 的字首组合词。Perl 被誉为语言中的“瑞士×××”。它功能强大且非常灵活。语言学家 Larry Wall 在廿世纪八十年代后期在 NASA 担任系统管理员时开发了 Perl。他创建 Perl 的目的是使构建报告的任务变得更简单。 Perl 现在用来执行许多任务。它也许是用于在 Web 上进行 CGI(公共网关接口)编程最流行的语言。其原因就是 Perl 是一种功能非常强大的文本处理器,而 Web 编程主要就是文本处理。另外,使用 Perl 通常比使用 C/C++、Java 或 Tcl 更简单,而且它比 Python 更早出现。Perl被称为是一种“胶水语言”。所谓胶水语言,也就是说它是可以用来将许多元素连接在一起的语言。

        Python:Python一种交互式面向对象的解释型编程语言。 Python使用非常清晰的语法实现非常强大的功能。它具有模块、类、意外处理以及非常高级别的动态数据类型和动态定义。并且,它具有接口和库函数供多种系统调用。内建模块还可以使用C或C++语言方便地编写。对于用户界面的编程,Python同样能够胜任。  Python可以运行在Linux 、UNIXWindowsDOS、OS/2、Mac以及Amiga等等多种环境下。 Python虽然有版权,但完全可以免费使用和分发,甚至是为了商业用途。

二.lamp架构-优化

硬件优化

1、升级硬件的一般规则:对于 PHP 脚本而言,主要的瓶颈是 CPU ,对于静态页面而言,瓶颈是内存和网络。一台 400 Mhz 的普通奔腾机器所下载的静态页面就能让 T3 专线(45Mbps)饱和。 
2、采用 hdparm 来优化磁盘,一般能提升
IDE 磁盘读写性能 200%,但是对 SCSI 硬盘也有效果。(不同类型的硬盘对比)

策略优化

3、Apache 处理 PHP 脚本的速度要比静态页面慢 2-10 倍,因此尽量采用多的静态页面,少的脚本。
4、PHP 脚本如果不做
缓冲,每次调用都需要编译,因此,安装一个 PHP 缓冲产品能提升 25-100% 的性能。
5、如果你采用了 Linux 系统,建议升级内核到 2.4,因为静态页面由内核服务。
6、另外一项缓冲技术是把不常修改的 PHP 页面采用
HTML 缓冲输出。
7、不要在 Web 服务器上运行 X-Windows ,关掉没有必要运行的进程。 
8、如果能够用文本就不要用图像,尽量减小图片的尺寸。 
9、分散负载,把数据库服务器放到另外的机器上去。采用另外低端的机器服务图片和 HTML 页面,如果所有的静态页面在另外一台服务器上处理,可以设置 httpd.conf 中的 KeepAlives 为 off ,来减少断开连接的时间。
10、以上所有的方法都是针对单机而言的,如果你觉得系统还是不够快,可以采用集群,负载均衡,缓冲技术。采用 Squid 作为缓冲,配置 Squid 的方法。 

编译优化

11、把基于文件的会话切换到基于共享内存的会话。编译 PHP 时采用 --with-mm 选项,在 php.ini 中设置 set session.save_handler=mm 。这个简单的修改能让会话管理时间缩短一半。
12、采用最新版本的 Apache ,并把 PHP 编译其中,或者采用 DSO 模式,不要采用
CGI方式。
13、编译 PHP 时,建议采用如下的参数:
--enable-inline-optimization --disable-debug 

配置优化

14、修改 httpd.conf : 
# 关闭 DNS lookups,PHP 脚本只拿 IP 地址
HostnameLookups off 
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文件来完成,这个文件的格式是这样的:

# 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文件系统高效的原因之一。 
4、优化输入输出 
   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、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守护进程

三.lamp的环境×××实例

1.源码安装mysql

①.下载并进行安装前的准备工作

wps_clip_p_w_picpath-11159

进行拆包

p_w_picpath 

②.mysql安装前的环境创建(此版本的mysql为绿色软件直接解压使用即可!!!)

[root@donghao244 ~]# groupadd mysql  // 创建mysql用户

[root@donghao244 ~]# useradd -r -g mysql mysql //增加mysql用户及组

[root@donghao244 ~]# cd /usr/local //切换到该目录

[root@donghao244 local]# ls

bin  etc  games  include  lib  libexec  sbin  share  src

[root@donghao244 local]# ln -s /usr/local/src/mysql-5.5.15-linux2.6-i686/  mysql

//新建连接

[root@donghao244 local]# cd mysql/

[root@donghao244 mysql]# chown -R mysql .   //修改当前的所有文件及目录的所有者为mysql

[root@donghao244 mysql]# chgrp -R mysql .   //修改当前的所有文件及目录的所属组为mysql

wps_clip_p_w_picpath-13847

[root@donghao244 mysql]# scripts/mysql_install_db --user=mysql

//使用mysql身份安装数据库

Installing MySQL system tables...

OK

Filling help tables...

OK

To start mysqld at boot time you have to copy

support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !

To do so, start the server, then issue the following commands:

./bin/mysqladmin -u root password 'new-password'

./bin/mysqladmin -u root -h donghao244.cj.com password 'new-password'

Alternatively you can run:

./bin/mysql_secure_installation

which will also give you the option of removing the test

databases and anonymous user created by default.  This is

strongly recommended for production servers.

See the manual for more instructions.

You can start the MySQL daemon with:

cd . ; ./bin/mysqld_safe &

You can test the MySQL daemon with mysql-test-run.pl

cd ./mysql-test ; perl mysql-test-run.pl

Please report any problems with the ./bin/mysqlbug script!

[root@donghao244 mysql]# chown -R root .  //修改所有当前目录的所有文件及目录的所有者为root

[root@donghao244 mysql]# chown -R mysql data  //修改所有当前目录的data目录的所有者为mysql

[root@donghao244 mysql]# cp support-files/my-medium.cnf /etc/my.cnf

//新建my.cnf文件

[root@donghao244 mysql]# bin/mysqld_safe --user=mysql &

//以mysql的身份运行mysql_safe

[1] 3904

[root@donghao244 mysql# 120804 19:19:12 mysqld_safe Logging to '/usr/local/mysql/data/donghao244.cj.com.err'.

120804 19:19:12 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data

[root@donghao244 mysql]# netstat -tupln |grep 3306 

tcp        0      0 :::3306                     :::*                        LI

[root@donghao244 mysql]# cp support-files/mysql.server /etc/init.d/mysqld  //可以使系统直接识别的控制脚本

[root@donghao244 mysql]# service  mysqld stop  //测试系统系统命令关闭mysql

Shutting down MySQL..120804 19:22:21 mysqld_safe mysqld from pid file /usr/local/mysql/data/donghao244.cj.com.pid ended

                                                           [  OK  ]

[1]+  Done                    bin/mysqld_safe --user=mysql

[root@donghao244 mysql]# netstat -tupln |grep 3306  //服务 已关闭

[root@donghao244 mysql]# service  mysqld start //测试开启服务

Starting MySQL...                                          [  OK  ]

[root@donghao244 mysql]# netstat -tupln |grep 3306  查看端口及服务状态

tcp        0      0 :::3306                     :::*                        LISTEN      4456/mysqld        

[root@donghao244 mysql]# chkconfig  --list |grep mysqld  //查看加入控制列表

[root@donghao244 mysql]# chkconfig  --add  mysqld

[root@donghao244 mysql]# chkconfig  --list |grep mysqld

mysqld          0:off 1:off 2:on 3:on 4:on 5:on 6:off

[root@donghao244 mysql]# ll /etc/rc.d/rc3.d/  |grep mysqld

//查看mysql在3级别的情况

lrwxrwxrwx 1 root root 16 Aug  4 19:24 S64mysqld -> ../init.d/mysqld

[root@donghao244 mysql]# cat /etc/ld.so.conf.d/mysql.conf

/usr/local/mysql/lib

[root@donghao244 mysql]# ln -s  /usr/local/mysql/include   /usr/include/mysql

[root@donghao244 mysql]# ll  /usr/include/mysql

lrwxrwxrwx 1 root root 24 Aug  4 19:32 /usr/include/mysql -> /usr/local/mysql/include

[root@donghao244 mysql]# ldconfig -v  |grep mys

/usr/local/mysql/lib:

libmysqlclient.so.18 -> libmysqlclient_r.so.18.0.0

 

2.源码安装apache

①.下载并解压

wps_clip_p_w_picpath-16188

p_w_picpath

 

②.apache的编译及安装

[root@donghao244 httpd-2.2.19]# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd  --enable-so  --enable-ssl   --with-z   //检测编译

[root@donghao244 httpd-2.2.19]#make  //编译

[root@donghao244 httpd-2.2.19]#make install  //安装

③.增加调用

在“/etc/ld.so.conf.d/”下编辑“mysql” 的调用路径,内容如下:

“/usr/local/apache/lib”

检测如下:

[root@donghao244 ld.so.conf.d]# ldconfig -pv |grep apache

libaprutil-1.so.0 (libc6) => /usr/local/apache/lib/libaprutil-1.so.0

libaprutil-1.so (libc6) => /usr/local/apache/lib/libaprutil-1.so

libapr-1.so.0 (libc6) => /usr/local/apache/lib/libapr-1.so.0

libapr-1.so (libc6) => /usr/local/apache/lib/libapr-1.so

④.加入系统识别的头文件

创建连接文件

[root@donghao244 ld.so.conf.d]#ln -s  /usr/local/apache/include  /usr/include/apache

//创建连接

此时可以直接使用 “service mysqld  start 进行启动mysql”

3.源码安装php

 ①.下载并对数据包进行解压缩

wps_clip_p_w_picpath-20349

p_w_picpath 

②.编译并安装

[root@donghao244 php-5.3.7]# ./configure  --prefix=/usr/local/php  --with-apxs2=/usr/local/apache/bin/apxs  --with-mysql=/usr/local/mysql  --with-mysqli=/usr/local/mysql/bin/mysql_config  --enable-mbstring=all

//检测编译环境

[root@donghao244 php-5.3.7]#make   //编辑

[root@donghao244 php-5.3.7]#make install  //安装

4.lamp环境测试

①.检测apache调用php

修改apache的配置脚本

vim  /etc/httpd/httpd.conf 如下:

166 AddType application/x-httpd-php   .php //添加对“php”格式文件的支持

167 <IfModule dir_module>

168     DirectoryIndex index.php index.html   //将“.php” 格式的文件设为apache的默认格式

169 </IfModule>

修改apache的默认主页 index.html 如下:

<html><body><h1>It works!</h1></body></html>

<?php

phpinfo();  //调用破php信息的函数

?>

测试页:

wps_clip_p_w_picpath-22494

②.测试apache连接mysql

 

[root@donghao244 htdocs]# cat index.php

<html><body><h1>It works!</h1></body></html>

<?php

phpinfo();

$link=mysql_connect('127.0.0.1','root','');

if($link)

echo "oh la la !!!--ok--";

else

echo "sorry!!!hehe,please ...";

?>

[root@donghao244 htdocs]# /usr/local/apache/bin/apachectl stop 

//关闭apache

[root@donghao244 htdocs]# /usr/local/apache/bin/apachectl start

//启动apache

[root@donghao244 htdocs]# service mysqld stop //关闭mysql

Shutting down MySQL....                                    [  OK  ]

测试:

wps_clip_p_w_picpath-25760

 

[root@donghao244 htdocs]# service mysqld start //开启mysql

Starting MySQL...                                          [  OK  ]

测试:

wps_clip_p_w_picpath-25831

[root@donghao244 htdocs]# /usr/local/mysql/bin/mysqladmin  -u  root -p password 123

Enter password:

//对mysql加密 ,密码为“123”

[root@donghao244 htdocs]# /usr/local/mysql/bin/mysql  -u  root -p

Enter password:

Welcome to the MySQL monitor.  Commands end with ; or \g.

Your MySQL connection id is 3

Server version: 5.5.15-log MySQL Community Server (GPL)

Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql&gt; \q

Bye

测试:

wps_clip_p_w_picpath-26681

图片内容如下

Warning: mysql_connect() [function.mysql-connect]: Access denied for user 'root'@'localhost' (using password: NO) in /usr/local/apache/htdocs/index.php on line 3
sorry!!!hehe,please ...

//修改密码造成的问题

[root@donghao244 htdocs]# cat index.php

<html><body><h1>It works!</h1></body></html>

<?php

$link=mysql_connect('127.0.0.1','root','123'); //添加账号密码!!!

if($link)

echo "oh la la !!!--ok--";

else

echo "sorry!!!hehe,please ...";

phpinfo();

?>

wps_clip_p_w_picpath-27102

 

×××的环境已经完成

实验终结:

1.selinux关闭,防火墙关闭

2.额调用与头文件的系统查找路径及位置

3.系统方式启动mysql的复制名称及路径要正确!!!

4.rpm包安装的mysql。需要卸载。或重新启动!!!

5.源码安装的mysql的启动方式不能连续执行“start”。结果会提示找不到“*.PID*”。解决方式---》^^!!!重启。

请关注下一个博客在此环境下的论坛架构!!!

嗯,韩宇说的对呀!