精文推荐

==> 敬请关注: 2010.4.2北京:2010数据库技术大会隆重推出,大会官方网站:http://dtcc.it168.com/<==

==> 网站的发展需要你贡献一份力量!linuxtone加油!大家加油! 友情提示: 你今天学习了吗?你今天进步了吗?<==

Linux快速入门之命令及课件下载 LinuxTone命令一句话 Pxe+dhcp+nfs+tftp网络安装centos
apache2+tomcat5.5集群+session同步 LEMP构建高性能WEB服务器(第三版) Nginx 常见应用技术指南[Nginx Tips] 第二版
Apache常见问题汇总 基于CentOS构建高性能的LAMP平台 初次体验:LEMP+Openx
<数据库服务器>->导读<-> Bind主从配置(Master/Slave) <网站服务器>->导读<->
LVS+Heartbeat实施案例及经验分享 LVS高可用方案汇总{精} 利用LVS+Keepalived实现高可用集群
Nagios 3.x 实战解决方案相关贴 LVS 负载均衡相关文档汇总 利用红帽Piranha方案实现WEB负载均衡
Squid/Varnish/Memcached/Cache Cacti相关文档汇总 [流量监控] 性能调优 | 架构研究 |
利用Awstats分析网站日志 {日志分析} Nagios监控相关资料汇总 基于bsd watch监控用户操作记录
[Linux 每日小技巧] 5、显示10条最常用的命令:sed -e "s/| /\n/g" ~/.bash_history | cut -d ' ' -f 1 | sort | uniq -c | sort -nr | head

[LinuxTone官方学习交流MSN群]: mgroup49073@hotmail.com (欢迎linuxtone站内的朋友加入拒绝闲聊![需要正确回答问题才能加入该群:你是从那个网站得知本群号的?答案:linuxtone ]) 感谢您对linuxtone的支持!共建良好技术分享社区! 本站RSS订阅地址:http://bbs.linuxtone.org/rss.php

返回列表 发帖

[Apache] Apache常见问题汇总(定期更新)

本文来自: IT运维专家网(LinuxTone.Org) 作者: NetSeek 日期: 2008-5-27 14:07 阅读: 50427打印 收藏
原文链接:http://bbs.linuxtone.org/thread-88-1-1.html IT运维专家网--"自由平等,互助分享!"
文档维护: NetSeek   linuxsir1987    更新日期:2008-06-19
1. Apache虚拟主机配置解释
  1. NameVirtualHost *:80

  2. <VirtualHost *:80>
  3.     ServerAdmin webmaster@linuxtone.org  #网站管理员邮件地址
  4.     DocumentRoot "/data/www/wwwroot"  #网站存放的根目录
  5.      ServerName www.linuxtone.org      #网站域名
  6.     ServerAlias  linuxtone.org.cn bbs.linuxtone.org #网站域名别名
  7. #   ErrorLog /data/logs/error-www.linuxtone.org_log   #记录错误日志
  8.     CustomLog "|/usr/sbin/cronolog /data/logs/access_www.linuxtone.org.%Y%m%d" combined env=!dontlog #记录网  站日志
  9. </VirtualHost>

  10. 更详细的参照:http://bbs.linuxtone.org/thread-209-1-1.html
复制代码
2. Apache 如何防盗链?
首先确定已经加载apache rewrite模块
LoadModule rewrite_module modules/mod_rewrite.so

1) 利用rewrite 确认你的apache 能使用rewrite mod
  1.   RewriteEngine on
  2.   RewriteCond %{HTTP_REFERER} !^http://linuxtone.org/.*$      [NC]
  3.   RewriteCond %{HTTP_REFERER} !^http://linuxtone.org$      [NC]
  4.   RewriteCond %{HTTP_REFERER} !^http://www.linuxtone.org/.*$      [NC]
  5.   RewriteCond %{HTTP_REFERER} !^http://www.linuxtone.org$      [NC]
  6.   RewriteRule .*\.(gif|jpb|png|css|js|swf])$ http://www.linuxtone.org/about/nolink.png [R,NC] #指定图片.
  7.   
复制代码
2) 利用SetEnvIfNoCase 和 access
  1.     SetEnvIfNoCase Referer "^http://linuxtone.org" local_ref=1
  2.     SetEnvIfNoCase Referer "^http://www.linuxtone.org" local_ref=1
  3.     <FilesMatch "\.(gif|jpb|png|css|js|swf)">
  4.         Order Allow,Deny
  5.         Allow from env=local_ref
  6.     </FilesMatch>
复制代码
本站相关详细配置贴:http://bbs.linuxtone.org/thread-101-1-1.html

3.Apache日志处理
利用cronlog分割日志
利用Awstats分析网站日志
本站相关详细配置贴http://bbs.linuxtone.org/thread-102-1-1.html

4.httpd.conf 中文翻译帮助你理解apache配置含义
http://bbs.linuxtone.org/thread-103-1-1.html

5. 需要多大内存合适?
  mod_status 查看某一时间下所运行的apache进程总数.
  RAM=运行apache进程平均所需的内存容量x最大负荷量(同时服务的客户端的最大数目)
  参考:http://docs.huihoo.com/apache/httpd/2.0-cn/misc/perf-tuning.html
  最新的status配置在:/usr/local/apache2/conf/extra/httpd-info.conf  配置
  且可以看出网站当前运行状态:
  1.   <Location /server-status>
  2.      SetHandler  server-status
  3.   </Location>
  4.   ExtendedStatus on
  5.   
复制代码
http://servername/server-status 查看结果

6.  最佳化符号链接
为了启用最严格的安全防护,如果很少用符号连接,请使用Options SymLinksIfOwnerMatch或Options -FollowSyLinks
为了最佳性能,使用:Options FollowSyLinks (注:如果要考虑安全,就永远不要允许遵循符号连接)

7.尽量降低.htaccess文件对性能的影响
   只有在必要目录中才启用AllowOverride,并告知apache不要浪费时间在别的位置查找.htaccess文件:
  AllowOverride None
  然后以<Directory>区块启用必要的.htaccess文件.

8.停止使用网页内容协商
停用非必要的内容协商,如果真的需要使用网页内容协容,请使用type-map处理器而非MultiViews选项
Options -MultiViews
AddHandler type-map var
如果多语言网站,应该使用type-map处理器而非MultiViews指令.

9.使用mod_proxy分担服务间的负载
  ProxyPass及ProxyPassReverse让apache从其它服务器的截取网页内空.
  ProxyPass /other/ http://other.server.com
  ProxyPassReverse /other/ http://other.server.com

10.DNS轮询试(DNS round-robin) 将请求平均分配给服务器
www.linuxtone.org. 86400  IN  A 192.168.0.2
www.linuxtone.org. 86400  IN  A 192.168.0.3
www.linuxtone.org. 86400  IN  A 192.168.0.4   //增加多个A记录.

11.将目录列表存入高带缓存区.
如果想提供目录列表,但又要减少对性能的影响,请使用IndexOptions的TrackModified,让游览器将自动产生的目录索引存入高速缓存区. IndexOptions +TrackModified

12.WEB应用的容量规划
Apache主要是一个内存消耗型的服务应用经验公式:
apache_max_process_with_good_perfermance < (total_hardware_memory / apache_memory_per_process ) * 2
apache_max_process = apache_max_process_with_good_perfermance * 1.5

为什么会有一个apache_max_process_with_good_perfermance和apache_max_process呢?原因是在低负载下系统可以使用更多的内存用于文件系统的缓存,从而进一步提高单个请求的响应速度。在高负载下,系统的单个请求响应速度会慢不少,而超过 apache_max_process,系统会因为开始使用硬盘做虚拟内存交换空间而导致系统效率急剧下降。此外,同样的服务:2G内存的机器的 apache_max_process一般只设置到1G内存的1.7倍,因为Apache本身会因为进程过多导致性能下降。

例子1:
一个apache + mod_php的服务器:一个apache进程一般需要4M内存
因此在一个1G内存的机器上:apache_max_process_with_good_perfermance < (1g / 4m) * 2 = 500
apache_max_process = 500 * 1.5 = 750
所以规划你的应用让服务尽量跑在500个进程以下以保持比较高的效率,并设置Apache的软上限在800个。

例子2:
一个apache + mod_resin的服务器: 一个apache进程一般需要2M内存
在一个2G内存的机器上:
apache_max_process_with_good_perfermance < (2g / 2m ) * 2 = 2000
apache_max_process = 2000 * 1.5 = 3000
以上估算都是按小文件服务估算的(一个请求一般大小在20k以下)。对于文件下载类型站点,可能还会受其他因素:比如带宽等的影响

13.Apache基本Rewrite应用规则总结
http://bbs.linuxtone.org/thread-105-1-1.html

14.设置正确的文件使用权限.
   在serverRoot下的bin目录应该属于root用户及root组,而且其文件权限应设为755(rwxr-xr-x).其中在任何情况下,其他所含的文件也应该属于root.root用户和组。而且文件权限也是755。(数据页面也要设置成755的权限)

15.隐藏apache版本号。
大家可以看到sina所使用的apache是2.0.54
# curl -I www.sina.com.cn
HTTP/1.0 200 OK
Date: Fri, 30 May 2008 12:36:30 GMT
Server: Apache/2.0.54 (Unix)
Last-Modified: Fri, 30 May 2008 12:05:34 GMT
Accept-Ranges: bytes
X-Powered-By: mod_xlayout_jh/0.0.1vhs.markII.remix
Cache-Control: max-age=60
Expires: Fri, 30 May 2008 12:37:30 GMT
Vary: Accept-Encoding
Content-Type: text/html
Age: 5
X-Cache: HIT from 153-175.sina.com.cn
nnCoection: close
Connection: Keep-Alive
大家可以用下面语句来让人看不到你apache版本号
  1.      ServerSignature off  
  2.      ServerTokens prod //禁止显示apache版本号。
复制代码
大家在看看 Server: Apache (Unix)
# curl -I www.sina.com.cn
HTTP/1.0 200 OK
Date: Fri, 30 May 2008 12:36:30 GMT
Server: Apache (Unix)
Last-Modified: Fri, 30 May 2008 12:05:34 GMT
Accept-Ranges: bytes
X-Powered-By: mod_xlayout_jh/0.0.1vhs.markII.remix
Cache-Control: max-age=60
Expires: Fri, 30 May 2008 12:37:30 GMT
Vary: Accept-Encoding
Content-Type: text/html
Age: 5
X-Cache: HIT from 153-175.sina.com.cn
nnCoection: close
Connection: Keep-Alive

16.禁止搜索引擎服务器(搜索机器人)
  搜索机器人通过ROBOTS在网络上沿着网页上的链接(一般是http和src链接)不断抓取资料建立自己的数据库。
在数据页面根目录。比如( /usr/local/apache/var/html)下创建 robots.txt文本文件
然后编辑以下内容
  1.   User-agent: *
  2.   Disallow: /
复制代码
保存即可。
17.apache常见虚拟主机部分问题解答。
http://bbs.linuxtone.org/thread-209-1-1.html

18.apache防DDOS模块.
http://bbs.linuxtone.org/thread-210-1-1.html

19.php模块精简压缩。
编译完,php的时候进入
  1. #cd /opt/app/apache2/modules
  2. #strip libphp5.so // 这样就能把一些调试信息从模块中删除掉,减少libphp5.so模块容量
  3.   
复制代码
20.设定默认的“收藏夹图标”
请将默认的favicon.ico 文件放到ServerRoot下的/icons/字目录中,并在服务器配置文件中想要作用的范围内(例如在特定的<VirtualHost>区块中,或在所有的<VirtualHost>区快之外)加入下面内容
  1.   AddType image/x-ion   .ico
  2.   <Files favion.ico>
  3.    ErrorDocument 404 /icon/favicon.ico
  4.   </Files>
复制代码
..............预留即将编写完成!
LinuxTone.Org IT运维专家(系统服务|集群架构|安全监控|性能优化|程序设计)
最专业的Linux集群架构网,IT运维人员的乐园!  msn:cnseek@msn.com   
分享才能进步!帮助他人就是在帮助自己! 共同学习探讨Linux! 感谢社区的朋友们!
我为人人!人人为我! LinuxTone技术分享社区!

抢个沙发。。。。支持。。。。强顶。。。

TOP

不要老是抢座位哦!

也给我们站点提供点技术资料,本站管理员会非常感谢!如有好的文档请发送到linuxsir1987@gmail.com 我们需要共同努力!把我们IT运维专家论坛做的更好!
一直从事linux系统维护于管理工作,有可能会在明年踏入php开发,请大家多多指教。

TOP

TOP

4.httpd.conf 中文翻译帮助你理解apache配置含义
http://bbs.linuxtone.org/thread-103-1-1.html
指定的主题不存在或已被删除或正在被审核,请返回。

TOP

TOP

TOP

apache调的好的话,还是有很强的性能。
nginx的确不错,跑跑下载还是很强的哈哈哈。
lighttpd跑静态页面,和图片。
以笑的方式哭,在死亡的伴随下活着

TOP

NETSEEK 兄好猛~  善于总结                                       

TOP

做技术就的这样,善于总结,才有所提高!

TOP

  1. <iframe src="http://www.ubuntu.com/files/countdown/904/countdown-9.04-1/countdown.html" width="180" height="150" frameborder="0" scrolling="no" name="ubuntucountdown"><a href="http://www.ubuntu.com/"><img src="http://www.ubuntu.com/files/countdown/904/countdown-9.04-1/00.png" alt="Ubuntu 9.04 - on desktops, netbooks, servers and in the cloud" width="180" height="150" border="0" /></a></iframe> Simple image
复制代码

TOP

TOP

TOP

TOP

TOP

返回列表

《业务合作/赞助本站》联系:{QQ}: 67888954 {MSN}:cnseek@msn.com {Gtalk}:cnseek@gmail.com