[color=red]全文转自:http://blog.csdn.net/wanghao72214/category/510248.aspx[/color]

application server采用j2ee架构技术,使用了免费的resin2.1.17搭建,并采用自行开发的缓存系统进行负载均衡,webserver 采用了重量级的apache 和轻量级的lighttpd。动态内容交由apache处理,静态内容(比如图片、css、js)等交由lighttpd处理。

以下是主要配置参数和建议:

一、java应用服务器,建议用resin2.1.17,如果有钱,可以买一个resin3的license,否则resin3比resin2慢,也可以考虑使用Glassfish,这个和resin性能差别比较小,tomcat还是不行。
如果缓存需要使用特别大的内存,建议用64位操作系统。32位jdk理论上最多使用4G内存,实际上只能用3G,3G还要分成两部分,一部分是native,剩下一部分才是Xmx这个参数定义的,配置不好
就经常出错,系统会停顿6-10秒,甚至jvm会因为native内存不够而崩溃(实际这种情况linux有的是剩余内存),这里我应用我的一些配置经验,如下:(以下内容csdn死活审核不过,疯了)

1:串行垃圾回收,也就是默认配置,完成10万request用时153秒,JVM参数配置如下:(略)

这种配置一般在resin启动24小时内似乎没有大问题,网站可以正常访问,但查看日志发现,在接近24小时时,Full GC执行越来越频繁,大约每隔3分钟就有一次Full GC,每次Full GC系统会停顿6秒左右,作为一个网站来说,用户等待6秒恐怕太长了,所以这种方式有待改善。MaxTenuringThreshold=7表示一个对象如果在救助空间移动7次还没有被回收就放入年老代,GCTimeRatio=19表示java可以用5%的时间来做垃圾回收,1/(1+19)=1 /20=5%。

2:并行回收,完成10万request用时117秒,配置如下:(略)
并行回收我尝试过多种组合配置,似乎都没什么用,resin启动3小时左右就会停顿,时间超过10 秒。也有可能是参数设置不够好的原因,MaxGCPauseMillis表示GC最大停顿时间,在resin刚启动还没有执行Full GC时系统是正常的,但一旦执行Full GC,MaxGCPauseMillis根本没有用,停顿时间可能超过20秒,之后会发生什么我也不再关心了,赶紧重启resin,尝试其他回收策略。

3:并发回收,完成10万request用时60秒,比并行回收差不多快一倍,是默认回收策略性能的2.5倍,配置如下:(略)
这个配置虽然不会出现10秒连不上的情况,但系统重启3个小时左右,每隔几分钟就会有5秒连不上的情况,查看gc.log,发现在执行ParNewGC时有个promotion failed错误,从而转向执行Full GC,造成系统停顿,而且会很频繁,每隔几分钟就有一次,所以还得改善。UseCMSCompactAtFullCollection是表是执行Full GC后对内存进行整理压缩,免得产生内存碎片,CMSFullGCsBeforeCompaction=N表示执行N次Full GC后执行内存压缩。

4:增量回收,完成10万request用时171秒,太慢了,配置如下 :(略)
似乎回收得也不太干净,而且也对性能有较大影响,不值得试。

5:并发回收的I-CMS模式,和增量回收差不多,完成10万request用时170秒。
配置如下:(略)

采用了sun推荐的参数,回收效果不好,照样有停顿,数小时之内就会频繁出现停顿,什么sun推荐的参数,照样不好使。

6:递增式低暂停收集器,还叫什么火车式回收,不知道属于哪个系,完成10万request用时153秒。配置如下:(略)
该配置效果也不好,影响性能,所以没试。

7:相比之下,还是并发回收比较好,性能比较高,只要能解决ParNewGC(并行回收年轻代)时的promotion failed错误就一切好办了,查了很多文章,发现引起promotion failed错误的原因是CMS来不及回收(CMS默认在年老代占到90%左右才会执行),年老代又没有足够的空间供GC把一些活的对象从年轻代移到年老代,所以执行Full GC。CMSInitiatingOccupancyFraction=70表示年老代占到约70%时就开始执行CMS,这样就不会出现Full GC了。SoftRefLRUPolicyMSPerMB这个参数也是我认为比较有用的,官方解释是softly reachable objects will remain alive for some amount of time after the last time they were referenced. The default value is one second of lifetime per free megabyte in the heap,我觉得没必要等1秒,所以设置成0。配置如下:略

8:第7的配置还有可能因为救助空间不够造成promotion failed,我索性把救助空间去掉,通过调整SurvivorRatio和MaxTenuringThreshold实现,设置如下,总之还是要根据实际情况做出适合的调整。下面是我的最终配置,已经非常稳定,如果改成64位系统,内存可以加大。但隔三差五重启resin还是有必要的,Perm空间总会变满的。

二、apache的一些配置和技巧。
安装apache时根据情况带几个参数,网上也有其他优化参数,但估计性能差不了多少,如下
./configure --prefix=/usr/local/apache2.2.10 --enable-so --enable-deflate --enable-rewrite --enable-expires
我做过测试,apache自带的mod_mem_cache不太好使,最大使用内存不到200M时就会有问题,内存使用量突然下降,所以
图片服务器建议不要用apache,用lighttpd或者nginx会更好。lighttpd+memcached的方式我就没配成功过,nginx+memcached能从缓存
里获取,但不能set到缓存,所以我用的是lighttpd+mod_mem_cache(需要把lighttpd打个补丁),稍后作详细介绍。

apache简单防DDOS攻击的配置,需要从网上找一个mod_evasive20模块,用/usr/local/apache/bin/apxs -cia mod_evasive20.c安装,一般情况下没有必要配置这玩意。
<IfModule mod_evasive20.c>
DOSHashTableSize 10000
DOSPageCount 2
DOSSiteCount 50
DOSPageInterval 1
DOSSiteInterval 1
DOSBlockingPeriod 10
DOSEmailNotify webmaster@xxx.com
DOSLogDir /var/log/mod_dosevasive.log
</IfModule>

apache防sql注入攻击的配置,需要安装mod_security模块
<IfModule mod_security.c>
SecFilterEngine On
SecFilterCheckURLEncoding On
SecFilterForceByteRange 32 126
SecFilterCheckUnicodeEncoding On
SecServerResponseToken Off
SecAuditEngine RelevantOnly
SecAuditLog logs/audit_log
SecFilterDebugLog logs/modsec_debug_log
SecFilterDebugLevel 0
SecFilterDefaultAction "deny,log,status:406"
SecFilter /etc/*passwd
SecFilter /bin/*sh
SecFilter "\.\./"
SecFilter "<( |\n)*script"
SecFilter "<(.|\n)+>"
SecFilter "delete[[:space:]]+from"
SecFilter "insert[[:space:]]+into"
SecFilter "select.+from"
SecFilter "union[[:space:]]+from"
SecFilter "drop[[:space:]]"
SecFilterSelective "HTTP_USER_AGENT|HTTP_HOST" "^$"
</IfModule>

加大apache最大连接数的配置,如果选择的是preworker工作方式。preworker和worker的区别就不讲了。apache2.0以上直接设置ServerLimit即可,apache2.0以前还要修改源代码才能使修改
的ServerLimit生效,建议应用服务器用apache2.0吧,性能差不了多少。

<IfModule mpm_prefork_module>
ServerLimit 20000 #ServerLimit据说要放第一行
StartServers 50
MinSpareServers 50
MaxSpareServers 100
MaxClients 10000
MaxRequestsPerChild 10000
</IfModule>

压缩传输的配置,这个做为网站来说非常重要,它是不压缩传输大小的20%左右,也就是说用户访问一个网站速度快了5倍,不配置不行,但是图片不能做压缩了。

<IfModule mod_deflate.c>
SetOutputFilter DEFLATE
DeflateCompressionLevel 3
DeflateFilterNote Input instream
DeflateFilterNote Output outstream
DeflateFilterNote Ratio ratio
LogFormat '"%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" "%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate
# Netscape 4.x has some problems...
BrowserMatch ^Mozilla/4 gzip-only-text/html
# Netscape 4.06-4.08 have some more problems
BrowserMatch ^Mozilla/4\.0[678] no-gzip
# MSIE masquerades as Netscape, but it is fine
#BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
# NOTE: Due to a bug in mod_setenvif up to Apache 2.0.48
# the above regex won't work. You can use the following
# workaround to get the desired effect:
BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html
# Don't compress images, java scripts and style sheets
SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png|js|css)$ no-gzip dont-vary

# Make sure proxies don't deliver the wrong content
# this needs mod_headers but it's very important
# so I don't add a IfModule around it
#Header append Vary User-Agent env=!dont-vary
#CustomLog logs/deflate_log.log deflate
#CustomLog "|/usr/local/cronolog/sbin/cronolog /usr/local/apache2.0.59_2/logs/www.shedewang.com.access.log.%Y%m%d" deflate env=!IMAG
</IfModule>

apache配置mod_mem_cache,这个模块不太好使,建议不用
<IfModule mod_cache.c>
#CacheForceCompletion 100
CacheDefaultExpire 3600
CacheMaxExpire 86400
CacheLastModifiedFactor 0.1
CacheIgnoreNoLastMod on
<IfModule mod_mem_cache.c>
CacheEnable mem /
MCacheSize 2000000
MCacheMaxObjectCount 10000
MCacheMinObjectSize 1000
MCacheMaxObjectSize 512000
MCacheRemovalAlgorithm LRU
</IfModule>
</IfModule>

CacheEnable: 启动 mod_cache,其后接两个参数。第一个参数指定快取的种类,应设为 mem (记忆体快取) 或 disk (磁碟快取) 之其一;第二个参数指定使用快取的 URI 路径,如果对整个网站 (或虚拟主机) 进行快取,简单指定为根目录(/) 即可。
CacheForceCompletion: 这个值指定当 HTTP request 被取消时,内容的产生动作要完成的百分比;预设是 60(%)。
CacheDefaultExpire: 指定快取的预设过期秒数;预设值是一小时 (3600)。
CacheMaxExpire: 指定快取最大的过期秒数;预设值是一天 (86400)。
CacheLastModifiedFactor: 用来从回应里 Last Modified 资讯算出 expire date。
计算方式是:expire period (过期时距) = 最后更新后至今的时间间距 * CacheLastModifiedFactor
而expire date = 目前时间 + expire period
不过无论如何,过期时间不能超过 CacheMaxExpire 的设定值。

配置mod_expires模块

mod_expires可以减少10%左右的重复请求,让重复的用户对指定的页面请求结果都CACHE在本地,根本不向服务器发出请求,这一点特别实用在图片服务器上。

mod_expires的安装配置:
<IfModule mod_expires.c>
# turn on the module for this directory
ExpiresActive on

# cache common graphics for 3 days
ExpiresByType image/jpg "access plus 365 days"
ExpiresByType image/gif "access plus 365 days"
ExpiresByType image/jpeg "access plus 365 days"
ExpiresByType image/png "access plus 365 days"

</IfModule>

四:图片服务器的安装
图片服务器是相对比较容易的,也是最稳定的服务器了,我建议用lighttpd或者nginx,不要用apache。
lighttpd不加cache也可以撑到50-80m没秒,如果比这个流量还大,建议用lighttpd+mod_mem_cache或者
lighttpd+memcached,但是后者我没有配成功,启动不了。nginx和memcached比较容易整合,但是又不能自动
set到memcached里去,还要自己用php或者java程序把图片放入到memcached里去,不够智能。我用的是lighttpd1.4.20+mod_mem_cache,可以
迟到4G多内存,比apache强多了。安装lighttpd的mod_mem_cache补丁如下
tar -xzvf lighttpd-1.4.20.tar.gz
cp lighttpd-1.4.20.mod_mem_cache.patch lighttpd-1.4.20
patch -p0 < lighttpd-1.4.20.mod_mem_cache.patch
sh autogen.sh
./configure --prefix=/usr/local/lighttpd-1.4.20
make && make install

配置文件增加如下段:
server.modules = (
# "mod_rewrite",
# "mod_redirect",
# "mod_alias",
"mod_access",
# "mod_cml",
# "mod_trigger_b4_dl",
# "mod_auth",
# "mod_status",
# "mod_setenv",
# "mod_fastcgi",
# "mod_proxy",
# "mod_simple_vhost",
# "mod_evhost",
# "mod_userdir",
# "mod_cgi",
# "mod_compress",
# "mod_ssi",
# "mod_usertrack",
"mod_expire",
# "mod_secdownload",
# "mod_rrdtool",
"mod_accesslog",
"mod_mem_cache" ) #注意加上这个

#然后增加如下配置段
mem-cache.filetypes = ("application/x-javascript", "text/css", "text/html", "text/javascript", "image/jpg", "image/jpeg", "image/gif", "image/png", "image/bmp")

mem-cache.enable = "enable"

#4096M
mem-cache.max-memory = 4096

#512k
mem-cache.max-file-size = 512

#lru count
mem-cache.lru-remove-count = 100000

#1 day
mem-cache.expire-time = 1440

五:nginx可以做负载均衡,按照IP做负载均衡就不用管分布式session的问题,这里就不做讲述了,需要的时候查查就行。

六:网上说的lighttpd+squid+apache可以怎么怎么加速网站,我配置了一下,根本没用,第一层的lighttpd只要必须经过squid,即使squid的缓存里有也会很慢,还没有直接一个lighttpd快。
下面附上squid3.0配置成功的配置文件,可以实现缓存,如果没有缓存可以往81这个端口转发。
#visible_hostname www.abc.com
visible_hostname localhost
http_port 3128 vhost vport
cache_mem 2048 MB
maximum_object_size_in_memory 2048 KB
memory_replacement_policy lru
#cache_dir ufs /tmp 512 16 256
cache_dir ufs /usr/local/squid/var/cache 2048 16 256
max_open_disk_fds 0
minimum_object_size 0 KB
maximum_object_size 32768 KB
logformat combined %>a %ui %un [%tl] "%rm %ru HTTP/%rv" %Hs %<st "%{Referer}>h" "%{User-Agent}>h" %Ss:%Sh
access_log /usr/local/squid/var/logs/access_log combined
cache_log /usr/local/squid/var/logs/cache.log
pid_filename /usr/local/squid/var/logs/squid.pid
#cache_store_log none
cache_peer 127.0.0.1 parent 81 0 no-query no-digest originserver name=www
#cache_peer_domain www www.abc.com
cache_peer_domain localhost
cache_peer_access www allow all
http_access allow all
acl QUERY urlpath_regex .exe
cache deny QUERY
cache_effective_user nobody
cache_effective_group nobody

领先的易物网站-舍得网基于J2ee Resin实现的技术内幕相关推荐

  1. html5网站测试工具,基于HTML5网页的前端技术测试技巧

    51Testing软件测试网)QTQ e-c HTML5是一种最新发布网页构架的普遍模型,是构建对程序.对用户都更有价值的数据驱动的的前端技术框架,它的价值在于融合CSS/javaScript/fla ...

  2. 在线电影推荐网 使用Python+Django+Mysql开发技术 在线电影推荐系统 电影网站推荐系统 基于用户、物品的协同过滤推荐算法 个性化推荐算法开发 机器学习、人工智能、大数据分布式开发

    在线电影推荐网 使用Python+Django+Mysql开发技术 在线电影推荐系统 电影网站推荐系统 基于用户.物品的协同过滤推荐算法 个性化推荐算法开发 机器学习.人工智能.大数据分布式开发 Mo ...

  3. 简单在线音乐推荐网 基于用户、物品的协同过滤推荐算法 使用Python+Django+Mysql开发技术 在线音乐推荐系统 音乐网站推荐系统 个性化推荐算法开发 人工智能、大数据分布式、机器学习开发

    简单在线音乐推荐网 基于用户.物品的协同过滤推荐算法 使用Python+Django+Mysql开发技术 在线音乐推荐系统 音乐网站推荐系统 个性化推荐算法开发 人工智能.大数据分布式.机器学习开发S ...

  4. 大数据智能易物平台匀易天下上线

    11月7日,北京匀加速科技有限公司第二代大数据智能易物平台匀易天下上线,该公司致力于打造易物信息共享.共增.共赢的商业生态圈,服务各地的传统企业.农产品企业.实体店及大众. 传统数据分析电子商务平台及 ...

  5. 移动上网青睐社交网站 校内网位列中文第一

    作者:徐新事 | 出处:DoNews | 2008-5-28 0:11:19 DoNews 5月27日消息 日前,Opera公布了今年第一季度移动浏览方面的趋势报告.该报告中,社交网站成为移动网络流量 ...

  6. java-net-php-python-java“校园易购”网站开发计算机毕业设计程序

    java-net-php-python-java"校园易购"网站开发计算机毕业设计程序 java-net-php-python-java"校园易购"网站开发计算 ...

  7. LinuxProbe 0x14 虚拟网站主机功能(基于端口)、Vsftpd服务传输文件、TFTP简单文件传输协议

    虚拟网站主机功能 基于端口号 基于端口号的虚拟主机功能可以让用户通过指定的端口号来访问服务器上的网站资源.在使用Apache配置虚拟网站主机功能时,基于端口号的配置方式是最复杂的. 因此我们不仅要考虑 ...

  8. java计算机毕业设计好物网站源码+mysql数据库+系统+lw文档+部署

    java计算机毕业设计好物网站源码+mysql数据库+系统+lw文档+部署 java计算机毕业设计好物网站源码+mysql数据库+系统+lw文档+部署 本源码技术栈: 项目架构:B/S架构 开发语言: ...

  9. 【酷易物联-arduino-sdk教程】利用自动生成的sdk模板点灯和上传数据

    目前更新了SDK生成代码功能,很适合新手入门,特别推荐. 工作准备: 开发板:ESP8266 开发环境:ESP-8266 arduino环境 arduino软件安装 接入设备: 选择模板,点灯,其他随 ...

最新文章

  1. python: 关于解决‘\u‘开头的字符串转中文的方法
  2. python3 filter 列表元素过滤(匹配)用法
  3. C++ 复数类运算符重载
  4. defer 的前世今生
  5. path manipulation怎么解决_干货!终于!解决macOS下pyenv安装python3.8.2缺少tkinter模块的问题!...
  6. Spring Boot 面试题
  7. 产品经理在早期如何快速学习?
  8. oracle crs 命令,ORACLE RAC CRSCTL 命令使用 及 执行的用户
  9. 引用管理器没有程序集_程序员必背英语单词不会,就别说你是程序员!
  10. NetCore 统一处理 webapi 返回null 转为“”
  11. 【学术分享】写论文必须养成的十大良好写作习惯
  12. 用swaks进行发件人伪造
  13. 【信源编码技术】实验1-浊音清音爆破音的时域及频域特性分析
  14. java deprecated 注释_Java注释中的@deprecated与源代码中的@Deprecated
  15. rand函数和srand函数详解
  16. CANopen协议介绍
  17. 笔记本电脑黑屏基础处理
  18. 学科实践活动感悟50字_包饺子实践活动感悟
  19. bzoj 2121 字符串游戏(字符串dp)
  20. HBuilderX的介绍与语法提示

热门文章

  1. 基于PCE的SDN演进方式
  2. NB-IoT费控智能电表功能介绍及远程拉合闸控制的应用
  3. rov 调试单个电机
  4. 最新版Maven3.6.3下载与安装
  5. GreenBrowserMaxthon评测(转)
  6. 跨平台应用开发进阶(三十):uni-app 实现集成火山视频直播服务
  7. 2020年8月装配式工程师报名考试工作的通知
  8. 多商户商城小程序如何操作运营?电商系统源码发展趋势
  9. 算法导论Van Emde Boas树
  10. 两个矩阵相乘在空间意义