WEB开发网      婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧鍡樻叏濞戞氨纾藉ù锝呮惈閳诲牏绱掗悩宕囧⒌鐎殿喛顕ч濂稿醇椤愶綆鈧洭姊绘担鍛婂暈闁规瓕顕ч~婵嬪Ω閳轰胶顔夐梺闈涚箳婵厼危閸喓绠鹃柛鈩兠慨鍥ㄣ亜鎼淬垺宕屾慨濠冩そ瀹曘劍绻濋崒姘兼綋闁诲孩顔栭崰鏍偉婵傚摜宓侀柡宥庡幖缁犳稒銇勯弮鍌氫壕闁挎稑绻樺娲川婵犲啫鐦烽梺鍛婃处閸嬪懘鎮鹃鍕拻濞达絽鎽滈弸鍐┿亜椤愩埄妯€鐎规洖缍婂畷绋课旈埀顒傜不閺嶎厽鐓冮柛婵嗗閺嗗﹪鏌涚€n偅宕岀€规洜鍏橀、姗€鎮欓幇鈺佺仾闁靛洤瀚版俊鐑芥晜閸撗呮澖婵犳鍠栭敃銈夊箹椤愶絾娅忛梻浣规偠閸庢粓鍩€椤掑嫬纾婚柟鐐窞閺冨牆宸濇い鎾跺缁遍亶姊绘担绛嬫綈鐎规洘锕㈤、姘愁槼妞ゃ垹锕缁樻媴閸涘﹤鏆堝┑鐐额嚋缁犳挸鐣疯ぐ鎺戠妞ゆ柨褰炵粭澶娾攽閻愭潙鐏熼柛銊︽そ閹繝寮撮悢缈犵盎闂佽婢樻晶搴g矙閼姐倗纾奸柍褜鍓熷畷姗€鍩炴径鍝ョ泿闂佺澹堥幓顏嗘閺囩喐娅忓┑鐘愁問閸犳牠鏁冮妸銉㈡瀺闁挎繂娲ら崹婵囩箾閸℃绠氶柡瀣叄閺岀喖顢涢崱妤€鏆欐い銉﹀姍濮婂宕掑▎鎴М闂佺濮ょ划宥夊箞閵娾晜鍋ㄧ紒瀣硶椤︻喖鈹戦悙鍙夘棡闁告梹甯為幑銏ゅ幢濞戞瑧鍘介梺闈涚箚閹虫岸宕烽鐘电劶闁诲函缍嗛崑浣圭濠婂牊鐓涚€广儱鍟慨鈧繝銏n潐閿曘垽寮诲☉銏″€锋い蹇撳椤洤鈹戦纭锋敾婵$偠妫勮灋闁告劦鐓佽ぐ鎺懳ч柛鈩冪憿婵洭姊洪悷鏉挎Щ闁硅櫕锕㈤悰顕€骞樼拠鑼唺閻庡箍鍎遍幏瀣涘⿰鍫熲拻闁稿本鐟чˇ锔界節閳ь剟鏌嗗鍛紵闂侀潧鐗嗛ˇ顓㈠焵椤掆偓閸熸潙鐣烽崡鐐╂婵☆垳鍘ч獮鍫ユ⒒娴e憡璐¢柛搴涘€濋妴鍐幢濞戞瑥浜楅梺鍝勬储閸ㄦ椽鎮″☉銏$厱闁靛绲介崝姘攽閿涘嫬甯堕棁澶嬬節婵犲倸顏柣顓烆儔閺屾洟宕惰椤忣剛绱掗悩宕囨创闁轰焦鍔欏畷銊╊敇閻樺灚缍侀梻鍌氬€风粈渚€骞栭锝呯窞闁搞儺鍓欓悞鍨亜閹哄棗浜剧紒鍓ц檸閸欏啫顕i幎钘夊耿婵炴垶鐟ラ埀顒傛暬閺屻劌鈹戦崱娑扁偓妤€顭胯閸楁娊寮婚敓鐘插耿婵炲棗绻嗛弸鍛存⒑閸濆嫮娼ら柛鏇ㄥ亽閸ゃ倕鈹戦悙鍙夘棡闁搞劎鏁诲畷鍝勭暆閸曨兘鎷洪梻鍌氱墛缁嬫帡藟閻愮儤鍋ㄦい鏍ㄧ☉濞搭噣鏌ㄥ┑鍫濅粶闁宠鍨归埀顒婄秵閸嬪嫭绂嶅Δ鍛厵闁煎湱澧楄ぐ褏绱掗幓鎺嬪仮闁诡喕绮欓幊锟犲Χ閸モ晪绱冲┑鐐舵彧缂嶁偓妞ゆ洘鐗曢埢鎾诲即閵忥紕鍘遍梺闈浨归崕铏閵徛颁簻妞ゆ劑鍨荤粻宕囩磼鏉堛劌绗掗摶锝夋偣閸パ勨枙闁逞屽墯閹稿墽妲愰幘瀛樺闁革富鍘稿Σ鍫濐渻閵堝棗鐏ラ柟鍐查叄閸┿垽骞樺ú缁樻櫍闂佺粯鍔忛弲婊堝棘閳ь剚淇婇悙顏勨偓鏍ь潖瑜版帒鍑犲┑鐘宠壘缁€鍌涖亜閹烘垵鈧崵澹曟總鍛婄厽婵☆垱瀵ч悵顏嗏偓瑙勬礀閻倿寮婚弴銏犲耿闁哄洨濯Σ顔碱渻閵堝骸浜濈紒璇茬墦閻涱噣宕堕妸锕€顎撻梺绋跨箰椤︿即鎮楅崨濠勭瘈闁汇垽娼у暩闂佽桨绀侀幉锟犲箞閵娾晩鏁囬柕蹇曞Х閿涙盯姊虹憴鍕缂佸鍠涢妵鎰板箳閹惧瓨鐝抽梻浣规偠閸庮噣寮崒鐐茬劦妞ゆ巻鍋撻柨鏇ㄤ邯瀵鏁撻悩鑼姦濡炪倖甯婇懗鍫曘€呴悜鑺ュ€甸柨婵嗛娴滅偤鏌涘Ο鎸庮棄闁宠鍨块崺銉╁幢濡ゅ啩鐢绘俊鐐€栭崹鍫曟偡閳轰胶鏆﹂柣銏㈩暯閸嬫捇鏁愭惔鈥冲箣闂佺ǹ顑嗛幐楣冨箟閹绢喖绀嬫い鎺嗗亾濞寸姭鏅犲铏圭矙閹稿骸鏀紓渚囧櫍缁犳牠骞冨鈧畷姗€顢欑憴锝嗗缂傚倸鍊烽悞锕傚煟閵堝鏁傞柛鏇㈡涧濞堛劑姊洪崜鎻掍簼婵炲弶鐗犻幃鍧楊敋閳ь剟寮婚敐澶婄疀妞ゆ棁濮ゅВ鍕磼閻愵剙鍔ら柕鍫熸倐瀵鈽夊顐e媰闂佺粯鍔﹂崜娑樷枔閵堝鐓涘ù锝呮憸婢э箓鏌熼绛嬫畼闁瑰弶鎸冲畷鐔碱敆閸屻倖袨缂傚倸鍊风欢锟犲窗閺嶎偅宕叉俊顖涘椤ャ倝姊虹拠鏌ュ弰婵炰匠鍥х婵犲﹤鍚樺☉銏╂晬闁绘劕顕崢闈涱渻閵堝棛澧俊顐f⒒缁牊鎷呴崷顓ф祫濡炪倖娲嶉崑鎾绘煙椤旂瓔娈旈柍缁樻崌瀹曞綊顢欓悾灞奸偗闂傚倷鑳剁划顖炴偋濠婂牆鍌ㄧ憸鏃堝箖妤e啯鍊婚柤鎭掑劚娴滄鏌熼悡搴f憼閽冭鲸銇勯銏⑿㈤柍瑙勫灴閸┿儵宕卞Δ鍐ф埛闂佽崵濮崑鎾绘煥閺囩偛鈧綊宕愰悽纰樺亾鐟欏嫭绀€婵炲眰鍔庢竟鏇熺鐎n偆鍘遍柣蹇曞仜婢т粙骞婇崨瀛樼厱闁哄倽娉曟牎闂侀潧娲ょ€氱増淇婇幖浣肝ㄩ柨鏃傜帛椤ワ綁姊绘担椋庝覆缂佹彃澧介幑銏ゅ醇閵壯冪ウ闂佸搫绉查崝宥嗗垔鐎涙ɑ鍙忔繝闈涙濠€浼存煙闊厼宓嗘慨濠勭帛閹峰懘鎼归悷鎵偧婵犵妲呴崑鍕疮绾惧锛傞梻浣筋潐瀹曟﹢顢氳鏁堥柡灞诲劜閸婄敻鏌ㄥ┑鍡涱€楅柡瀣枛閺岋綁骞樼捄鐑樼€炬繛锝呮搐閿曨亝淇婇崼鏇炵<婵﹩鍋勯ˉ姘舵⒒閸屾瑨鍏岀紒顕呭灦閵嗗啴宕ㄩ鍥ㄧ☉铻栭柛娑卞幘閸樻椽姊洪崷顓炰壕缂佸墎鍋ゅ顕€宕煎┑鍡欑崺婵$偑鍊栧Λ渚€锝炴径灞稿亾濮橆兙鍋㈡慨濠冩そ閹筹繝濡堕崨鍛灪缁绘盯鎳犻鈧埢鍫ユ煕閳规儳浜炬俊鐐€栫敮鎺楀疮椤栫偞鍋熸い蹇撶墛閻撶喖鐓崶褝宸ュù婊堢畺濮婂宕掑顑藉亾妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晝閳ь剛绮婚悩缁樼厵闂侇叏绠戦獮妤呮煕濞嗗繒绠婚柡宀€鍠撶槐鎺楀閻樺磭浜堕梻浣呵归鍌炲疾閻樿钃熼柨婵嗩槸鍥撮柟鑹版彧缁辨洘绂掑⿰鍕閻庢稒岣块惌濠勭磽瀹ュ拑韬€殿喖顭烽幃銏ゅ礂閻撳簶鍋撶紒妯圭箚妞ゆ牗绻傛禍褰掓煟閿濆棙銇濇慨濠冩そ瀹曨偊宕熼鈧▍銈囩磽娴g瓔鍤欓柣妤€妫濋敐鐐剁疀閹句焦妞介、鏃堝椽娴h妫冨┑鐘垫暩閸嬬偤宕归崼鏇熷殞濡わ絽鍟ㄩ埀顒€鍊垮畷顐﹀礋閵婏附鏉搁梻浣哥枃濡嫬螞濡や胶顩叉繝闈涱儐閻撶喖鏌i弬鍨骇婵炲懎锕弻鏇㈠幢閺囩媭妲梺瀹狀嚙闁帮綁鐛幒妤€绫嶉柛灞剧⊕缁额偊姊婚崒娆戭槮闁圭⒈鍋婂畷顖烆敃閿曗偓绾剧懓鈹戦悩宕囶暡闁稿骸锕弻娑㈩敃閻樻彃濮曢梺鎶芥敱閸ㄥ爼骞堥妸鈺傚仭闁绘鐗婇幃娆撴⒑鐠囪尙绠扮€殿喖澧庨幑銏犫槈濞嗘劕顎撻梺鍛婂姈瑜板啴顢旈锝冧簻闁冲搫鍟崢鎾煛鐏炶濮傜€殿喗鎸抽幃娆徝圭€n亙澹曢悷婊呭鐢宕戦崒鐐寸厸闁搞儯鍎遍悘顏堟煟閹惧磭绠伴柍瑙勫灴閹瑩鎳犻鑳闂備礁鎲¢弻锝夊磹濠靛钃熸繛鎴欏灩閻撴盯鎮楅敐搴″閽冭鲸淇婇悙顏勨偓鎴﹀礉婵犲洤纾块柣銏⑶圭粻鏍ㄧ箾閸℃ɑ灏紒鐙欏洦鐓欓悗娑欋缚缁犮儲绻涢崗鑲╊暡濞e洤锕俊鍫曞炊椤喓鍎甸弻娑氣偓锝庡墮娴犻亶鏌℃担绋挎殻濠殿喒鍋撻梺闈涚墕閸熺娀宕戦幘瀛樺缂侇垱娲橀悗濠氭⒑閸︻厼浜炬繛鍏肩懃閳绘捇骞囬悧鍫氭嫼闂佸憡鍔曞鍫曞箚閸喆浜滈柟瀛樼箖閸犳﹢鏌e☉鍗炴珝濠殿喒鍋撻梺闈涚墕濡矂骞忔繝姘拺缂佸瀵у﹢浼存煟閻曞倸顩紒顔硷躬閹囧醇濞戞鐩庢俊鐐€栭崝鎴﹀春閸曨倠锝夊箹娴e湱鍘介梺鎸庣箓閹冲骸危婵犳碍鎳氶柨婵嗩槹閻撶姵绻涢弶鎴剱婵炲懎娲弻锝夊箻閹颁礁鍓板銈庝簻閸熷瓨淇婇崼鏇炲耿婵妫欓埛鏍⒒娴h姤纭堕柛鐘叉瀹曟洟鎳犻鍌滅効閻庡箍鍎遍悧鍕瑜版帗鐓欓柣鎴炆戠亸鐢告煕濡吋鏆慨濠呮缁辨帒螣閾忛€涙闂佽棄鍟存禍鍫曞箖濡法鐤€闁挎繂鎳庣粻褰掓⒒閸パ屾Ч缂佺粯绻冪换婵嬪磼濮橆厽顔嶇紓鍌欑椤﹂亶宕曢妶澶婄疄闁靛⿵濡囩弧鈧梺鍛婁緱閸n喗绂掗埡鍐=濞达絼绮欓崫娲偨椤栨稑绗╅柣蹇斿浮濮婃椽骞嗚缁犲鏌嶈閸撴氨绮欓幒妞尖偓浣割潨閳ь剙顫忔繝姘<婵炲棙鍨垫俊浠嬫煟鎼达絿鎳楅柛蹇曞Т閹碱偊顢橀崗鐓庣窞濠电姴瀚悡锝嗙節閻㈤潧浠﹂柛銊ュ閸掓帗鎯旈姀銏╂锤闂備緡鍓欑粔鐢稿煕閹烘嚚褰掓晲閸涱喖鏆堥梺鍝ュ枔閸嬬偟鎹㈠☉姘珰鐟滃繘鎮鹃悽纰樺亾鐟欏嫭绀€缂傚秴锕濠氬幢濡ゅ﹤鎮戦梺鍛婁緱閸ㄤ即鐛崼銉︹拻濞达絼璀﹂弨浼存煙濞茶閭慨濠佺矙瀹曠喖顢涘☉妯圭暗婵犵數鍋涘Λ娆撳箰婵犳碍鍋傞柣妯虹-缁犻箖鏌℃径瀣劸闁稿孩鍔栫换娑㈠川椤撶喎娅i梻鍥ь樀閺岋絽螣閾忕櫢绱為梺娲诲幖閿曨亪寮诲鍥ㄥ枂闁告洦鍋嗘导宀勬⒑閹肩偛濮傜紒鐘崇墵楠炲啫鈻庨幘鏉戠檮婵犮垼娉涢ˇ顖炲垂濠靛鈷掗柛灞剧懄缁佺増銇勯弴鐔哄⒌鐎规洘婢樿灃闁告侗鍋€閸嬫捇宕橀鐓庣獩闂佸搫顦伴崹褰掑矗閳ь剙鈹戦悩顔肩伇闁糕晜鐗犲畷婵嬪即閻樺吀绗夐梺瑙勫劶婵倝鎮″▎鎾寸厵妞ゆ牕妫楅懟顖氣枔閸洘鍋℃繝濠傚缁跺弶绻涚仦鍌氬婵″弶鍔欓獮妯兼嫚閼碱剨绱叉繝鐢靛仜濡瑩宕归懖鈺冪幓婵°倕鎳忛埛鎴︽煕濠靛嫬鍔氶弽锟犳⒑缂佹﹩娈樺┑鐐╁亾闂侀潧妫旂欢姘嚕娴犲鏁囬柣鎰皺閻涒晠姊绘担鍛婅础闁冲嘲鐗撳畷銏$鐎n亞鏌ч梺鎸庣箓椤︿即鍩涢幋鐘电<閻庯綆鍘界涵鍓佺磼閻樺啿鈻曢柡灞剧☉铻i柣妯哄级閸g儤銇勯幇顏嗙煓闁哄矉缍侀獮鍥敊閸撗呮缂傚倷娴囬褍螞濞嗘挸桅闁告洦鍨伴崘鈧梺闈浤涢崨顖氬笓闂備焦鐪归崺鍕垂鏉堚晝鐭欓柟鐑樻⒐瀹曞弶绻涢幋娆忕仼鐎瑰憡绻冮妵鍕箻鐠虹儤鐎婚梺鍝勵儑婵挳鍩為幋锔绘晩缁绢厼鍢叉慨娑氱磽娓氬洤娅橀柛銊ョ埣閻涱喛绠涘☉妯虹獩闁诲孩绋掗敋濞寸媭鍙冨缁樼瑹閸パ冧紟缂備胶濮甸崹鐢稿煝閹炬枼鏀介柛顐犲灮閿涙繈姊虹粙鎸庢拱闁荤噦濡囩划濠囨偋閸稐绨婚梺鍝勬搐濡煤閵堝洤顥氱憸鐗堝笚閻撴洘銇勯鐔风仴婵炲懏锕㈤弻娑㈠Χ閸℃ḿ顦紓浣介哺閹稿骞忛崨顖涘妞ゆ牗绮庣粣妤冪磽閸屾瑨顔夋俊鐙欏洤纾婚柟鍓х帛閳锋帒霉閿濆牜娼愰柛瀣█閺屾稒鎯旈鑲╀桓閻庤娲樼换鍌烆敇婵傜ǹ宸濇い蹇撴噽閳ь剚妞藉娲箹閻愭彃濮堕梺鍛婃尰瀹€鎼佸春濞戙垹绠i柣妯兼暩閿涙粓鏌f惔顖滅У闁稿瀚伴、姘堪閸曨厾鐦堥梺閫炲苯澧存鐐茬Ч椤㈡瑩宕滆缁辨煡姊虹拠鎻掑毐缂傚秴妫濆畷鎴﹀川椤撶姵娈鹃悗鍏夊亾闁逞屽墴閸┾偓妞ゆ帒鍠氬ḿ鎰箾閹绘帞绠荤€规洝顫夌粋鎺斺偓锝庝簽閻g儤绻涚€电ǹ孝妞ゆ垵鎳庨蹇撯攽閸″繑鏂€闂佺粯蓱瑜板啴顢旈埡鍌ゆ闁绘劖鎯屽▓婊勬叏婵犲啯銇濋柟顔惧厴瀵爼骞愭惔鈾€鍋撻鐐粹拺濞村吋鐟х粔闈浢瑰⿰搴濈盎闁伙綁顥撻幉鎾礋椤撶姷妲囨繝娈垮枟閿曗晠宕滃☉銏犲偍闁规壆澧楅埛鎴︽煕濠靛棗顏柛灞诲姂閺屾盯濡搁敂濮愪虎闂佽鍣换婵囦繆閻戣姤鏅滈柦妯侯槸娴煎孩绻濈喊妯活潑闁搞劋鍗抽幃妯衡攽鐎n偄浜楅梺瑙勫婢ф鎮¢悢鍏肩厵闁硅鍔栫涵楣冩煛鐎n偆娲撮柡宀嬬秮楠炴瑩宕橀妸銈呮瀳闁诲氦顫夊ú鏍偉閸忛棿绻嗛柣鎴f鍞梺闈涱槶閸庢盯骞嬮悩鐢碉紳闂佺ǹ鏈悷褔藝閿斿浜滈柟瀛樼箘婢ф洟鏌i敐鍥у幋闁诡喕绮欏畷褰掝敃椤愶絿绋愰梻鍌欑濠€閬嶅磿閵堝拋娼栭柤濮愬€曢ˉ姘舵煕韫囨稒锛熺紒璇叉閵囧嫰寮介妸褏鐣垫繛瀛樼矊缂嶅﹪寮婚敐澶嬫櫜闁割偆鍣ユ禒鈺冪磽娴d粙鍝洪柟绋款煼楠炲繘宕ㄧ€涙ɑ鍎梺鑽ゅ枑婢瑰棝顢曢懖鈺冪=闁稿本鐟︾粊鐗堛亜閺囧棗娲﹂崑瀣煕閳╁啰鈯曢柛瀣ф櫇閳ь剛鎳撶€氫即宕戞繝鍌栫細闁靛ň鏅滈悡鍐喐濠婂牆绀堟慨姗嗗幘閳瑰秴鈹戦悩鎻掍簽婵炲吋澹嗛埀顒€鍘滈崑鎾斥攽閻樻彃鏁柕濞у懐锛濋梺绋挎湰閻燂妇绮婇弶娆炬富闁哄鍨堕幉鎼佹煙楠炲灝鐏茬€规洜鍘ч埞鎴﹀箛椤撶姷鈻夌紓鍌氬€搁崐鐑芥倿閿曚焦鎳屽┑鐘愁問閸ㄤ即顢氶鐘愁潟闁圭儤鍨熷Σ鍫熸叏濡も偓濡宕滈弶搴撴斀闁绘劘灏欐晶娑㈡煕閺冣偓閻熴儵锝炶箛鎾佹椽顢旈崟顓у晣闂備胶绮崝鏍亹閸愵喒鈧牠宕卞☉娆屾嫼闂佸憡绋戦オ鏉戔枔閺冨牊鐓曢柣鏃堟敱閸嬨儵鏌熼鈧粻鏍箖濠婂懐椹抽悗锝庡亝濞呮牠姊绘担铏瑰笡闁告梹岣挎禍绋库枎閹板灚顔旈梺鎼炲労閸撴岸鍩涢幋锔界厽闁绘梻鍘ф禍浼存煕閵堝洤鏋庨柍瑙勫灴椤㈡岸鍩€椤掆偓宀h儻顦归柛鈹垮灲楠炴ê菐椤掆偓娴滄繈姊洪崨濠傚闁哄倷绶氶獮蹇涙惞閸︻厾锛濋梺绋挎湰閻熝囧礉瀹ュ瀚呴梺顒€绉甸悡鍐⒑閸噮鍎忔繛鎼櫍閺岋紕浠﹂悾灞濄垽鏌i敐蹇曠瘈妤犵偛绉归、娆戜焊閺嵮冪阀闂備浇顕х€涒晠顢欓弽顓為棷妞ゆ洍鍋撶€规洘鍨剁换婵嬪磼濠婂嫭顔曢梻浣告贡閸庛倝銆冮崱娑樼9闁绘垼濮ら崐鐢告煟閵忋垺顏㈢憸鐗堝笧瀹撲線鏌涢鐘插姕闁抽攱甯掗湁闁挎繂娲﹂崵鈧梺宕囩帛濞茬喖寮婚埄鍐懝闁搞儜鍕綆闁诲氦顫夊ú姗€宕归崸妤冨祦婵☆垵鍋愮壕鍏间繆椤栨粌甯舵鐐村姍濮婄粯鎷呴崨濠傛殘婵炴挻纰嶉〃濠傜暦閺夋娼╅悹楦挎閻ゅ洭姊洪崨濠佺繁闁哥姵娲滈幑銏ゅ幢濞戞瑧鍘卞┑鐐叉濞存艾危缁嬪簱鏀芥い鏂垮悑閸犳﹢鏌熼挊澶屽煟闁轰焦鍔栧鍕偓锝庝簷閸濇绻濋悽闈涗沪闁搞劌澧庨弫顕€骞掗幘瀛樼彿闂佸搫琚崕鏌ユ偂濞戙垺鐓曢悘鐐佃檸濞堟柨霉濠婂牏鐣烘慨濠傤煼瀹曟帒顫濋钘変壕闁绘垼濮ら崵鍕煕閹捐尙顦﹂柛銊︾箖閵囧嫰寮介顫捕缂備讲鍋撳鑸靛姈閻撴盯鏌涢妷銏℃珔闁逞屽墾缂嶄線骞冮姀銈呬紶闁靛/鍛潓闂傚倷鐒﹂幃鍫曞磿濠婂牆绀冮柍杞扮婵啴姊婚崒姘偓鐑芥嚄閸撲礁鍨濇い鏍仜閽冪喖鏌曟繛鐐珕闁稿骸绉电换婵嬫濞戝崬鍓扮紓鍌欒閺呯娀寮婚妶澶婄畳闁圭儤鍨垫慨灞剧箾鐎涙ḿ鐭嬬紒顔芥崌瀵鏁撻悩鑼槰闂侀潧饪电粻鎴λ囬埡渚囨富闁靛牆鍟崝姘亜閿旂偓鏆€殿喛顕ч埥澶愬閻樻剚妫熼梺鑽ゅТ濞诧妇绮婇幘顔肩;闁圭偓鏋奸弨浠嬫倵閿濆簼绨芥い鏃€鍨垮娲礈閹绘帊绨煎┑鐐插级閿曘垹鐣烽幇鐗堝€婚柤鎭掑劤閸樹粙姊洪悷閭﹀殶闁稿绉剁槐鎾愁潩閼哥數鍘卞┑顔姐仜閸嬫挸霉濠婂棙纭炬い顐㈢箰鐓ゆい蹇撳缁卞爼姊洪崨濠冨闁告挻鐟╁畷鎴濐吋婢跺鎷洪梺鍛婄☉閿曘儵鎮¢妷鈺傜厸闁割偒鍋勬晶瀵糕偓娈垮枟閻撯€崇暦婵傜ǹ鍗抽柕濠忛檮濞呮牠姊绘担铏瑰笡闁告梹娲熼、姘额敇閵忕姴鍋嶉梺鍛婎殘閸嬫劙寮ㄦ禒瀣厽闁归偊鍓欑痪褎銇勯妷锔剧煂缂佽鲸甯炵槐鎺懳熼搹璇″剬缂傚倷绶¢崰姘卞垝椤栨粍宕叉繝闈涙-濞尖晜銇勯幘璺盒㈡鐐村姍濮婅櫣鎷犻懠顒傤唺闂佺ǹ顑囬崰鏍ь嚕閺屻儺鏁冮柨婵嗘閻濓繝姊绘担绛嬪殭婵﹫绠撻敐鐐村緞婵炴帗妞介弫鍐磼濮樻唻绱卞┑鐘垫暩婵挳宕愭繝姘辈闁挎洖鍊归悡鐔兼煛閸愩劌鈧敻骞忛敓鐘崇厸濞达絽鎲¢ˉ銏ゆ煛鐏炵晫啸妞ぱ傜窔閺屾盯骞樼€靛憡鍣伴梺绯曟杺閸ㄥ綊顢橀崗鐓庣窞閻庯綆鍋呴悵鎶芥⒒娴h鍋犻柛搴櫍瀵彃鈹戠€n偅娅栧┑鐘绘涧濞层劎绮绘ィ鍐ㄧ骇闁割偅绻傞埛鏃傜磼鐎n厼鍚归柟鍙夋倐瀵爼宕归鑺ヮ唹缂傚倷绀侀崐鍝ョ矓瑜版帒绠栨繛鍡樻惄閺佸棝鏌涚仦鍓х煂婵℃彃娲缁樼瑹閳ь剙岣胯椤ㄣ儴绠涢弴鐐电瓘闂佸憡鎸嗛崟顐㈠箲闂備胶绮崝锕傚礂濞嗘劗顩叉繝濠傜墛閻撴瑩鎮楀☉娆嬬細缂佺姵鐗滈埀顒傛嚀閹诧紕鎹㈤崟顓燁潟闁圭儤顨忛弫濠囨煕閹炬鍟伴濂告⒒娓氣偓濞佳囨偋閻愮數绀婂ù锝呮憸閺嗭附鎱ㄥ璇蹭壕闂佺硶鏅换婵嗙暦濮椻偓婵℃悂濡疯閸氬姊婚崒姘偓宄懊归崶顒夋晪鐟滃繘鍩€椤掍胶鈻撻柡鍛箘閸掓帒鈻庨幘宕囶唺闂佺懓顕慨瀵哥不閻㈠憡鐓熼柣妯哄帠閼割亪鏌涢弬鍨劉缂佸顦濂稿幢濡搫浼庢繝纰夌磿閸嬬娀顢氳缁傚秵銈i崘鈹炬嫼闂佸憡绻傜€氼垶锝為敃鍌涚厱闁哄倽娉曢悞鎼佹煕閳瑰灝鍔滅€垫澘瀚换娑㈠閵忕姵鐎鹃悗鍨緲鐎氫即骞嗛崒鐐蹭紶闁靛鐏栭幋锔解拺闂傚牊绋掗幖鎰版倵濮樺崬顣煎ǎ鍥э躬楠炴牗鎷呯憴鍕彸闂備礁鎲℃笟妤呭储閼归偊鏉洪梻鍌氬€搁崐宄懊归崶顒夋晪闁哄稁鍘肩粣妤佷繆閵堝懏鍣洪柛瀣剁節閺屽秹宕崟顒€娅¢梺閫炲苯鍘哥紒鑸佃壘椤曪綁顢氶埀顒€鐣烽悡搴樻斀闁割偒鍋呮晥婵犵绱曢崑鎴﹀磹閺嶎厼绠伴柤濮愬€栧畷鏌ユ煕閺囥劌骞橀柣顓炴閺屾盯寮撮妸銉т画闂佹娊鏀辩敮锟犲蓟濞戞矮娌柛鎾楀嫬娅楃紓鍌欐閼宠埖鏅跺Δ鍛﹂柛鏇ㄥ灠閸楁娊鏌i弬鎸庢儓闁冲嘲鐭傞幃妤冩喆閸曨剛锛涢梺鍛婎殔閸熷潡顢氶敐鍡欘浄閻庯絽鐏氶弲婵嬫⒑闂堟稓澧曟繛鏉戝€稿嵄缂佸绨遍弨浠嬫煟濡櫣浠涢柡鍡忔櫅閳规垿顢欓懞銉ュ攭閻庤娲橀崝鏍崲濠靛棭娼╂い鎺嶆祰缁躲垽姊绘担鐟邦嚋婵炲弶鐗犲畷鎰亹閹烘挸浜楀┑鐐叉閸旀垶绂嶅⿰鍫熺厸鐎广儱楠告禍婊兠归悩宕囩煀闂囧绻濇繝鍌涘櫣妞わ絿鍘ц彁闁搞儜宥堝惈闂佺懓纾慨鐢告晬閹邦兘鏀介柛鈩冿供閸炴煡姊婚崒娆戭槮闁汇倕娲敐鐐村緞閹邦剙鐎梺绉嗗嫷娈旈柡鍕╁劦閺屾盯寮撮妸銉т哗缂備讲鍋撻柛鎰靛枟閻撳繐鈹戦悙鎴濆暞閸g兘鏌涚€Q€鍋撻弬銉︽杸闂佹寧绋戠€氼剚绂嶆總鍛婄厱濠电偛鐏濋埀顒佺箓閻g兘濮€鎺抽崑鍛存煕閹扳晛濡挎い蟻鍐f斀闁宠棄妫楅悘鐔兼偣閳ь剟鏁冮崒姘優闂佸搫娲㈤崹娲磻閿濆鐓曢柕澶涚到婵″潡鏌曢崼婵堟憼濞e洤锕獮鎾诲箳閺傚簱鍙洪梻浣告惈閺堫剙煤濠靛牏涓嶆繛鎴欏灩閸楁娊鏌i幋婵囶棡缂傚秴鐭傚缁樻媴缁嬫寧姣愰梺鍦拡閸嬪﹪鐛繝鍛杸婵炴垶鐟ユ禍妤呮椤愩垺澶勯柟灏栨櫊閹垽宕卞☉娆忎化婵°倧闄勭€笛囶敂閻樺樊鐔嗙憸搴∶洪悢鐓庤摕婵炴垯鍨圭猾宥夋煃瑜滈崜鐔肩嵁閹版澘绠柦妯侯槼閹芥洖鈹戦悙鏉戠仧闁搞劎鎳撹灋婵☆垵宕电粻楣冩煕閳╁啰鎳冨ù婊勫劤铻栭柡鍐ㄥ€荤壕浠嬫煕鐏炲墽鎳勭紒浣规緲椤啰鈧稒蓱閸婃劖顨ラ悙鏉戝缂佺粯绻傞~婵嬵敆閸屻倕鏁搁梻鍌欑閹测剝绗熷Δ鍛瀭闁规儼濮ら崕妤佺箾閸℃ɑ灏紒鐘茬秺閹鈽夊▍铏灩娴滄悂顢橀悘鑽ゆ嚀楗即宕奸姀銏℃瘒闂備礁鎼張顒傜矙閹达箑鐓橀柟杈剧畱缁€瀣亜閹扳晛鐏╃悮姗€姊婚崒娆戝妽婵$偛娼″畷銏$鐎n亞顔囨俊銈忕到閸燁偆绮婚悢鍏肩厵闂傚倸顕崝宥夋煕鐎n亶鍎旈柡灞剧洴椤㈡洟鏁愰崶鈺冩毉闂備浇宕甸崰鍡涘礉閹存繍娼栨繛宸簻娴肩娀鏌涢弴銏℃锭闁告搩鍠氱槐鎾存媴閽樺鍘悗鍏夊亾缂佸顑欓崵鏇炩攽閻樺磭顣查柛瀣閺岋綁骞橀搹顐e闯濡炪倧瀵岄崣鍐箖瀹勬壋鍫柛鎰典簽椤斿﹪姊烘潪鎵窗闁哥姵鐗犻崺銉﹀緞閹邦剦娼婇梺鎸庣☉鐎氼剟鐛幇鐗堚拻濞达絽鎲¢崯鐐层€掑顓ф疁鐎规洘婢樿灃闁告侗鍘鹃敍娆撴⒑鐟欏嫬顥嬪褎顨婇幃鈥斥槈閵忊€斥偓鍫曟煟閹伴偊鏉洪柛銈嗙懃閳规垿顢欓悡搴樺亾閸ф钃熼柣鏃傗拡閺佸﹪鏌涘┑鍡楊仱闁稿鎸搁埞鎴﹀幢濞嗘劖顔曢梻浣告贡閸庛倝宕归悢鑲猴綁宕奸悢绋垮伎濠德板€愰崑鎾翠繆椤愶絾鈷掓俊鍙夊姍閺佹捇鏁撻敓锟� ---闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘辨繝鐢靛Т閸婂綊宕戦妷鈺傜厸閻忕偠顕ф慨鍌溾偓娈垮櫘閸o絽鐣锋總鍛婂亜闁告稑饪撮崬鍫曟⒒閸屾瑨鍏岄弸顏呫亜閹存繃顥㈡鐐村姍瀹曟粏顦查柛銊︾箖閵囧嫰骞樼捄杞版睏濠碘剝褰冮悧濠冪┍婵犲浂鏁嶆慨姗嗗幗閸庢挾绱撴担鍝勑い鏇嗗洤鐓橀柟杈鹃檮閸婄兘鏌涘▎蹇fТ闁哄鐟︾换娑氣偓娑欋缚閻绱掗鑺ュ磳妤犵偛鍟撮崹楣冨棘閵夛富娼旈梻渚€娼ф蹇曟閺囥垹鍌ㄩ柛妤冨亹閺€浠嬫煟閹邦厽缍戦柣蹇嬪劤閳ь剝顫夊ú锕傚礈閻斿吋鍋樻い鏂挎閻旀哺褔宕堕敂鍓ф晨闂傚倷绀侀幖顐﹀磹閸︻厸鍋撶粭娑樻硽婢舵劕顫呴柍鈺佸暙瀵寧绻濋悽闈浶㈤柟鍐茬箻椤㈡棃鎮╃紒妯煎幍闂佽崵鍠愬姗€顢旈鐐╂斀闁斥晛鍟崐鎰攽閿涘嫬鍘撮柡浣稿€块獮鍡氼槾缂佸鐗撳濠氬磼濮橆兘鍋撻悜鑺ュ殑闁割偅娲栫粻鐘绘煙閹规劦鍤欓柛姘秺閺屸€愁吋鎼粹€崇缂備胶濯崹鍫曞蓟閵娾晜鍋嗛柛灞剧☉椤忥拷
开发学院软件开发Java IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 ... 阅读

IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题

 2010-04-01 00:00:00 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄥジ鏌熼惂鍝ョМ闁哄矉缍侀、姗€鎮欓幖顓燁棧闂備線娼уΛ娆戞暜閹烘缍栨繝闈涱儐閺呮煡鏌涘☉鍗炲妞ゃ儲鑹鹃埞鎴炲箠闁稿﹥顨嗛幈銊╂倻閽樺锛涘┑鐐村灍閹崇偤宕堕浣镐缓缂備礁顑嗙€笛囨倵椤掑嫭鈷戦柣鐔告緲閳锋梻绱掗鍛仸鐎规洘鍨块獮鍥偋閸垹骞嶇紓鍌氬€烽悞锕傛晪缂備焦銇嗛崶銊у帗閻熸粍绮撳畷婊堟晝閸屾氨鐓戦梺鍛婂姦閻撳牆岣块弽顓熺厱婵犻潧妫楅悵鏃傛喐閺傝法鏆﹂柟顖炲亰濡茬偓绻涚€电ǹ孝闁靛牏枪椤繘鎼圭憴鍕彴闂佽偐鈷堥崜娑㈩敊婢舵劖鈷戦柣鎾虫捣缁夎櫣绱掗悩宕囧⒌妤犵偛鍟妶锝夊礃閳轰讲鍋撴繝姘參婵☆垯璀﹀Σ濂告煙閼恒儲绀嬫慨濠冩そ濡啫鈽夋潏顭戔偓鍡樼節绾版ǚ鍋撻搹顐㈡灎閻庤娲忛崹浠嬪箖娴犲宸濆┑鐐靛亾鐎氬ジ姊洪懡銈呮瀾闁荤喆鍎抽埀顒佹皑閸忔ê鐣烽婵堢杸婵炴垶鐟ч崢閬嶆⒑缂佹◤顏嗗椤撶喐娅犻柣銏犳啞閻撳繘鏌涢埄鍐炬當闁逞屽墮濠€杈╃磽閹惧顩烽悗锝庝簻缁愭稒绻濋悽闈浶㈤悗姘煎墴閻涱噣宕奸妷锔规嫼缂佺虎鍘奸幊搴ㄋ夊澶嬬厵婵炶尪顔婄花鑺ヤ繆閸欏濮嶇€殿喗鎸抽幃銏ゅ传閸曘劌褰忛梻鍌氬€搁崐鎼佸磹妞嬪孩顐芥慨姗嗗厳缂傛氨鎲稿鍥у疾闂備線娼ч悧鍡椕洪悩璇茬;闁圭偓鍓氬ḿ鈺傘亜閹扳晛鐏╃紒渚囧櫍濮婅櫣绱掑Ο鍦箒闂侀潻缍囩紞渚€鎮伴鈧獮鎺楀箠閾忣偅顥堥柛鈹惧亾濡炪倖甯掗崐缁樼▔瀹ュ鐓ユ繝闈涙椤ョ姷绱掗埦鈧崑鎾绘⒒閸屾艾鈧悂鎮ф繝鍕煓闁硅揪绠戝Ч鍙夌箾閸℃璐╅柣鐔稿閸亪鏌涢鐘茬伄闁哄棭鍋婂娲传閸曨厾鍔圭紓鍌氱С閻掞箓骞堥妸鈺佺劦妞ゆ帒瀚悡鍐煙椤栨粌顣肩痪顓犲亾缁绘繈鍩€椤掍焦缍囬柕濞у懎楠勯梻浣告惈濞层劑宕伴幘璺哄К闁逞屽墮閳规垿顢欓弬銈勭返闂佸憡锕㈢粻鏍х暦閵忋倖鍋ㄩ柛娑樑堥幏铏圭磽閸屾瑧鍔嶉柨姘攽椤曞棛鐣甸柡灞剧洴楠炴﹢寮堕幋婵囨嚈闂備浇顕栭崰妤勬懌濠电偟鍘х换妯讳繆閹间礁围闁搞儮鏅濋弳浼存⒒閸屾瑧顦︽繝鈧潏鈺佸灊妞ゆ牗绮嶉弳婊堟煟閹邦剛鎽犳繛鍛У缁绘盯骞嬮悙瀵告缂佺偓宕橀崑鎰閹惧瓨濯撮悹鎰靛灣缁辨澘鈹戦悙鏉戠祷妞ゆ洦鍙冮崺鈧い鎺戝枤濞兼劖绻涢崣澶屽ⅹ闁伙絿鍏橀、妤呭礃椤忓啰鑳洪梻鍌氬€风粈渚€骞夐敓鐘茬闁哄洢鍨归悿顕€鏌eΟ娆惧殭缂佲偓閸喓绡€闂傚牊绋撴晶娑氣偓瑙勬礀瀵墎鎹㈠☉銏犵闁绘劑鍔庣槐浼存⒑閸濆嫭顥滄俊顐n殜閸╃偤骞嬮敂钘変汗闁哄鐗滈崑鍕储閿熺姵鈷戦弶鐐村閸斿秹鏌eΔ浣虹煂婵″弶鍔欓獮妯尖偓娑櫭鎾寸箾鐎电ǹ孝妞ゆ垵鎳橀獮妤呮偨閸涘ň鎷洪梺闈╁瘜閸樹粙宕甸埀顒€鈹戦悙鑼勾闁稿﹥绻堥獮鍐┿偅閸愨晛鈧鏌﹀Ο渚Ш妞ゆ柨锕铏规喆閸曨剙鍓归梺鍛娒肩划娆忕暦閹剧粯鍋ㄩ柛娑樑堥幏娲⒑閼姐倕鏋戞繝銏★耿楠炲啯绗熼埀顒勫蓟閿濆绠抽柣鎰暩閺嗐倝姊虹拠鈥虫灍妞ゃ劌锕悰顕€寮介妸锕€顎撻梺绋跨箰椤︽壆鈧俺妫勯埞鎴︽倷閼搁潧娑х紓浣瑰絻濞尖€崇暦閺囥垹围濠㈣泛锕ら幆鐐烘⒑闁偛鑻晶瀛樻叏婵犲啯銇濇鐐寸墵閹瑥霉鐎n亙澹曢梺鍝勭▉閸樹粙宕戠€n喗鐓熸俊顖氱仢閸氬湱鈧鎸风欢姘舵偂椤愶箑鐐婇柕濞р偓婵洭姊洪崫鍕櫤闁诡喖鍊垮濠氬Ω閳哄倸浜為梺绋挎湰缁嬫垿顢旈敓锟�婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧濠囧极妤e啯鈷戦柛娑橈功閹冲啰绱掔紒妯虹伌濠碉紕鏁诲畷鐔碱敍濮橀硸鍟嬮梻浣告啞椤ㄥ牓宕戦悢鍝ヮ浄闁兼祴鏅濈壕钘壝归敐鍛儓妞ゅ骸鐭傞弻娑㈠Ω閵壯冪厽閻庢鍠涢褔鍩ユ径鎰潊闁绘ḿ鏁搁弶鎼佹⒒閸屾艾鈧悂鎮ф繝鍕煓闁圭儤顨嗛崐鍫曟煕椤愮姴鍔滈柛濠勬暬閺岋綁鎮㈤崫鍕垫毉闂佸摜鍠撻崑鐔烘閹烘梹瀚氶柟缁樺笚濞堢粯绻濈喊澶岀?闁轰浇顕ч悾鐑芥偄绾拌鲸鏅┑顔斤耿绾悂宕€n喗鈷戦悹鍥ㄧ叀閸欏嫭绻涙担鍐叉搐缁犵儤绻濇繝鍌滃闁稿鏅涢埞鎴﹀磼濮橆厼鏆堥梺鎶芥敱閸ㄥ綊鎯€椤忓牜鏁囬柣鎰綑椤庢稑鈹戦悙鎻掓倯闁告梹鐗滈幑銏犫槈閵忊€虫濡炪倖宸婚崑鎾绘煛鐎n亜顒㈤柕鍥у椤㈡洟濮€閵忋埄鍞虹紓鍌欐祰妞村摜鏁幒鏇犱航闂備礁鍚嬬粊鎾疾濠婂牆鍚圭€光偓閸曨兘鎷绘繛鎾村焹閸嬫捇鏌嶈閸撴盯宕戝☉銏″殣妞ゆ牗绋掑▍鐘炽亜閺冨洤浜归柡鍡楁閺屻劌鈹戦崱娆忣暫闂佸憡鏌ㄩ悘姘跺Φ閸曨垱鏅滈柣锝呰嫰瀵劑姊虹拠鈥虫珯缂佺粯绻冩穱濠囨嚋闂堟稓绐為柣搴秵閸撴瑧鏁ィ鍐┾拻濞达絿枪椤ュ繘鏌涚€n亝鍣介柟骞垮灲瀹曟﹢顢欓懖鈺嬬幢婵$偑鍊曠换鎰板箠閹邦喚涓嶉柛鎾椻偓閸嬫捇鎮烽弶娆炬闂佸摜濮靛ú婊堟嚍鏉堛劎绡€婵﹩鍓涢悾楣冩⒑缂佹ɑ鐓ラ柛姘儔閸╂盯骞嬮敂钘夆偓鐢告煕閿旇骞栭弽锟犳⒑闂堟稒顥滈柛鐔告尦瀵濡舵径濠勵槰闂佽偐鈷堥崜娆撴偂閻斿吋鍊甸悷娆忓缁€鍐磼鐠囪尙澧︾€殿噮鍋婂畷姗€顢欓懖鈺佸Е婵$偑鍊栫敮鎺斺偓姘€鍥х劦妞ゆ帊鐒﹂ˉ鍫⑩偓瑙勬礃閿曘垽銆佸▎鎾冲簥濠㈣鍨板ú锕傛偂閺囥垺鐓冮柍杞扮閺嬨倖绻涢崼鐕傝€块柡宀嬬秮閹垻绮欓崹顕呮綒婵犳鍠栭敃銉ヮ渻娴犲绠栭柍鈺佸暞閸庣喖鏌嶉埡浣告殲闁伙讣缍佸缁樻媴閾忕懓绗¢梺缁橆殕濞茬喐淇婇崜浣虹煓閻犳亽鍔嶅▓楣冩⒑缂佹ê鐏﹀畝锝堟硶瀵囧焵椤掑嫭鈷戦柟鑲╁仜閸斺偓闂佸憡鍔戦崝搴ㄥΧ椤曗偓濮婂宕掑▎鎴犵崲濠电偘鍖犻崟鍨啍闂婎偄娲﹀ú姗€锝為弴銏$厸闁搞儯鍎遍悘鈺呮煕鐏炶濡介柕鍥у缁犳盯骞樼捄渚澑闂備焦濞婇弨閬嶅垂閸ф钃熼柣鏂垮悑閸ゅ啴鏌嶆潪鐗堫樂缂侇喖鐖煎娲川婵犲啠鎷瑰銈冨妼閿曨亜顕f繝姘櫢闁绘ɑ褰冪粣娑橆渻閵堝棙顥堥柡渚囧枟閹便劑宕堕埡鍐紳婵炶揪绲挎灙闁逞屽墮濠€閬嶅极椤曗偓閹垺淇婇幘铏窛闁逞屽墴濞佳囧箺濠婂懎顥氬┑鍌溓圭痪褔鏌涢锝団槈濠德ゅ亹缁辨帒螖娴d警鏆$紓浣虹帛閻╊垶骞冮埄鍐╁劅闁挎繂娴傞崯瀣⒒娴h櫣銆婇柡鍌欑窔瀹曟粌鈹戠€n亞顔嗛梺鍛婄☉閻°劑鎮¢妷鈺傚€甸柨婵嗘噽娴犳稓绱撳鍡╂疁婵﹤顭峰畷鎺戭潩椤戣棄浜剧€瑰嫭鍣磋ぐ鎺戠倞鐟滄粌霉閺嶎厽鐓忓┑鐐靛亾濞呭棝鏌涙繝鍌涘仴闁哄被鍔戝鎾倷濞村浜鹃柛婵勫劤娑撳秹鏌$仦璇插姕闁绘挻娲熼弻鏇熷緞濡儤鐏堟繝鈷€灞芥珝闁哄矉绱曢埀顒婄岛閺呮繄绮i弮鍫熺厸鐎光偓閳ь剟宕伴弽褏鏆︽繝濠傛-濡查箖鏌i姀鈺佺仭闁烩晩鍨跺濠氭晸閻樻彃绐涘銈嗘濡嫰鍩€椤掍礁濮嶉柡宀嬬磿娴狅妇鎷犻幓鎺濇綆闂備浇顕栭崰鎾诲磹濠靛棛鏆﹂柟鐑樺灍濡插牊鎱ㄥΔ鈧Λ鏃傛閿燂拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷  闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘遍梺闈涚墕閹冲酣顢旈銏$厸閻忕偠顕ч埀顒佺箓閻g兘顢曢敃鈧敮闂佹寧妫佹慨銈夋儊鎼粹檧鏀介柣鎰▕閸ょ喎鈹戦鈧ḿ褔锝炲┑瀣╃憸搴綖閺囥垺鐓欓柟瑙勫姦閸ゆ瑧鐥幆褍鎮戠紒缁樼洴瀹曞崬螣閾忓湱鎳嗛梻浣告啞閿曨偆妲愰弴鐘愁潟闁规儳顕悷褰掓煕閵夋垵瀚ぐ顖炴⒒娴h鍋犻柛鏂跨焸閹儵宕楅梻瀵哥畾闂佸湱铏庨崰鏍矆閸愨斂浜滈柡鍐ㄥ€哥敮鍓佺磼閹邦厾娲存慨濠冩そ瀹曨偊宕熼崹顐嵮囨⒑閹肩偛濡肩紓宥咃工閻g兘濮€閻樺棙妞介、鏃堝川椤撴稑浜鹃柛顭戝亽濞堜粙鏌i幇顖氱毢濞寸姰鍨介弻娑㈠籍閳ь剛鍠婂澶娢﹂柛鏇ㄥ灡閺呮粓鎮归崶顏勭毢濞寸姵鎮傞幃妤冩喆閸曨剛鈹涚紓浣虹帛缁诲牓鎮伴鑺ュ劅闁靛⿵绠戝▓鐔兼⒑闂堟冻绱¢柛鎰╁妼椤╊剟姊婚崒姘偓鎼併偑閹绢喖纾婚柛鏇ㄥ€嬪ú顏呮櫇闁逞屽墰閸欏懘姊洪崫鍕犻柛鏂垮閺呭爼鏁撻悩鏂ユ嫽闂佺ǹ鏈悷锔剧矈閻楀牄浜滈柡鍥ф閹冲宕戦幘璇插瀭妞ゆ劑鍨虹拠鐐烘倵鐟欏嫭绀冪紒顔芥崌楠炲啴濮€閿涘嫰妾繝銏f硾椤戝洨绮欐笟鈧缁樻媴閻熸澘濮㈢紓浣虹帛閸旀洟鏁冮姀鈩冪秶闁宠桨绶″Λ婊堟⒑缁嬭法绠绘俊顐ユ硶閹广垽宕卞Ο闀愮盎闂佸搫绉查崝搴ㄣ€傞弻銉︾厵妞ゆ牗姘ㄦ晶娑㈡煏閸パ冾伃妞ゃ垺娲熸慨鈧柕蹇嬪灩婵鲸绻濆▓鍨灈闁挎洏鍔岄埢宥夋晲婢跺﹦顔嗛梺缁樶缚缁垶宕甸幋鐐簻闁圭儤鍨垫禍鐐烘煕閻愰娼愮紒缁樼箓閳绘捇宕归鐣屼憾闂佺厧鐏曢崶銊у幈闂佸搫鍟犻崑鎾绘煕閵娿儳浠㈤柣锝呭槻鐓ゆい蹇撳閸旓箑顪冮妶鍡楃瑐闂傚嫬绉电粋宥呪堪閸喓鍘甸梺鍛婄箓鐎氼喛鍊存俊鐐€х拋锝囩不閹捐钃熸繛鎴欏灩鍥撮柟鑲╄ˉ閳ь剚鏋奸幏顐︽⒒娴e憡鎯堥柡鍫墴閹嫰顢涢悙闈涚ウ濠碘槅鍨伴崥瀣暦婢舵劖鐓熼柟瀵稿亶缂傛岸鏌嶈閸撴繈顢氳閳ユ棃宕橀鍢壯囧箹缁厜鍋撻懠顒傛晨缂傚倸鍊烽懗鍓佸垝椤栫偛绀夋俊銈呮噹閻鏌涘☉鍗炲季婵炴挸顭烽弻鏇㈠醇濠靛洤娅х紓浣哄С閸楁娊骞冨Δ鈧~婵嬫偂鎼粹檧鎷梻浣筋嚃閸犳銆冩繝鍥モ偓浣割潨閳ь剟骞冨⿰鍫濆耿婵☆垵娅eΣ锝夋⒒閸屾瑧绐旀繛浣冲洦鍋嬮柛鈩冦亗濞戞ǚ鏋庨柟瀵稿Х閻掑ジ姊洪柅鐐茶嫰婢у瓨鎱ㄦ繝鍐┿仢闁诡喚鍏樺鍫曞箰鎼淬垻妲梻鍌氬€风粈浣规償濠婂懎绶ゅù鐘差儐閸嬧晝鈧懓瀚竟瀣醇椤忓牊鐓曢柡鍥ュ妼娴滀粙鏌涢妶鍐ㄢ偓婵嬪蓟閿濆棙鍎熼柕蹇婃噰婵洭鏌ょ憗銈呪偓婵嬪蓟閻斿吋鐓ラ悗锝庡亖娴犮垹鈹戦纭峰姛缂侇噮鍨崇划顓㈡偄閻撳海鍊為悷婊冪灱閼鸿鲸绂掔€n偀鎷虹紓浣割儐椤戞瑩宕曢幇鐗堢厽闁冲搫锕ら悘锔筋殽閻愯韬柟顔哄灮閸犲﹥娼忛妸锔界彨濠电姷鏁搁崑鐐哄垂閸洘鍋¢柨鏇炲€归崑鐔衡偓鐟板閸嬪﹤銆掓繝姘厪闁割偅绻冮ˉ鐐烘煟閹惧崬鍔氭い顓″劵椤︽挳鏌¢崪浣镐簼缂佹梻鍠栧鎾閳ュ厖绨甸梺鐟板悑閹矂宕板璺鸿埞闁汇垹鎲¢悡鐔兼煟濡厧鍔嬫い蹇曞█閹ǹ绠涚€n亜顫囬悗瑙勬礃缁诲牓骞冮姀銈嗘優闁革富鍙忕槐鎻掆攽閻橆喖鐏辨繛澶嬬〒閳ь剚绋堥弲鐘汇€侀弮鍫熷亹缂備焦岣块崢鎾绘偡濠婂嫮鐭掔€规洘绮岄~婵囷紣濠靛洦娅撻梻浣告惈缁嬩線宕㈤懖鈺冪幓婵°倕鎳忛悡娑氣偓骞垮劚妤犳悂鐛幇鐗堢厓鐟滄粓宕滈妸褏涓嶉柟鎹愵嚙閽冪喖鏌曟繛褉鍋撻柛瀣崌閺佹劙宕掑☉娆戝絿缂傚倷鑳舵慨鐢告嚌妤e啫鐓橀柟杈惧瘜閺佸﹪鏌i敐鍛伇闁伙絿鏁诲鍝劽虹拠鎻掔闂佺粯顨呭Λ妤€鐣甸崟顖涒拺缂備焦锚閻忓崬鈹戦鍝勨偓婵嬪春濞戙垹绠i柣妯兼暩閿涙粓鏌f惔顖滅У闁稿甯″畷鏇㈠Ψ閳哄倻鍘遍柟鍏肩暘閸ㄨ鎱ㄥ澶嬬厸鐎光偓閳ь剟宕伴弽顓炵畺闁绘垼濮ら崑瀣煕椤愩倕鏋戦柛濠勫厴濮婃椽骞戦幇顒€鎯為梺绋款儍閸婃繂顕g拠娴嬫闁靛繒濮烽悿鈧梻浣哥枃濡椼劎绮堟担鍛婃殰婵犵數濮烽。浠嬪礈濠靛ǹ浜归柛鎰靛枟閸嬪鈹戦悩鎻掝仾鐎规洖寮剁换娑㈠箣濞嗗繒浠煎Δ鐘靛亼閸ㄧ儤绌辨繝鍥ч柛娑卞幗濞堣泛顪冮妶鍡樼叆妞わ富鍨堕崺鐐哄箣閿旇棄鈧兘鏌ょ喊鍗炲妞ゃ倐鍋撻梻鍌欑劍鐎笛兠鸿箛娑樺瀭鐟滅増甯紞鏍叓閸ャ劍绀堢痪鎯у悑娣囧﹪顢涘┑鎰濡炪倕瀛╅幐缁樼┍婵犲洦鍊风€瑰壊鍠栭崜鎵磽娴i潧濮€闁稿鍔欓獮澶嬪閺夋垵鑰垮┑鐐叉閸ㄥ綊鏁嶅┑瀣拺缂佸瀵у﹢鐗堟叏濡ǹ濮€闁愁亞鏁诲缁樻媴閸涢潧缍婇、鏍幢濞戞ḿ顔囬梺鐓庮潟閸婃牕鐣烽崣澶岀闁瑰鍋涢悞褰掓煕鐎n偅灏柍钘夘槸閳诲海鈧綆鍓涚粣妤呮⒒娴h銇熼柛妯虹秺瀹曟劕鈹戠€n亣鎽曞┑鐐村灟閸ㄥ湱绮绘繝姘仯闁惧繒鎳撻崝瀣煟韫囨挾澧﹂柟顔筋殘閹叉挳宕熼鍌ゆО婵犵绱曢崑妯煎垝濞嗗繒鏆︽繛宸簻閻掑灚銇勯幒宥夋濞存粍绮撻弻鐔煎传閸曨厜褎淇婇幆褍妲婚棁澶嬬節婵犲倸顏柣顓熷浮閺屸€崇暆閳ь剟宕伴弽顓炵畺婵犲﹤鍚橀悢鍏兼優闂侇偅绋掑Ο濠囨⒒閸屾瑧绐旈柍褜鍓涢崑娑㈡嚐椤栨稒娅犳い鏂垮⒔绾剧晫鈧箍鍎遍幏鎴濐啅閵夛负浜滈柡鍥朵簽缁夘喗顨ラ悙鍙夋崳缂侇喚鏁搁埀顒婄秵閸嬪懎鈻嶅畝鍕拻濞达絽鎲¢崯鐐寸箾鐠囇呯暤鐎规洘绮岄埥澶愬閻樻彃浜堕梻鍌欑贰閸撴瑧绮旈悽鍛婂亗闁绘梻鍘х粻褰掓煙绾板崬骞栭柣蹇ョ悼缁辨帗寰勯幇顓熼敪闂傚洤顦扮换婵囩節閸屾稑娅i梺鍛娚戦幐鎶藉蓟閿濆绠奸柛鎰╁妼閳峰顪冮妶鍐ㄧ仾妞ゃ劌锕ら悾鐑藉箳閹宠櫕妫冮崺鈧い鎺嶈兌椤╂彃螖閿濆懎鏆為柛瀣у墲缁绘盯宕卞Δ鍐唶濡炪倕娴氭禍鐐烘儉椤忓牆绠氱憸婊堟偂婵傚憡鐓涢悘鐐插⒔閳藉鎽堕弽顓熺厓鐟滄粓宕滈悢椋庢殾妞ゆ牜鍋涢柨銈嗕繆閵堝拑鏀婚柡鍜佷邯濮婃椽骞愭惔锝囩暤濡炪倧瀵岄崹铏珶閺嚶颁汗闁圭儤鎸鹃崢浠嬫⒑閸濆嫭澶勬慨妯稿姂瀹曟繂顓兼径瀣垫闁诲函缍嗛崰妤呭煕閹烘鐓曢悘鐐插⒔閹冲懏銇勯敂鑲╃暤闁哄瞼鍠撻崰濠囧础閻愭壆鐩庨梺鎹愬吹閸嬨倝骞冨Δ鍛棃婵炴垶鐟﹂崰鎰箾閹寸偞灏紒澶婄秺瀵鎮㈤悡搴n唹闂侀€涘嵆濞佳冣枔椤撱垺鈷戦柦妯侯槸閺嗙喖鏌涢悩宕囧⒌鐎殿喖顭峰鎾偄閾忚鍟庨梻浣虹帛閸旓箓宕滃鑸靛仧闁哄洢鍨洪埛鎴犵磼鐎n偒鍎ラ柛搴$箲娣囧﹪顢曢敐鍥╃杽閻庢鍠涢褔鍩ユ径濠庢僵妞ゆ劧绲芥刊浼存⒒娴e憡鍟為柟绋挎閸┾偓妞ゆ巻鍋撻崡閬嶆煕椤愶絿绠ユ繛鎾愁煼閺屾洟宕煎┑鍥ф畻闂佺粯绋掔划鎾诲蓟閻旂厧绀勯柕鍫濇椤忥拷
核心提示:当今很多 Java 应用程序都通过使用线程来利用该语言的功能,从而支持并发编程,IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题,很多线程可以共享相同的数据对象,但是如果应用程序中控制线程的部分设计得不好,您将回到在本系列的第 1 部分介绍的 Dump A

当今很多 Java 应用程序都通过使用线程来利用该语言的功能,从而支持并发编程。很多线程可以共享相同的数据对象,但是如果应用程序中控制线程的部分设计得不好,则您可能会遇到锁争用问题从而降低性能。

例如,在多线程应用程序中,如果多个线程访问相同的资源进行读写访问, 则可能会出现线程同步问题。如果一个线程尝试读取某个文件,而另一个线程 对其进行写访问,则可能会损坏数据。为了解决这个问题,Java 语言允许一个线程获得对对象的专有锁, 从而防止其他任何线程访问它。一旦该线程完成对该对象的处理之后,便释放该对象,以便 其他线程可以进行访问。但是,如果应用程序没有进行过精心设计,则这种机制可能会导致更高级别的争用。

如果一个锁正在使用中,而另一个线程尝试获取它,这时会发生锁争用。 如果锁被频繁获得和/或持有时间较长,则可能会发生更高级别的争用。 更高级别的锁争用(很多线程尝试访问它)将成为系统中的瓶颈, 因为每个运行的线程将暂停执行,直到它所需的锁变为可用为止, 这样便限制了应用程序的性能。

使用 JLA 防止出现锁问题

面向 Java 的 IBM 锁分析器 (JLA) 是 alphaWorks 中的新工具,它可以 在运行 IBM 提供的 Java SDK 或 JRE 版本 5.0 或更高版本的的任何平台上运行, 对活动应用程序执行锁分析,以突出显示线程的活动并且提供对锁争用频率的深入洞察。该视图可以帮助解决锁争用问题以及性能问题。

JLA 一边运行现有的 Java 应用程序,一边收集该应用程序的所有锁信息。记录每个锁及其详细信息,如保持的时间、是否争用以及它阻塞线程尝试获得它的时间百分比。该工具由运行时库和前端图形用户界面组成,前者必须在启动所要监视的应用程序时加载,后者可以显示结果和性能分析。

JLA 设计详细信息

JLA 由以下两个程序包组成:

JLAagent。该程序包与平台有关,由特定于平台的库文件和一组打包成 JAR 的 Java 类组成,它提供与 Java 虚拟机 (JVM) 的连接以收集有关运行的应用程序的锁统计信息。

JLAGui。该程序包是使用 Swing 编写的,它与平台无关,提供图形用户界面。

JLAagent 中的本地库是用 C 编写的并且使用 Java 虚拟机工具界面 ( Java Virtual Machine Tool Interface,JVM TI)。该界面提供方法控制在 JVM 中运行的应用程序的执行。通过该界面,您可以利用 IBM 发布的 JVM 中可用的功能收集线程统计信息。还可以通过对您要分析的 Java 应用程序的启动命令进行修改,让 JVM 在启动时加载此本地库。然后本地库使用与它一起打包的 Java 类创建一个平台 MBean 服务器,该服务器提供允许 JLAGui 连接 JLAagent 的机制。

启动 MBean 服务器之后, JLAGui 可以通过将该服务器导航到本地库中,然后导航到运行的 JVM 中,从而请求运行的应用程序的锁统计信息。由于 JLAagent 和 JLAGui 通过 MBeans 连接,因此它们没有必要在同一机器上运行;JLAGui 还可以从网络上的任意位置连接到 MBean 服务器。

运行 JLA

若要运行 JLA,您必须首先为您的应用程序配置 JLAagent。 然后您才可以启动 JLAGui 开始监视锁性能。如果您尚未这样做, 请 下载 JLA 以便您可以跟随本文的操作。

配置应用程序以使用 JLA

有很多版本的 JLAagent,IBM 提供的 JRE 支持的每个平台使用一个版本;您必须确保使用的 JLAagent 与您要监视的应用程序将运行的平台相对应。如果您使用了错误版本的 JLAagent,则尝试监视的应用程序将无法加载并且将崩溃。根据将要启动它的 JRE 的基础架构,每个 JLAagent 程序包都具有一个名称。

在运行所要监视的应用程序的计算机上,将 JLAagent 程序包解压缩到某个目录。将该目录添加到 Java 类路径和系统路径。属性文件名为 JLAtiagent。属性包含在该程序包中;它包含有关启动 MBean 服务器的连接信息。如果您想修改默认值,可以编辑该属性。

若要为将进行分析的应用程序加载 JLAagent,请修改该应用程序的启动命令。 添加 -agentlib:JLAtiagent 参数以便它加载本地库, 将添加的 JLAtiagent.jar 添加到类路径, 并指定 JLAtiagent.properties 文件的位置。

例如,启动命令 java dummy.class 将需要进行如下修改:

java -Dcom.sun.management.config.file=JLAtiagent.properties 
   -agentlib:JLAtiagent -cp .;JLAagent.jar dummy.class

如果此时出现异常,请进行检查以确保使用正确的 JLAagent 版本。如果一切正常,将会在命令行上显示消息 JLA 客户机正在注册 MBeanServer。

此时,JLAagent 已经指导 VM 开始记录锁详细信息,即使 JLAGui 未运行也是如此。这意味着当启动 JLAGui 时,您将能够查看整个应用程序生命周期中的锁统计信息。

JLAGui

您可以使用以下命令启动 JLAGui:

java -jar JLAGui.jar 

默认情况下, JLAGui 将查找在本地主机端口 1972 上运行的 MBean 服务器;同样不需要指定这些值。但是如果您想使用不同的值,则可以在命令行上修改主机或端口值,如表 1 所示:

表 1. JLAGui 的连接选项

设置默认值说明
-Dcom.ibm.jla.port1972需要匹配 JLAtiagent 使用的 com.sun.management.jmxremote.port 值
-Dcom.ibm.jla.hostname本地主机如果想监视在远程机器上运行的应用程序,可以设置为 IP 地址或有效的主机名

当启动 GUI 时,它将尝试通过机器上运行的 MBean 服务器以及在启动选项中指定的端口号连接到代理程序。 如果连接成功,则图 1 中的屏幕将显示:

图 1. 初始 JLA 屏幕
IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题

查看原图(大图)

如果连接未成功,则会显示错误消息,并提供 GUI 尝试连接的详细信息。仔细查看错误消息以确保连接正确。如有必要,您可以关闭 GUI,然后用修改后的命令行选项重新启动。您还可以进行检查以确保要分析的应用程序正在运行附带的本机代理程序。

单击 Create Report 按钮即可创建正在监视的应用程序当前线程统计信息的快照报告。您将看到三个面板(参见图 2),它们显示 Java 监视程序(应用程序创建的那些监视程序)、系统监视程序(VM 创建的那些监视程序)以及摘要报告页。应用程序创建或使用的任何监视程序在表和图中都有一个条目。每个监视程序只有一个条目可见,即使有多个线程访问它也是如此。将在监视程序级别而不是线程级别记录该数据。

图 2. JLA 报告示例
IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题

查看原图(大图)

每一列的高度基于慢锁计数的值,它与图中的所有列有关。当请求的监视程序已经被另一个线程拥有并且请求线程被阻塞时会发生缓慢计数。每个条状图形的颜色基于 %MISS 列的值(参见表 2),从红色 (100%) 逐渐过渡到黄色 (50%),并且最终变为绿色 (0%)。红色条表示每次请求监视程序时线程都会阻塞,而绿色条表示线程从不阻塞。对图进行快速扫描将显示执行得不太好的那些监视程序。

表 2 解释报告表中各列值的说明:

表 2. 报告表图例

列名说明
%MISS当请求的线程被阻塞以等待监视程序时总 gets(获取)的百分比。
GETS成功获取的总数。
NONREC非递归获取的总数。该数包括 SLOW gets。
SLOW非递归获取(导致阻塞请求线程以等待释放监视程序)的总数。NONREC 中包含该数。
REC递归获取的总数。递归获取表示请求的线程已经拥有监视程序 。
TIER2支持三层自旋锁的平台上,层 2(内部自旋循环)迭代的总数。
TIER3支持三层自旋锁的平台上,层 3(外部线程让步循环)迭代的总数。
%UTIL监视程序持有时间除以时间间隔。必须打开持有时间计数。
AVER_HTM监视程序的平均持有时间;不包括递归获取,因为递归获取时已经拥有监视程序。
MONITOR NAME监视程序名称,如果不知道名称,则为 NULL(空白)。

运行中的 JLA

一个简单的应用程序示例将帮助您了解如何使用 JLA 帮助查找锁争用的区域。假设一个应用程序由两个线程组成,而这两个线程都尝试访问同一个对象。本例中,该对象就是一个名为 JLAsink 的类,该类包含两个同步的方法,一个用于设置数据块,一个用于检索该数据块。这两个线程同时开始并且都在一个循环中运行以同时访问 JLAsink。一个线程称为 setter 方法,另一个线程称为 retrieval 方法。

图 3 显示在性能较差的示例应用程序中运行 JLA 的结果:

图 3. 最初的 JLA 快照
IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题

查看原图(大图)

可以从此屏幕截图中看到,JLAsink 监视程序进行了 9,161 次 get,并且请求线程被阻塞,阻止它获得 25% 的锁时间。很明显,当处理尝试获得锁的线程时,应用程序的这部分性能将有所下降。

图 4 显示在更高效的示例应用程序中运行的 JLA:

图 4. 在优化的应用程序中运行 JLA 的快照
IBM 的 Java 诊断,第 3 部分: 使用面向 Java 的 Lock Analyzer 诊断同步和锁问题

查看原图(大图) 

您可以看出 JLAsink 监视程序进行了 9,370 次 get,并且没有阻塞任何一个线程。这表明在处理锁争用时,该监视程序运行得比较理想。现在优化的代码比未优化的代码运行速度更快,您可以通过比较每次运行的时间间隔看到这一点。 第二次运行访问 JLAsink 对象的次数比第一次运行多,并且它花的时间较少。

未来计划

随着当前功能的完善,该工具的发展正逐渐稳定。将来,我们的团队将在 JLA 的基础上发布一个新工具,该工具将超越锁统计信息,提供对活动 Java 应用程序的分析。该工具不仅仅具有 JLA 的功能,而且还具有 EVTK 和 Dump Analyzer 工具的功能。目前该工具还处于设计阶段。

结束语

在本系列的下一篇文章中,您将回到在本系列的第 1 部分介绍的 Dump Analyzer 工具。 您将对该工具的扩展性获得更深入的了解,并且还将学习如何构建您自己的分析模块。

Tags:IBM Java 诊断

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接