apache 双cpu 优化 性能调优
一、...AS release 4 apache+MYsql+PHP的安装和优化
软件版本:httpd-2.2.3.tar.gz
mysql-5.0.18.tar.gz
php-5.0.4.tar.gz
1安装mysql
shell#tar xzvf mysql-5.0.15.tar.gz
#解开安装包
shell#cd mysql-5.0.1
shell#./configrue--prefix=/usr/local/mysql
shell# make make install
shell#make install
#进入安装目录,设置安装路径.编译并安装
shell#groupadd mysql
shell#useradd-g mysql mysql
#新建名为mysql的组,并新建名为mysql的用户,并且默认属于mysql组
shell#chgrp-R mysql/usr/local/mysql
#改变/usr/local/mysql及下属文件与目录的属组
shell#cp support-files/my-large.cnf/etc/my.cnf
#copymy-large.cnf到/etc中,替换原有的my.cnf
shell#scripts/mysql_install_db
#建立初始数据
shell#chown-R mysql:mysql/usr/local/mysql/var
shell#cp support-files/mysql.server/etc/init.d/mysqld
#copymysql.server到init.d目录中并重命名为mysqld,启动文件
shell#chmod 755/etc/init.d/mysqld
#设置启动文件的权限有为755
shell#chkconfig--add mysqld
shell#chkconfig mysqld on
#把此服务添加到系统启动中,add为添加至/etc/rc.d/init.d中,on默认在3/5级别服务默认启动
shell#/etc/init.d/mysqld start
shell#/usr/local/mysql/bin/mysqld_safe
启动myhsql
shell#/usr/local/mysql/bin/mysqladmin-u root password 123
默认root用户密码为空,设置密码为123
shell#/usr/local/mysql/bin/mysql-u root-p
#输入上面设置的123后.以root身份登陆
shell#./mysqladmin-u root-p password 456
#修改mysql root用户密码为456,在提示框中要输入原密码,
mysql grant select on test.* to'ttt'@'%' identified by'ttt' with grant option;
#添加一个名称为ttt,密码为ttt的mysql账户,对test数据库有修改权限
2安装apache-2.2.3
shell#tar xzvf httpd-2.2.3.tar.gz
shell#cd httpd-2.2.3
shell#./configure--prefix=/usr/local/apache--enable-so
shell#make make install
#解包设置安装信息编译安装
shell#cp/usr/local/apache/bin/apachectl/etc/init.d/httpd
#把服务cp至启动文件中
shell#chmod 755/etc/init.d/httpd
#设置服务权限
3安装php
shell#tar xvzf php-5.0.4.tar.gz
shell#cd php-5.0.4
shell#./configure--with-mysql=/usr/local/mysql--with- apxs2=/usr/local/apache/bin/apxs--prefix=/usr/local/php
shell#make make instal
#解包设置安装信息编译安装
shell#echo
AddType application/x-httpd-php.php/usr/local/apache/conf/httpd.conf
shell#echo AddType application/x-httpd-php.sulpx/usr/local/apache/conf/httpd.conf
shell#echo AddType application/x-httpd-php-source.phps/usr/local/apache/conf/httpd.conf
shell#echo DirectoryIndex index.php index.html index.htm index.html.var/usr/local/apache/conf/httpd.conf
#在http.conf中加入对php的支持
shell#/usr/local/apache/bin/apachectl start
#启动http
测试,在/usr/local/apache/htdocs下建一文件名为test.php,内容为:? phpinfo();?,然后在打开IE输入本机IP地址查看,如显示php页面,则建立成功
网上文档:
#tar xzvf libpng-1.2.8-config.tar.gz
#tar xzvf freetype-2.1.9.tar.gz
#tar xzvf zlib-1.2.2.tar.gz
#tar xzvf gd-2.0.33.tar.gz
#tar xzvf httpd-2.0.54.tar.gz
#tar xzvf php-5.0.4.tar.gz
#tar xzvf mysql-5.0.15.tar.gz#########default setup/change my.cnf for onlyone please
cd mysql-5.0.18
./configure--prefix=/usr/local/mysql--with-charset=utf8--with-extra-charsets=gbk,gb2312,big5 make make install
groupadd mysql
useradd-g mysql mysql
chgrp-R mysql/usr/local/mysql
cp support-files/my-large.cnf/etc/my.cnf
scripts/mysql_install_db
chown-R mysql:mysql/usr/local/mysql/var
cp support-files/mysql.server/etc/init.d/mysqld
chmod 755/etc/init.d/mysqld
/usr/local/mysql/bin/mysqld_safe
-----------------------------chkconfig--add mysqld
chkconfig mysqld on
------------------------------
#########support soft setup
cd/root/install/libpng-1.2.8-config
./configure make make install
cd/root/install/freetype-2.1.9
./configure--prefix=/usr/local/freetype-2.1.9 make make install
cd/root/install/zlib-1.2.2
./configure--prefix=/usr/local/zlib-1.2.2 make; make install
cd/root/install/jpeg-6b
cp-R/root/install/jpeg-6b/usr/local/
mkdir-p/usr/local/man/man1
./configure--enable-shared--enable-static make make install
cd/root/install/gd-2.0.33
./configure--prefix=/usr/local/gd-2.0.33--with-freetype=/usr/local/freetype-2.1.9 make make install#########apache setup
cd/root/install/httpd-2.2.3
./configure--prefix=/usr/local/apache--enable-so--enable-rewrite make make install
#rm-f/etc/init.d/httpd
#cp/usr/local/apache/bin/apachectl/etc/init.d/httpd
#chmod 755/etc/init.d/httpd
#########php setup
cd/root/install/php-5.0.4
./configure--with-mysql=/usr/local/mysql--enable-trans-sid--enable-track-vars--with-png-dir=/usr/local/bin--with-gd=/usr/local/gd-2.0.33--with-jpeg-dir=/usr/local/jpeg-6b--with-extension_dir=/usr/local/lib/extension--with-freetype-dir=/usr/local/freetype-2.1.9--with-zlib-dir=/usr/local/zlib-1.2.2--with-apxs2=/usr/local/apache/bin/apxs--prefix=/usr/local/php--with-config-file-path=/usr/local/php--enable-force-cgi-redirect--disable-cgi--with-gettext--with-gdbm make make install
sed-e's/variables_order="EGPCS"/variables_order="ECPGS"/g'-e's/register_globals= Off/register_globals= On/g' php.ini-dist/usr/local/php/bin/php.ini
echo AddType application/x-httpd-php.php/usr/local/apache/conf/httpd.conf
echo AddType application/x-httpd-php.sulpx/usr/local/apache/conf/httpd.conf
echo AddType application/x-httpd-php-source.phps/usr/local/apache/conf/httpd.conf
echo DirectoryIndex index.php index.html index.htm index.html.var/usr/local/apache/conf/httpd.conf
/usr/local/apache/bin/apachectl stop
/usr/local/apache/bin/apachectl start
./configure--with-mysql=/usr/local/mysql--enable-trans-sid--enable-track-vars--with-png-dir=/usr/local/libpng-1.2.5--with-gd=/usr/local/gd-2.0.33--with-jpeg-dir=/usr/local/jpeg-6b--with-extension_dir=/usr/local/lib/extension--with-freetype-dir=/usr/local/freetype-2.1.9--with-zlib-dir=/usr/local/zlib-1.2.2--with-apxs2=/usr/local/apache/bin/apxs--prefix=/usr/local/php--with-config-file-path=/usr/local/php--enable-force-cgi-redirect--disable-cgi--with-gettext--with-gdbm make make install [LAMP平台]LAMP这个词的由来最早始于德国杂志“c't Magazine”,Michael Kunze在1990年最先把这些项目组合在一起创造了LAMP的缩写字。这些组件虽然并不是开开始就设计为一起使用的,但是,这些开源软件都可以很方便的随时获得并免费获得。这就导致了这些组件经常在一起使用。在过去的几年里,这些组件的兼容性不断完善,在一起的应用情形变得非常普便。为了改善不同组件之间的协作,已经创建了某些扩展功能。目前,几乎在所有的Linux发布版中都默认包含了“LAMP stack”的产品。这些产品组成了一个强大的Web应用程序平台LAMP平台由四个组件组成,呈分层结构。每一层都提供了整个软件栈的一个关键部分:Linux:Linux处在最低层,提供操作系统。其他每个组件实际上也在 Linux上运行。但是,并不一定局限于 Linux,如有必要,其他组件也可以在 Microsoft? 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提供的一些特性的动态内容。[检测工具]为了得到完整的调试结果,建议你采用 ApacheBench或者 httperf之类的软件。如果你对非 LAMP架构的服务器测试有兴趣的话,建议你采用微软的免费软件: Web Application Stress Tool(需要 NT或者 2000)。(其它服务器测试工具)
检测 Apache,采用 top d 1显示所有进程的 CPU和内存情况。另外,还采用 apachectl status命令[硬件优化]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 off15、如果网络拥挤,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守护进程。
二、linux***apache***性能调优***8G***8核***的服务器
[检测工具]
为了得到完整的调试结果,建议你采用 ApacheBench或者 httperf之类的软件。如果你对非 LAMP架构的服务器测试有兴趣的话,建议你采用微软的免费软件: Web Application Stress Tool(需要 NT或者 2000)。(其它服务器测试工具)
检测 Apache,采用 top d 1显示所有进程的 CPU和内存情况。另外,还采用 apachectl status命令
[硬件优化]
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文件来完成,这个文件的格式是这样的:
每一栏是一个参数,其中最重要的是前面几个参数。第一个数字是在"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文件中加入如下行:
以上的设置加大了缓冲区大小,降低了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芯片。
然后,重新编译核心,重新起动计算机,执行如下命令:
现在两块网卡已经象一块一样工作了。这样可以提高集群节点间的数据传输.bonding对于服务器来是个比较好的选择,在没有千兆网卡时,用两块100兆网卡作bonding,可大大提高服务器到交换机之间的带宽.但是需要在交换机上设置连接bonding网卡的两个子口映射为同一个虚拟接口。编辑/etc/modules.conf文件,加入如下内容,以使系统在启动时加载Bonding模块。
“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等。
三、Apache出现的CPU高占用率该怎么解决
您好,很高兴为您解答。
1. Apache与WinSock v2相冲突
Apache官方提供的手册中提到,在Windows系统下Apache2.x为了提高性能而使用了Microsoft WinSock v2 API,但是一些常见的防火墙软件会破坏他的正确性,从而使得Apache出现死循环操作造成CPU100%。
其错误提示如下所示:
[error](730038)An operation was attempted on something that is not a socket.: winnt_accept: AcceptEx failed. Attempting to recover.
[error](OS 10038): Child 3356: Encountered too many errors accepting client connections. Possible causes: dynamic address renewal, or incompatible VPN or firewall software. Try using the Win32DisableAcceptEx directive.
[warn](OS 121)信号灯超时时间已到。: winnt_accept: Asynchronous AcceptEx failed.
[warn](OS 64)指定的网络名不再可用。: winnt_accept: Asynchronous AcceptEx failed.
可以依次采用下面的方法来解决上面的问题,如果进行了一步还有问题就继续下一步:
1)在httpd.conf文件中使用 Win32DisableAcceptEx禁止Apache使用 Microsoft WinSock v2 API:
<IfModulempm_winnt.c>
Win32DisableAcceptEx#禁止使用AcceptEx()
</IfModule>
2)使用System Repair Engineer(SREng)查看WinSocket供应者,如果出现非MS的陌生项则将其删除,并使用软件的“重置WinSocket”按钮进行重置。
3)卸载与Apache相冲突的杀毒软件或防火墙软件。
如果进行上面的三个步骤之后还有问题,那应该看看是不是还有下面的错误。
2.是否加载了第三方模块(so文件)
Apache2.x要求所有的第三方模块都必须是线程安全的,但有很多第三方的模块可能存在内存泄露,因此时间一长就可以极大的消耗Apache资源。所以可以采用将所有的第三方模块逐个关闭的方法看看运行一段时间之后Apache对资源的占用是否有所改善。
3.“Terminating 1 threads that failed to exit”错误
上面错误中的数字1有可能是其他数字,造成这个错误的原因是Apache在关闭并发线程的时候出现线程溢出,从而造成内存泄露,表现出来的就是Apache所占用的系统资源持续增长。
具体来说,Apache的子进程在结束当前请求之前会首先将所有的并发线程进行关闭,在关闭的时候会等待3分钟,如果3分钟之内没有将所有的线程关闭则会抛出上述的错误提示,然后强制关闭。这样就造成了内存溢出,时间一长会使得Apache所占用资源持续增长直到无法工作。这个时候可以适当将MaxRequestsPerChild的值降低,使得Apache子进程所并发的线程数量减少,从而降低该错误出现的几率。
但是这种方式并不能彻底解决问题,幸好Apache2.0.x的最新版本(2.0.63)解决了之前版本的这个问题,如果3分钟之内有线程没有关闭的话会自动根据时间情况再增加等待结束的时间直到最终将所有的线程结束。日志文件中会出现类似下面的信息:
Child1952:Waiting150moresecondsfor2workerthreadstofinish.
Child1952:Waiting120moresecondsfor1workerthreadstofinish.
Child1952:Allworkerthreadshaveexited.
4.“file.\\server\\mpm\\winnt\\child.c, line 1078, assertion"(rv>= 0)&&(rv< threads_created)" failed”错误
这个错误是Apache的一个bug(#11997),可以通过 Win32DisableAcceptEx禁止Apache使用WinSocket v2来避免此bug,具体设置见前述。
5. PHP5.2.1以上版本的libmysql.dll与MySQL5不兼容
PHP5.2.1以后的新版本(截止目前最新版本为5.2.5)中用于连接MySQL的libmysql.dll组件与MySQL5不兼容,在Apache中运行PHP的时候会造成Apache产生CPU100%的问题。
解决的方法就是从下载5.2.1版本,将压缩包中的libmysql.dll文件覆盖现在的文件,然后重启Apache就可以了。
6.病毒或木马程序命名为Apache.exe
有的时候病毒或木马程序会将其名称命名为Apache.exe文件达到一种掩饰的目的,这个时候使用第三方进程分析器查看进程的路径然后将其删除或使用杀毒软件清除就可以了。
7.程序编写不严谨造成死循环等错误
如果上面的问题都不存在Apache依然产生CPU100%的问题的话,通常来说就应该是Web程序自身的问题了,例如死循环等等。这个时候需要在日志中设置HTTP请求的文件及执行的时间,然后查找出执行时间比较长的地址进行分析排查。
日志格式设置如下:
LogFormat"%v%h%l%u%t[%Ts]\"%r\"%>s%b"vhost_common#设置程序执行时间
<VirtualHostxxx.xxx.xx.xx:80>
ServerNamexxx.xxx.com
DirectoryIndexindex.phpindex.htmlindex.htm
DocumentRoot"xxx"
#cronolog.exe用于将日志文件进行分割的应用程序,可以在下载
CustomLog"|bin/cronolog.exee:/%Y%m%d.log"vhost_common
</VirtualHost>
如若满意,请点击右侧【采纳答案】,如若还有问题,请点击【追问】
希望我的回答对您有所帮助,望采纳!
~ O(∩_∩)O~
推荐阅读