xsteam:java對象和xml之間相互轉(zhuǎn)換
xsteam:java對象和xml之間相互轉(zhuǎn)換
1、如果按字符截取會導(dǎo)致中英文顯示的長度不一
2、如果按字節(jié)截取可能會導(dǎo)致最后一個中文截成兩部分
以下代碼是在網(wǎng)上獲取并經(jīng)過改造而成,能夠很好的解決上面兩個問題
/**
* 根據(jù)指定字節(jié)數(shù)截取字符串,當(dāng)指定處為中文第一個字節(jié)時少截取一個字符,當(dāng)長度大于指定截取長度時,截取后在字符串末尾追加指定字符串<br/>
* 這里添加了字符串的編碼,因?yàn)轫撁娴木幋a不同,字符串所占字節(jié)也不同
*
* @param str 待截取字符串,如果為null或者"",則立即返回str
* @param length 需要截取的長度
* @param endStr 截取后末尾追加的字符串
* @param charset 待截取字符串的編碼
* @return
*/
public String subStringByByte(String str, int length, String endStr, String charset) {
if (str == null || "".equals(str.trim()) || length <= 0) {
return str;
}
try {
int strlen = str.getBytes(charset).length;// 這里要和頁面的編碼相關(guān)
if (strlen < length) return str;
Pattern p = Pattern.compile("^[""u4e00-""u9fa5]$");
int i = 0, j = 0;
int sublength = length - ((endStr == null) ? 0 : endStr.getBytes(charset).length);
for (char c : str.toCharArray()) {
Matcher m = p.matcher(String.valueOf(c));
i += m.find() ? 2 : 1;
++j;
if (i == sublength) break;
if (i > sublength) {
--j;
break;
}
}
return str.substring(0, j) + endStr;
} catch (UnsupportedEncodingException e) {
return str;
}
}
英文不太好,經(jīng)常忘記,所以現(xiàn)在寫下來:
1,transient:在序列化一個類時,如果類中某個字段不想被序列化,則使用此關(guān)鍵字
2、volatile:用于線程同步時
JVM生成的所有新對象放在新域中。一旦對象經(jīng)歷了一定數(shù)量的垃圾收集循環(huán)后,便進(jìn)入舊域。而在永久域中是用來存儲JVM自己的反射對象的,如class 和method對象,而且GC(Garbage Collection)不會在主程序運(yùn)行期對永久域進(jìn)行清理。其中新域和舊域?qū)儆诙眩谰糜蚴且粋€獨(dú)立域并且不認(rèn)為是堆的一部分
一、java.lang.OutOfMemoryError: PermGen space
PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域,
這塊內(nèi)存主要是被
JVM存放Class和Method信息的,Class在被Loader時就會被放到PermGen space中,
它和存放類實(shí)例
(Instance)的Heap區(qū)域不同,GC(Garbage Collection)不會在主程序運(yùn)行期對
PermGen
space進(jìn)行清理,所以如果你的應(yīng)用中有很多CLASS的話,就很可能出現(xiàn)PermGen space錯誤,
這種錯誤常見在web服務(wù)器對
JSP進(jìn)行pre compile(預(yù)編譯)的時候。如果你的WEB APP下都用了大量的第三方j(luò)ar, 其大小
超過了jvm默認(rèn)的大小(4M)那么就會
產(chǎn)生此錯誤信息了。
解決方法: 手動設(shè)置MaxPermSize大小
修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using CATALINA_BASE:
$CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -XX:PermSize=64M
-XX:MaxPermSize=128m
建議:將相同的第三方j(luò)ar文件移置到tomcat/shared/lib目錄下,這樣可以達(dá)到減少
jar 文檔重復(fù)占用內(nèi)存的目的。
二、java.lang.OutOfMemoryError: Java heap space
Heap size 設(shè)置
JVM堆
的設(shè)置是指java程序運(yùn)行過程中JVM可以調(diào)配使用的內(nèi)存空間的設(shè)置.JVM在啟動的時候會自動設(shè)置Heap size的值,
其初始空間(即
-Xms)是物理內(nèi)存的1/64,最大空間(-Xmx)是物理內(nèi)存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可
進(jìn)行設(shè)
置。Heap size 的大小是Young Generation 和Tenured Generaion 之和(新域和舊域之和)。
提示:在JVM中如果98%
的時間是用于GC且可用的Heap size 不足2%的時候?qū)伋龃水惓P畔ⅰ?br />
提示:Heap Size
最大不要超過可用物理內(nèi)存的80%,一般的要將-Xms和-Xmx選項設(shè)置為相同,而-Xmn為1/4的-Xmx值。
解決方法:手動設(shè)置
Heap size
修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using
CATALINA_BASE: $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -Xms800m
-Xmx800m -XX:MaxNewSize=256m"
動態(tài)應(yīng)用,是相對于網(wǎng)站靜態(tài)內(nèi)容而言, 是指以c/c++、php、Java、perl、.net等 服務(wù)器端語言開發(fā)的網(wǎng)絡(luò)應(yīng)用軟件,比如論壇、網(wǎng)絡(luò)相冊、交友、BLOG等常見應(yīng)用。動態(tài)應(yīng)用系統(tǒng)通 常與數(shù)據(jù)庫系統(tǒng)、緩存系統(tǒng)、分布式存儲系統(tǒng)等密不可分。
大型動態(tài)應(yīng)用系統(tǒng)平臺主要是針對于大流 量、高并發(fā)網(wǎng)站建立的底層系統(tǒng)架構(gòu)。大型網(wǎng)站的運(yùn)行需要一個可靠、安全、可擴(kuò)展、易維護(hù)的應(yīng)用系統(tǒng)平臺做為支撐,以保證網(wǎng)站應(yīng)用的平穩(wěn)運(yùn)行。
大型動態(tài)應(yīng)用系統(tǒng)又可分為幾個子系統(tǒng):
l Web前端系統(tǒng)
l 負(fù)載均衡系統(tǒng)
l 數(shù)據(jù)庫集群系統(tǒng)
l 緩存系統(tǒng)
l 分布式存儲系統(tǒng)
l 分布式服務(wù)器管理系統(tǒng)
l 代碼分發(fā)系統(tǒng)
Web前端系統(tǒng)
結(jié)構(gòu)圖:

為了達(dá)到不同應(yīng)用的服務(wù)器共享、避免單點(diǎn)故障、集中管理、統(tǒng)一配置等目的,不以應(yīng)用劃分服 務(wù)器,而是將所有服務(wù)器做統(tǒng)一使用,每臺服務(wù)器都可以對多個應(yīng)用提供服務(wù),當(dāng)某些應(yīng)用訪問量升高時,通過增加服務(wù)器節(jié)點(diǎn)達(dá)到整個服務(wù)器集群的性能提高,同 時使他應(yīng)用也會受益。該Web前端系統(tǒng)基于Apache/Lighttpd/Eginx等 的虛擬主機(jī)平臺,提供PHP程序運(yùn)行環(huán)境。服務(wù)器對開發(fā)人員是透明的,不需要開發(fā)人員介入服務(wù)器管理
負(fù)載均衡系統(tǒng)

負(fù)載均衡系統(tǒng)分為硬件和軟件兩種。硬件負(fù)載均衡效率高,但是價格貴,比如F5等。軟件負(fù)載均衡系統(tǒng)價格較低或者免費(fèi),效率較硬件負(fù)載均衡系統(tǒng) 低,不過對于流量一般或稍大些網(wǎng)站來講也足夠使用,比如lvs,nginx。大多數(shù)網(wǎng)站都是硬件、軟件負(fù)載均衡系統(tǒng)并用。
數(shù)據(jù)庫集群系統(tǒng)
結(jié)構(gòu)圖:

由于Web前端采用了負(fù)載均衡集群結(jié)構(gòu)提高了服務(wù)的有效性和擴(kuò)展性,因此數(shù)據(jù)庫必須也是高可靠的才能保證整個服務(wù)體系的高可靠性,如何構(gòu)建一個高可靠的、可以提供大規(guī)模并發(fā)處理的數(shù)據(jù)庫體系?
我們可以采用如上圖所示的方案:
1) 使用 MySQL 數(shù)據(jù)庫,考慮到Web應(yīng)用的數(shù)據(jù)庫讀多寫少的特點(diǎn),我們主要對讀數(shù)據(jù)庫做了優(yōu)化,提供專用的讀數(shù)據(jù)庫和寫數(shù)據(jù)庫,在應(yīng)用程序中實(shí)現(xiàn)讀操作和寫操作分別訪問不同的數(shù)據(jù)庫。
2) 使用 MySQL Replication 機(jī)制實(shí)現(xiàn)快速將主庫(寫庫)的數(shù)據(jù)庫復(fù)制到從庫(讀庫)。一個主庫對應(yīng)多個從庫,主庫數(shù)據(jù)實(shí)時同步到從庫。
3) 寫數(shù)據(jù)庫有多臺,每臺都可以提供多個應(yīng)用共同使用,這樣可以解決寫庫的性能瓶頸問題和單點(diǎn)故障問題。
4) 讀數(shù)據(jù)庫有多臺,通過負(fù)載均衡設(shè)備實(shí)現(xiàn)負(fù)載均衡,從而達(dá)到讀數(shù)據(jù)庫的高性能、高可靠和高可擴(kuò)展性。
5) 數(shù)據(jù)庫服務(wù)器和應(yīng)用服務(wù)器分離。
6) 從數(shù)據(jù)庫使用BigIP做負(fù)載均衡。
緩存系統(tǒng)

緩存分為文件緩存、內(nèi)存緩存、數(shù)據(jù)庫緩存。在大型Web應(yīng)用中使用最多且效率最高的是內(nèi)存緩存。最常用的內(nèi)存緩存工具是Memcachd。使用正確的緩存系統(tǒng)可以達(dá)到實(shí)現(xiàn)以下目標(biāo):
1、 使用緩存系統(tǒng)可以提高訪問效率,提高服務(wù)器吞吐能力,改善用戶體驗(yàn)。
2、 減輕對數(shù)據(jù)庫及存儲集服務(wù)器的訪問壓力
3、Memcached服務(wù)器有多臺,避免單點(diǎn)故障,提供高可靠性和可擴(kuò)展性,提高性能。
分布式存儲系統(tǒng)
結(jié)構(gòu)圖:

WEB系統(tǒng)平臺中的存儲需求有下面兩個特點(diǎn):
1) 存儲量很大,經(jīng)常會達(dá)到單臺服務(wù)器無法提供的規(guī)模,比如相冊、視頻等應(yīng)用。因此需要專業(yè)的大規(guī)模存儲系統(tǒng)。
2) 負(fù)載均衡cluster中的每個節(jié)點(diǎn)都有可能訪問任何一個數(shù)據(jù)對象,每個節(jié)點(diǎn)對數(shù)據(jù)的處理也能被其他節(jié)點(diǎn)共享,因此這些節(jié)點(diǎn)要操作的數(shù)據(jù)從邏輯上看只能是一個整體,不是各自獨(dú)立的數(shù)據(jù)資源。
因此高性能的分布式存儲系統(tǒng)對于大型網(wǎng)站應(yīng)用來說是非常重要的一環(huán)。(這個地方需要加入對某個分布式存儲系統(tǒng)的簡單介紹。)
分布式服務(wù)器管理系統(tǒng)
結(jié)構(gòu)圖:

隨著網(wǎng)站訪問流量的不斷增加,大多的網(wǎng)絡(luò)服務(wù)都是以負(fù)載均衡集群的方式對外提供服務(wù),隨之集群規(guī)模的擴(kuò)大,原來基于單機(jī)的服務(wù)器管理模式已經(jīng)不能夠滿足我們的需求,新的需求必須能夠集中式的、分組的、批量的、自動化的對服務(wù)器進(jìn)行管理,能夠批量化的執(zhí)行計劃任務(wù)。
在分布式服務(wù)器管理系統(tǒng)軟件中有一些比較優(yōu)秀的軟件,其中比較理想的一個是 Cfengine。它可以對服務(wù)器進(jìn)行分組,不同的分組可以分別定制系統(tǒng)配置文件、計劃任務(wù)等配置。它是基于C/S 結(jié)構(gòu)的,所有的服務(wù)器配置和管理腳本程序都保存在Cfengine Server上,而被管理的服務(wù)器運(yùn)行著 Cfengine Client 程序,Cfengine Client通過SSL加密的連接定期的向服務(wù)器端發(fā)送請求以獲取最新的配置文件和管理命令、腳本程序、補(bǔ)丁安裝等任務(wù)。
有了Cfengine 這種集中式的服務(wù)器管理工具,我們就可以高效的實(shí)現(xiàn)大規(guī)模的服務(wù)器集群管理,被管理服務(wù)器和 Cfengine Server 可以分布在任何位置,只要網(wǎng)絡(luò)可以連通就能實(shí)現(xiàn)快速自動化的管理。
代碼發(fā)布系統(tǒng)
結(jié)構(gòu)圖:

隨著網(wǎng)站訪問流量的不斷增加,大多的網(wǎng)絡(luò)服務(wù)都是以負(fù)載均衡集群的方式對外提供服務(wù),隨之集群規(guī)模的擴(kuò)大,為了滿足集群環(huán)境下程序代碼的批量分發(fā)和更新,我們還需要一個程序代碼發(fā)布系統(tǒng)。
這個發(fā)布系統(tǒng)可以幫我們實(shí)現(xiàn)下面的目標(biāo):
1) 生產(chǎn)環(huán)境的服務(wù)器以虛擬主機(jī)方式提供服務(wù),不需要開發(fā)人員介入維護(hù)和直接操作,提供發(fā)布系統(tǒng)可以實(shí)現(xiàn)不需要登陸服務(wù)器就能把程序分發(fā)到目標(biāo)服務(wù)器。
2) 我們要實(shí)現(xiàn)內(nèi)部開發(fā)、內(nèi)部測試、生產(chǎn)環(huán)境測試、生產(chǎn)環(huán)境發(fā)布的4個開發(fā)階段的管理,發(fā)布系統(tǒng)可以介入各個階段的代碼發(fā)布。
3) 我們需要實(shí)現(xiàn)源代碼管理和版本控制,SVN可以實(shí)現(xiàn)該需求。
這里面可以使用常用的工具Rsync,通過開發(fā)相應(yīng)的腳本工具實(shí)現(xiàn)服務(wù)器集群間代碼同步分發(fā)。
將一個命令的輸出作為下一個命令的輸入
例:ls | grep text --這個命令將查找當(dāng)前目錄下名稱中包含text的目錄或者文件
xargs:
將一個命令的輸入作為下一個命令的參數(shù)
例:ls | xargs grep -i text --這個命令將當(dāng)前目下的所有文件作為參數(shù)傳遞給grep來查找文件中是否包含"text"
find . | xargs grep "user" --查詢當(dāng)前目錄及其子目錄下所有內(nèi)容中包含"user"的文件
sql server:select top 10 * from 表名 order by newid();
oracle:select * from(select * from 表名 order by dbms_random.value) where rownum<=20;
access:select top 10 * from 表名 order by rnd(ID)
html { filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1); }
需要最新網(wǎng)頁標(biāo)準(zhǔn)支持:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
Flash要在object標(biāo)簽中加入如下代碼:
<param value="false" name="menu"/>
<param value="opaque" name="wmode"/>
1、下載wamp5,安裝wamp5,如需更改端口請修改Apache配置文件,更改端口(如:8888)后還需要更改wamp根目錄wampmanager.ini文件中的以下地方
Type: item; Caption: "Localhost"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/"; Glyph: 5
Type: item; Caption: "phpMyAdmin"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/phpmyadmin/"; Glyph: 5
Type: item; Caption: "SQLiteManager"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/sqlitemanager/"; Glyph: 5
2、安裝后訪問首頁http://localhost:8888,點(diǎn)擊phpinfo()查看php信息,如果只顯示如下信息:
This program makes use of the Zend Scripting Language Engine:
Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
查看php目錄下的php.ini文件,沒有[Zend]塊,表明ZendOptimizer沒有安裝
3、下載ZendOptimizer,安裝路徑選擇D:\Program Files\Zend,選擇apache2.x及php.ini的位置,安裝完成后php.ini最后會添加以下內(nèi)容:
[Zend]
zend_extension_manager.optimizer_ts="D:\Program Files\Zend\ZendOptimizer-3.3.0\lib\Optimizer-3.3.0"
zend_extension_ts="D:\Program Files\Zend\ZendOptimizer-3.3.0\lib\ZendExtensionManager.dll"
4、訪問http://loalhost:8888/ppframe進(jìn)行ppframe的安裝,安裝成功后登陸后臺,如果沒有安裝ZendOptimizer,左側(cè)的exam是打不開的,但是passport可以打開。
1、如果頁面有<base/>標(biāo)簽的則要在js引入后再添加<base target="_self" />;
2、在<script/>中添加屬性defer="defer";