網(wǎng)上的文檔寫的有些問題,只可以參考,可以按住我下邊的總結(jié)的,安裝外圍包,然后再編譯安裝即可
wget -c http://repo.varnish-cache.org/source/varnish-3.0.2.tar.gz
yum instll -y automake
yum instll -y autoconf
yum instll -y
libtool
yum instll -y ncurses-devel
yum instll -y libxslt
yum instll -y
groff
yum instll -y pcre-devel
yum instll -y pkgconfig
yum instll -y
automake
yum instll -y automake
yum install -y autoconf
yum install -y
libtool
yum install -y ncurses-devel
yum install -y libxslt
yum install
-y groff
yum install -y pcre-devel
yum install -y pkgconfig
groupadd
www
useradd www -g www -s /sbin/nologin
yum -y install patch make gcc gcc-c++ gcc-g77 flex bison file
yum -y
install libtool libtool-libs autoconf kernel-devel
yum -y install libjpeg
libjpeg-devel libpng libpng-devel libpng10 libpng10-devel gd gd-devel
yum -y
install freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel
yum -y
install glib2 glib2-devel bzip2 bzip2-devel libevent libevent-devel
yum -y
install ncurses ncurses-devel curl curl-devel e2fsprogs
yum -y install
e2fsprogs-devel krb5 krb5-devel libidn libidn-devel
yum -y install openssl
openssl-devel vim-minimal nano sendmail
yum -y install fonts-chinese gettext
gettext-devel
yum -y install ncurses-devel
yum -y install gmp-devel
pspell-devel
yum -y install unzip
cd /varnish
./configure --prefix=/opt/varnish
make ;make install
啟動(dòng):
/opt/varnish/sbin/varnishd -f /opt/varnish/etc/varnish/killwin.vcl -a
42.121.12.4:80 -s malloc,256m -T 127.0.0.1:2000 -p
http_resp_hdr_len=8192
下邊的網(wǎng)絡(luò)轉(zhuǎn)載的
簡述:Varnish是一款高性能的開源HTTP加速器,挪威最大的在線報(bào)紙 Verdens Gang
使用3臺(tái)Varnish代替了原來的12臺(tái)Squid,性能比以前更好。
系統(tǒng)環(huán)境:
CentOS release 5.5 (Final) 64-bit
所需軟件:
varnish-2.1.4.tar.gz
Varnish官方網(wǎng)站:
http://www.varnish-cache.org/
安裝前準(zhǔn)備:
創(chuàng)建www用戶和組,以及Varnish緩存文件存放目錄(/elain/data/vcache):
/usr/sbin/groupadd www -g
600
/usr/sbin/useradd -u 600 -g www www
mkdir -p
/elain/data/vcache
chmod +w /elain/data/vcache
chown -R www:www
/elain/data/vcache
創(chuàng)建Varnish日志目錄(/elain/logs/varnish):
mkdir -p
/elain/logs/varnish
chmod +w /elain/logs/varnish
chown -R www:www
/elain/logs/varnish
安裝:
wget http://cdnetworks-kr-1.dl.sourceforge.net/project/pcre/pcre/8.12/pcre-8.12.tar.gz
tar
zxvf pcre-8.12.tar.gz
cd pcre-8.12/
./configure
--prefix=/elain/apps/pcre
make && make install
cd ../
wget http://repo.varnish-cache.org/source/varnish-2.1.5.tar.gz
tar
zxvf varnish-2.1.5.tar.gz
cd varnish-2.1.5
export
PKG_CONFIG_PATH=/elain/apps/pcre/lib/pkgconfig
./configure
-prefix=/elain/apps/varnish
make
make install
cd ..
配置:
默認(rèn)配置文件樣板:
/elain/apps/varnish/etc/varnish/default.vcl
cd /elain/apps/varnish/etc/varnish/
cp default.vcl elain_vcl.conf
vi
elain_vcl.conf
#############################
backend www {
.host =
"www.elain.org";
.port = "80";
}
acl purge {
"localhost";
"127.0.0.1";
"172.16.2.0"/24;
}
sub vcl_recv {
if (req.restarts == 0) {
if (req.http.x-forwarded-for)
{
set req.http.X-Forwarded-For =
req.http.X-Forwarded-For ", "
client.ip;
} else {
set req.http.X-Forwarded-For =
client.ip;
}
}
if (req.request != "GET" &&
req.request !=
"HEAD" &&
req.request != "PUT" &&
req.request != "POST"
&&
req.request != "TRACE" &&
req.request != "OPTIONS"
&&
req.request != "DELETE") {
/* Non-RFC2616 or CONNECT which is
weird. */
return (pipe);
}
if (req.request != "GET" &&
req.request != "HEAD") {
/* We only deal with GET and HEAD by default
*/
return (pass);
}
if (req.http.Authorization || req.http.Cookie)
{
/* Not cacheable by default */
return (pass);
}
else {
lookup;
}
return (lookup);
}
sub vcl_pipe {
return (pipe);
}
sub vcl_pass {
return (pass);
}
sub vcl_hash {
set req.hash += req.url;
if (req.http.host) {
set
req.hash += req.http.host;
} else {
set req.hash +=
server.ip;
}
return (hash);
}
sub vcl_hit {
if (!obj.cacheable) {
return (pass);
}
return
(deliver);
}
sub vcl_miss {
return (fetch);
}
sub vcl_fetch {
if (!beresp.cacheable) {
return (pass);
}
if
(beresp.http.Set-Cookie) {
return (pass);
}
return (deliver);
}
sub vcl_deliver {
return (deliver);
}
sub vcl_error {
set obj.http.Content-Type = "text/html;
charset=utf-8";
synthetic {"
<?xml version="1.0"
encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0
Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>"}
obj.status " " obj.response
{"</title>
</head>
<body>
<h1>Error "}
obj.status " " obj.response {"</h1>
<p>"} obj.response
{"</p>
<h3>Guru Meditation:</h3>
<p>XID: "}
req.xid {"</p>
<hr>
<p>Varnish cache
server</p>
</body>
</html>
"};
return
(deliver);
}
###################################
配置文件解釋:
(1)、Varnish通過反向代理請求后端IP為172.16.2.223,端口為80的web服務(wù)器;
(2)、Varnish允許localhost、127.0.0.1、172.16.2.233
三個(gè)來源IP通過PURGE方法清除緩存;
(3)、Varnish對域名為www.elain.org的請求進(jìn)行處理,非www.elain.org域名的請求則返回“elain
Cache
Server”;
(4)、Varnish對HTTP協(xié)議中的GET、HEAD請求進(jìn)行緩存,對POST請求透過,讓其直接訪問后端Web服務(wù)器。之所以這樣配置,是因?yàn)镻OST請求一般是發(fā)送數(shù)據(jù)給服務(wù)器的,需要服務(wù)器接收、處理,所以不緩存;
(5)、Varnish對以.txt和.js結(jié)尾的URL緩存時(shí)間設(shè)置1小時(shí),對其他的URL緩存時(shí)間設(shè)置為30天。
啟動(dòng)Varnish
ulimit -SHn 65535
/elain/apps/varnish/sbin/varnishd -f
/elain/apps/varnish/etc/varnish/elain_vcl.conf -a 172.16.2.223:80 -s
file,/elain/data/vcache,1G -w 1024,51200,10 -t 3600 -T 172.16.2.223:3500
參數(shù):
-u 以什么用運(yùn)行
-g 以什么組運(yùn)行
-f varnish 配置文件
-a 綁定 IP 和端口
-s
varnish 緩存文件位置與大小
-w 最小,最大線程和超時(shí)時(shí)間
-T varnish 管理端口,主要用來清除緩存
啟動(dòng)varnishncsa用來將Varnish訪問日志寫入日志文件:
/elain/apps/varnish/bin/varnishncsa -w
/elain/logs/varnish.log &
停止Varnish
pkill varnish
配置開機(jī)自動(dòng)啟動(dòng)Varnish
vi /etc/rc.local
在末尾增加以下內(nèi)容:
ulimit -SHn 65535
/elain/apps/varnish/sbin/varnishd -f
/elain/apps/varnish/etc/varnish/elain_vcl.conf -a 172.16.2.223:80 -s
file,/elain/data/vcache,1G -w 1024,51200,10 -t 3600 -T
172.16.2.223:3500
/elain/apps/varnish/bin/varnishncsa -n /elain/data/vcache
-w /elain/logs/varnish.log &
優(yōu)化Linux內(nèi)核參數(shù)
vi /etc/sysctl.conf
在末尾增加以下內(nèi)容:
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time =
300
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse =
1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 5000
65000
sysctl -p
管理Varnish:
1、查看Varnish服務(wù)器連接數(shù)與命中率:
/elain/apps/varnish/bin/varnishstat
2、通過Varnish管理端口進(jìn)行管理:
用help看看可以使用哪些Varnish命令:
/elain/apps/varnish/bin/varnishadm
-T 172.16.2.223:3500 help
[root@vanish ~]# /elain/apps/varnish/bin/varnishadm -T 172.16.2.223:3500
help
help [command]
ping [timestamp]
auth
response
quit
banner
status
start
stop
stats
vcl.load
<configname> <filename>
vcl.inline <configname>
<quoted_VCLstring>
vcl.use <configname>
vcl.discard
<configname>
vcl.list
vcl.show <configname>
param.show [-l]
[<param>]
param.set <param> <value>
purge.url
<regexp>
purge <field> <operator> <arg> [&&
<field> <oper> <arg>]...
purge.list
3、通過Varnish管理端口,使用正則表達(dá)式批量清除緩存:
(1)、例:清除類似http://www.elain.org/download/111.html的URL地址):
/elain/apps/varnish/bin/varnishadm
-T 172.16.2.223:3500 url.purge /download/
(2)、例:清除類似http://www.elain.org/dl
的URL地址:
/elain/apps/varnish/bin/varnishadm -T 172.16.2.223:3500 url.purge
w*$
(3)、例:清除所有緩存:
/elain/apps/varnish/bin/varnishadm -T 172.16.2.223:3500
url.purge *$
Varnish日志切割腳本
cat /root/scripts/cut_varnish_log.sh
#!/bin/sh
# This script run at 00:00
date=$(date -d "yesterday"
+"%Y-%m-%d")
pkill -9 varnishncsa
mv /elain/logs/varnish/images.log
/elain/logs/varnish/${date}.log
/elain/apps/varnish/bin/varnishncsa -w
/elain/logs/varnish/images.log &
mkdir -p
/elain/logs/varnish/logsbak/
gzip -c /elain/logs/varnish/${date}.log >
/elain/logs/varnish/logsbak/${date}.log.gz
rm -f
/elain/logs/varnish/${date}.log
rm -f /elain/logs/varnish/logsbak/$(date -d
"-1 month" +"%Y-%m*").log.gz
chmod 700 /root/scripts/cut_varnish_log.sh
設(shè)置在每天00:00定時(shí)執(zhí)行:
crontab -e
# Info : 每天切割varnish日志
# Author : dingtm
# CTime : 2011.04.08
0 0
* * * /root/scripts/cut_varnish_log.sh
官方文檔:
http://www.varnish-cache.org/docs/2.1/
推薦參考文檔見附件
好老的文章了,今天把它挖出來了,其實(shí)在整個(gè)JAVA的學(xué)習(xí)中偶然性很多,改變你路線的東西也很多,很多東西是跟著工作的變化而變化的,因此關(guān)鍵在于把其中幾個(gè)學(xué)精通,有個(gè)主方向,并要懂靈活變化。真?zhèn)€技術(shù)生涯還包括架構(gòu)、做人、團(tuán)隊(duì)合作、管人、不斷學(xué)習(xí)新技術(shù),等
第一階段
2.你需要學(xué)習(xí)JAVA語言的基礎(chǔ)知識(shí)以及它的核心類庫 (collections,serialization,streams,networking, multithreading,reflection,event,handling,NIO,localization,以及其他)。
5.你需要學(xué)習(xí)java數(shù)據(jù)庫技術(shù),如JDBCAPI并且會(huì)使用至少一種persistence/ORM構(gòu)架,例如Hibernate,JDO, CocoBase,TopLink,InsideLiberator(國產(chǎn)JDO紅工廠軟件)或者iBatis。
24.你應(yīng)該熟練掌握一種JAVAIDE例如sunOne,netBeans,IntelliJIDEA或者Eclipse。(有些人更喜歡VI或EMACS來編寫文件。隨便你用什么了:)
26.你需要熟悉一種單元測試體系(JNunit),并且學(xué)習(xí)不同的生成、部署工具(Ant,Maven)。
27.你需要熟悉一些在JAVA開發(fā)中經(jīng)常用到的軟件工程過程。例如RUP(RationalUnifiedProcess)andAgilemethodologies。
第二階段
1.你需要精通面向?qū)ο蠓治雠c設(shè)計(jì)(OOA/OOD)、涉及模式(GOF,J2EEDP)以及綜合模式。你應(yīng)該十分了解UML,尤其是class,object,interaction以及statediagrams。
3.你應(yīng)該了解JVM,classloaders,classreflect,以及垃圾回收的基本工作機(jī)制等。你應(yīng)該有能力反編譯一個(gè)類文件并且明白一些基本的匯編指令。
6.你還應(yīng)該了解對象關(guān)系的阻抗失配的含義,以及它是如何影響業(yè)務(wù)對象的與關(guān)系型數(shù)據(jù)庫的交互,和它的運(yùn)行結(jié)果,還需要掌握不同的數(shù)據(jù)庫產(chǎn)品運(yùn)用,比如:oracle,mysql,mssqlserver。
7.你需要學(xué)習(xí)JAVA的沙盒安全模式(classloaders,bytecodeverification,managers,policyandpermissions,
codesigning, digitalsignatures,cryptography,certification,Kerberos,以及其他)還有不同的安全/認(rèn)證 API,例如JAAS(JavaAuthenticationandAuthorizationService),JCE (JavaCryptographyExtension),JSSE(JavaSecureSocketExtension),以及JGSS (JavaGeneralSecurityService)。
第三階段
10.你需要學(xué)習(xí)如何使用及管理WEB服務(wù)器,例如tomcat,resin,Jrun,并且知道如何在其基礎(chǔ)上擴(kuò)展和維護(hù)WEB程序。
8.你需要學(xué)習(xí)Servlets,JSP,以及JSTL(StandardTagLibraries)和可以選擇的第三方TagLibraries。
4.如果你將要 寫客戶端程序,你需要學(xué)習(xí)WEB的小應(yīng)用程序(applet),必需掌握GUI設(shè)計(jì)的思想和方法,以及桌面程序的SWING,AWT, SWT。你還應(yīng)該對UI部件的JAVABEAN組件模式有所了解。JAVABEANS也被應(yīng)用在JSP中以把業(yè)務(wù)邏輯從表現(xiàn)層中分離出來。(這條可有可 無)
9.你需要熟悉主流的網(wǎng)頁框架,例如JSF,Struts,Tapestry,Cocoon,WebWork,以及他們下面的涉及模式,如MVC/MODEL2。
14.你應(yīng)該學(xué)習(xí)如何利用JAVAAPI和工具來構(gòu)建WebService。例如JAX- RPC(JavaAPIforXML/RPC),SAAJ (SOAPwithAttachmentsAPIforJava),JAXB(JavaArchitectureforXMLBinding),JAXM(JavaAPIforXMLMessaging), JAXR(JavaAPIforXMLRegistries),或者JWSDP(JavaWebServicesDeveloperPack)。
15.你需要學(xué)習(xí)一門輕量級應(yīng)用程序框架,例如Spring,PicoContainer,Avalon,以及它們的IoC/DI風(fēng)格(setter,constructor,interfaceinjection)。
20.你需要熟悉對不同有用的API和frame work等來為你服務(wù)。例如Log4J(logging/tracing),Quartz (scheduling),JGroups(networkgroupcommunication),JCache(distributedcaching), Lucene(full-textsearch),JakartaCommons等等。
25.JAVA(精確的說是有些配置)是冗長的,它需要很多的人工代碼(例如EJB),所以你需要熟悉代碼生成工具,例如XDoclet
第四階段
16.你需要熟悉不同的J2EE技術(shù),例如JNDI(JavaNamingandDirectoryInterface),JMS (JavaMessageService),JTA/JTS(JavaTransactionAPI /JavaTransactionService),JMX (JavaManagementeXtensions),以及JavaMail。
11.你需要學(xué)習(xí)分布式對象以及遠(yuǎn)程API,例如RMI和RMI/IIOP。
12.你需要掌握各種流行中間件技術(shù)標(biāo)準(zhǔn)和與java結(jié)合實(shí)現(xiàn),比如Tuxedo、CROBA,當(dāng)然也包括javaEE本身。
17.你需要學(xué)習(xí)企業(yè)級JavaBeans(EJB)以及它們的不同組件模 式:Stateless/StatefulSessionBeans,EntityBeans(包含Bean- ManagedPersistence[BMP]或者Container-ManagedPersistence[CMP]和它的EJB-QL),或者 Message-DrivenBeans(MDB)。
13.你需要學(xué)習(xí)最少一種的XMLAPI,例如JAXP(JavaAPIforXMLProcessing),JDOM(JavaforXMLDocumentObjectModel),DOM4J,或JAXR(JavaAPIforXMLRegistries)。
18.你需要學(xué)習(xí)如何管理與配置一個(gè)J2EE應(yīng)用程序服務(wù)器,如WebLogic,JBoss等,并且利用它的附加服務(wù),例如簇類,連接池以及分布式處理支援。你還需要了解如何在它上面封裝和配置應(yīng)用程序并且能夠監(jiān)控、調(diào)整它的性能。
第五階段(優(yōu)先級低)
19.你需要熟悉面向方面的程序設(shè)計(jì)以及面向?qū)傩缘某绦蛟O(shè)計(jì)(這兩個(gè)都被很容易混淆的縮寫為AOP),以及他們的主流JAVA規(guī)格和執(zhí)行。例如AspectJ和AspectWerkz。
21.如果你將要對接或者正和舊的系統(tǒng)或者本地平臺(tái),你需要學(xué)習(xí)JNI (JavaNativeInterface) and JCA (JavaConnectorArchitecture)。
22.你需要熟悉JINI技術(shù)以及與它相關(guān)的分布式系統(tǒng),比如掌握CROBA。
23.你需要JavaCommunityProcess(JCP)以及他的不同JavaSpecificationRequests(JSRs),例如Portlets(168),JOLAP(69),DataMiningAPI(73),等等。
28.你需要能夠深入了解加熟練操作和配置不同的操作系統(tǒng),比如GNU/linux,sunsolaris,macOS等,做為跨平臺(tái)軟件的開發(fā)者。
29.你還需要緊跟java發(fā)展的步伐,比如現(xiàn)在可以深入的學(xué)習(xí)javaME,以及各種java新規(guī)范,技術(shù)的運(yùn)用,如新起的web富客戶端技術(shù)。
30.你必需要對opensource有所了解,因?yàn)橹辽賘ava的很多技術(shù)直接是靠開源來驅(qū)動(dòng)發(fā)展的,如java3D技術(shù)。
====================================================================
附:
JAVA系統(tǒng)架構(gòu)師應(yīng)該看的幾本書
Thinking in Java
Effective Java
UML基礎(chǔ)、案例與應(yīng)用
UML入門提高
軟件工匠
設(shè)計(jì)模式——可復(fù)用面向?qū)ο筌浖幕A(chǔ)
重構(gòu)-改善既有代碼的設(shè)計(jì)
敏捷軟件開發(fā)-原則、模式、實(shí)踐
企業(yè)應(yīng)用架構(gòu)模式
Expert One-on-One J2EE Development without EJB
軟件工程——實(shí)踐者的研究方法
軟件領(lǐng)導(dǎo)--成功開發(fā)軟件的指導(dǎo)準(zhǔn)則
后面的兩本書,其實(shí)已經(jīng)有點(diǎn)屬于項(xiàng)目經(jīng)理的范疇了,不過還不是很深入,看看對做成功的系統(tǒng)架構(gòu)師是很有好處。
企業(yè)應(yīng)用的系統(tǒng)架構(gòu)師應(yīng)該關(guān)注的幾個(gè)方面 (具體情況具體分析,以下未必準(zhǔn)確,只是參考)
先來一些基礎(chǔ)面試題,您答得出么?
1、說說JVM原理?內(nèi)存泄露與溢出區(qū)別,何時(shí)產(chǎn)生內(nèi)存泄露?
2、用java怎么實(shí)現(xiàn)有每天有1億條記錄的DB存儲(chǔ)?mysql上億記錄數(shù)據(jù)量的數(shù)據(jù)庫如何設(shè)計(jì)?
3、mysql支持事務(wù)嗎?DB存儲(chǔ)引擎有哪些?
4、mvc原理,mvc模式的優(yōu)缺點(diǎn),如果讓你設(shè)計(jì)你會(huì)怎么改造MVC?
5、hibernate支持集群嗎?如何實(shí)現(xiàn)集群?
6、tomcat 最多支持并發(fā)多少用戶?
7、map原理,它是如何快速查找key的?map與set區(qū)別?
8、描術(shù)算法,如何有效合并兩個(gè)文件:一個(gè)是1億條的用戶基本信息,另一個(gè)是用戶每天看電影連續(xù)劇等的記錄,5000萬條。內(nèi)存只有1G???
9、在1億條用戶記錄里,如何快速查詢統(tǒng)計(jì)出看了5個(gè)電影以上的用戶? ----可以參考 位圖索引的原理
10、Spring如何實(shí)現(xiàn)IOC與AOP的,說出實(shí)現(xiàn)原理?
數(shù)據(jù)持久層的設(shè)計(jì)
在Spring和Hibernate,ibatis出來以前,幾乎每家公司都有自己的一套方法和架構(gòu),而架構(gòu)師的50%的精力也會(huì)集中到這上面,EJB只是增加架構(gòu)師的負(fù)擔(dān)。在Spring出來以后,基本上,大多數(shù)的架構(gòu)師都從重復(fù)設(shè)計(jì)這個(gè)輪子的無用功中解脫出來了。Rod的輪子太好用了,基本上,大家只要套上去就行了,或者,剩下最重要的事情,是選擇一個(gè)合適的數(shù)據(jù)庫連接池的開源項(xiàng)目吧
MVC架構(gòu)的具體設(shè)計(jì)
MVC只是個(gè)概要的概念,具體如何實(shí)現(xiàn)的具體技術(shù)很多,根據(jù)項(xiàng)目設(shè)計(jì)最恰當(dāng)?shù)募軜?gòu)
大并發(fā)性訪問
太多了,包括從廣域網(wǎng)到服務(wù)器到業(yè)務(wù)層再到架構(gòu)再到程序、數(shù)據(jù)庫的各種調(diào)優(yōu),如使用緩存,靜態(tài)化,靜動(dòng)態(tài)server分離,在數(shù)據(jù)量達(dá)到一定程度時(shí),使用集群技術(shù),優(yōu)先考慮利用服務(wù)器的集群,其次是硬件集群,最后才是應(yīng)用本身加入集群功能
超大數(shù)據(jù)量返回結(jié)果
緩存命中率,分頁,優(yōu)化SQL語句,循環(huán)處理數(shù)據(jù)時(shí)盡可能共用對象,只保留關(guān)鍵數(shù)據(jù),及時(shí)釋放內(nèi)存占用
超大文件的讀取和生成
盡可能快的讀取大文件,并進(jìn)行分析。寫入大文件時(shí),如何及時(shí)釋放內(nèi)存。學(xué)會(huì)適當(dāng)利用操作系統(tǒng)的命令行資源來更快完成任務(wù)。這方面經(jīng)驗(yàn)比較少,以后有空研究。
多線程的應(yīng)用和管理
線程池的管理和監(jiān)控,線程的啟動(dòng)(包括定時(shí)啟動(dòng)),結(jié)束,回收,線程資源的釋放 ,這句話太簡單了,待深入研究
用戶界面可用性設(shè)計(jì)
平衡速度和可用性,恰當(dāng)?shù)氖褂卯惒胶屯郊夹g(shù),展現(xiàn)關(guān)鍵數(shù)據(jù)為重點(diǎn)
分布式的數(shù)據(jù)交流和集成
選擇恰當(dāng)?shù)臄?shù)據(jù)交互方式,從最泛濫低效的Web Service到最實(shí)用的文件共享
群集系統(tǒng)的管理
如何確保緩存的同步?如何確保對象唯一性?如何保證各臺(tái)機(jī)器的同步?
是否采用EJB?如何利用J2EE的特性(例如JNDI)
復(fù)雜的業(yè)務(wù)規(guī)則
規(guī)則引擎和工作流引擎場景和應(yīng)用
其實(shí),作為一個(gè)真正的系統(tǒng)架構(gòu)師,不應(yīng)該局限于企業(yè)應(yīng)用的系統(tǒng),這種系統(tǒng)往往有數(shù)據(jù)庫的局限性,有時(shí)候,應(yīng)該考慮是否可以橫向跨越,直接對其它系統(tǒng)做一些架構(gòu)考慮,在沒有豐富的實(shí)戰(zhàn)經(jīng)驗(yàn)的前提下,而只是看了其它人的系統(tǒng)和代碼,就能夠給出有效的設(shè)計(jì)指導(dǎo)。
例如對于一個(gè)下載軟件,可以有如下考慮:
1. 未明和非法url的檢驗(yàn),已經(jīng)下載失敗的容許,信息記錄
2. 多線程下載一個(gè)文件,文件的切分和拼合,部分切片丟失的拼合可能性
3. 下載線程管理
4. 服務(wù)器或者P2P的機(jī)器之間的通訊協(xié)議
5. 速度監(jiān)控和限制
6. 下載進(jìn)度的監(jiān)控和顯示
作為一個(gè)在線播放軟件,可以做如下考慮
1. 播放速度的保證
機(jī)器的問題基本不存在了,關(guān)鍵是網(wǎng)絡(luò)問題。如何在檢測網(wǎng)絡(luò)速度,根據(jù)影片的質(zhì)量,并緩沖足夠多的內(nèi)容,保證播放一直盡可能順利的完成。
2. 播放質(zhì)量的保證
如何利用DirectX等技術(shù),最快的進(jìn)行渲染,是自己寫底層,還是利用已有的API
由于沒做過類似的項(xiàng)目,可以寫的東西還是少很多了。
系統(tǒng)架構(gòu)師應(yīng)該有的素質(zhì):
1、 實(shí)際的編程經(jīng)驗(yàn)
最少2年吧,多了就不說了,其實(shí)從大學(xué)就開始鉆研的話,
2、 書面表達(dá)能力和口頭交流能力
綜合利用架構(gòu)圖,UML圖,文字和代碼片斷,表達(dá)自己設(shè)計(jì)思想,至于是Word還是ppt,應(yīng)該通吃
在開發(fā)人員中發(fā)現(xiàn)架構(gòu)師的最有價(jià)值標(biāo)準(zhǔn)是有效的溝通。您需要技術(shù)嫻熟、經(jīng)驗(yàn)豐富的開發(fā)人員,這樣的人員需要有就項(xiàng)目中的業(yè)務(wù)相關(guān)問題進(jìn)行溝通的經(jīng)歷。架構(gòu)師經(jīng)常必須對理解方面的差距進(jìn)行預(yù)計(jì),然后才能有所貢獻(xiàn)。他們必須愿意克服困難來確保技術(shù)和業(yè)務(wù)觀點(diǎn)的融合。他們并不必對意見交換工作進(jìn)行計(jì)劃和協(xié)調(diào);這仍然主要是項(xiàng)目經(jīng)理的工作。他們的任務(wù)是確定表述系統(tǒng)設(shè)計(jì)時(shí)的最佳工具和構(gòu)件,以促進(jìn)有效的意見交換。他們必須能夠判斷當(dāng)前方法顯得不足而需要采用新方法的情況。寫作技能也非常重要,還需要具有制作草圖的技能或使用制圖軟件的能力。
3、 自覺主動(dòng);積極解決設(shè)計(jì)問題
架構(gòu)師的日常工作目標(biāo)經(jīng)常并不明確。很多開發(fā)人員直接參考功能規(guī)范來列出任務(wù)清單。架構(gòu)師通常則是向這些開發(fā)人員提供所需結(jié)構(gòu)的人員,以便盡可能提高工作效率。好的候選者不僅進(jìn)行溝通方面的工作,而且也會(huì)預(yù)計(jì)各種設(shè)計(jì)問題并加以解決——通常在沒有任何具體指示的情況下自覺進(jìn)行。無論所分配的職責(zé)如何,積極參與項(xiàng)目的開發(fā)人員都有機(jī)會(huì)從一起工作的人員中脫穎而出。
4、 抽象思維能力和總結(jié)能力
架構(gòu)師,顧名思義,在系統(tǒng)未搭建好之前,就要能夠有一個(gè)草圖在心。而如果是對現(xiàn)有系統(tǒng)的改造,那么能在看過系統(tǒng)的文檔(如果有的話)和代碼后,就能總結(jié)出系統(tǒng)的架構(gòu)特點(diǎn)。
架構(gòu)師必須能夠理解表述模糊的概念并將其變成相關(guān)各方能夠理解的項(xiàng)目構(gòu)件。他們必須能夠理解抽象概念,并以具體的語言對其進(jìn)行溝通。開發(fā)人員中好的候選者經(jīng)常要求或自己主動(dòng)解釋開發(fā)生命周期中容易混淆的問題。他們能迅速評估各種想法并將其納入后續(xù)工作的操作建議中。
開發(fā)人員經(jīng)常具有很強(qiáng)的數(shù)學(xué)能力,而好的架構(gòu)師則傾向于表現(xiàn)出更強(qiáng)的口頭表達(dá)能力。管理人員經(jīng)常說開發(fā)人員具有“工程意識(shí)”,而這是一個(gè)用于評估架構(gòu)師的非常有意義的方面。架構(gòu)師應(yīng)該具有很強(qiáng)的解決技術(shù)問題的能力,但還必須能夠準(zhǔn)確獲知更為全面的人員如何與技術(shù)交互的信息。這要求具有某種形式的抽象思維(而不再是代碼的細(xì)節(jié)),這種思維能力可能較難形成。
5、 全面的技術(shù)資訊吸收能力和選擇鑒別能力
作為開發(fā)人員出身,對于某一個(gè)具體問題的研究能力(雖然很多人總結(jié)為google能力),已經(jīng)相當(dāng)具備了。但是對技術(shù)資訊的全面接受和選擇性深入了解能力,并且做出正確的判斷,那些技術(shù)無非是廠家的噱頭,而那些技術(shù)是真正可以用到項(xiàng)目,提高項(xiàng)目質(zhì)量的好技術(shù),這種能力確實(shí)至關(guān)重要的。
1、public boolean isCacheable(ServletRequest request) {
boolean cachable = false;
if (getTime() > 0) {
/**
* some AJAX application use post to get the page, need to specify a
* cache=true parameter to enable cache. Known url includes:
*/
if ("true".equals(request.getParameter("cache"))) {
cachable = true;
} else if (request.getParameter("noCache") == null
&& (request instanceof HttpServletRequest)) {
HttpServletRequest req = (HttpServletRequest) request;
String uri = req.getRequestURI();
String contextPath = req.getContextPath();
if(contextPath.length()>0)
uri = uri.substring(contextPath.length());
cachable = this.isCacheUris(uri);
}
}
return cachable;
}
public void setCacheUris(List<String> cacheUris) {
this.cacheUris = cacheUris;
}
private boolean isCacheUris(String uri){
for(String _uri:cacheUris){
if(uri.equals(_uri)){
return true;
}
}
return false;
}
2、<bean id="cacheFilterBean" class="com.ebizer.framework.core.filter.CacheFilter">
<property name="cacheUris">
<list>
<value>/trend.html</value>
</list>
</property>
</bean>