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Т闁哄鐟︾换娑氣偓娑欋缚閻绱掗鑺ュ磳妤犵偛鍟撮崹楣冨棘閵夛富娼旈梻渚€娼ф蹇曟閺囥垹鍌ㄩ柛妤冨亹閺€浠嬫煟閹邦厽缍戦柣蹇嬪劤閳ь剝顫夊ú锕傚礈閻斿吋鍋樻い鏂挎閻旀哺褔宕堕敂鍓ф晨闂傚倷绀侀幖顐﹀磹閸︻厸鍋撶粭娑樻硽婢舵劕顫呴柍鈺佸暙瀵寧绻濋悽闈浶㈤柟鍐茬箻椤㈡棃鎮╃紒妯煎幍闂佽崵鍠愬姗€顢旈鐐╂斀闁斥晛鍟崐鎰攽閿涘嫬鍘撮柡浣稿€块獮鍡氼槾缂佸鐗撳濠氬磼濮橆兘鍋撻悜鑺ュ殑闁割偅娲栫粻鐘绘煙閹规劦鍤欓柛姘秺閺屸€愁吋鎼粹€崇缂備胶濯崹鍫曞蓟閵娾晜鍋嗛柛灞剧☉椤忥拷
开发学院数据库DB2 在 Linux 上利用数据分区功能提高可伸缩性和性能 阅读

在 Linux 上利用数据分区功能提高可伸缩性和性能

 2008-09-17 16:31:30 来源: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硾椤戝洨绮欐笟鈧缁樻媴閻熸澘濮㈢紓浣虹帛閸旀洟鏁冮姀鈩冪秶闁宠桨绶″Λ婊堟⒑缁嬭法绠绘俊顐ユ硶閹广垽宕卞Ο闀愮盎闂佸搫绉查崝搴ㄣ€傞弻銉︾厵妞ゆ牗姘ㄦ晶娑㈡煏閸パ冾伃妞ゃ垺娲熸慨鈧柍鎯帮骏閸ㄦ椽濡甸崟顖f晜闁告洦鍋呭▓缁樼節绾版ǚ鍋撳畷鍥х厽閻庤娲栧畷顒冪亙闂侀€炲苯澧撮柨婵堝仦閹棃濡搁敂瑙勫闂備礁鎲$粙鎴︺偑閹绢喗鍊垮┑鍌氭啞閻撴洟鏌曟径瀣仴闁瑰啿楠搁锝夊Ω閵夈垺鏂€闂佺粯锕╅崰鏍倶鏉堛劎绠惧璺侯儑椤ジ鏌h閻倸顫忛搹鍦<婵☆垵宕甸崣鍡涙⒑閸涘﹨澹樻い鎴濐樀楠炲啴鏁撻悩鍙傘劑鏌嶉崫鍕偓鎼佸焵椤掑倹鏆柡灞诲妼閳规垿宕卞☉鎵佸亾濡ゅ懏鐓曟俊顖滅帛鐏忥箓鏌$仦鍓с€掗柍褜鍓ㄧ紞鍡涘磻閸涱垯鐒婇柟娈垮枤绾捐偐绱撴担璐細缂佺姵鎸婚妵鍕敃閿濆洨鐤勫銈冨灪閿氶柍钘夘槸閳诲氦绠涢敐鍕そ闂傚倸鍊峰ù鍥х暦閻㈢ǹ绐楅柟閭﹀枛閸ㄦ繈骞栧ǎ顒€鐏繛鍛У娣囧﹪濡堕崨顓熸闂佸搫妫欑划鎾诲蓟閻斿吋鍊绘俊顖濐嚙閺嗘顪冮妶鍌涙珕鐟滄澘鍟村﹢渚€姊虹紒妯诲碍婵炲鍏橀獮妤呮偐缂佹ḿ鍘介梺瑙勫劤閻°劎绮堢€n喗鐓涚€光偓閳ь剟宕伴弽顓犲祦闁糕剝鍑瑰銊╂⒑閹肩偛鈧宕伴弽顓炶摕鐎广儱顦扮€电姴顭块懜鐬垿鍩㈤崼銉︹拺闁告繂瀚€氭壆绱掓径濠傤暢婵″弶鍔欓獮鎺楀箠瀹曞洤鏋涢柟绛圭節婵″爼宕ㄩ鐔荤发濠电姷顣槐鏇㈠磻閹达箑纾归柕鍫濐槸绾惧鏌涘☉鍗炵仭鐎规洘鐓¢弻娑㈩敃閻樻彃濮庣紓浣哄Х婵數鎹㈠┑鍥╃瘈闁稿本绋戝▍锝夋⒑閸濆嫷鍎忛柣妤€锕ョ粚杈ㄧ節閸ヨ埖鏅┑鐘茬仛閸旀洖鈻撻鐑嗘富闁靛牆鎳愮粻鎵磽瀹ュ拑宸ユい顐㈢箲缁绘繂顫濋鍌︾床婵犵數鍋涘Λ娆撳春閸惊锝夘敋閳ь剙顫忛搹瑙勫厹闁告粈绀佸▓婵堢磽娴d粙鍝烘繛鍙夌矒瀹曟岸骞掗幋鏃€鐎婚梺瑙勫劤绾绢參顢樺ú顏呪拺闁圭ǹ瀛╅悡銉╂煙绾板崬浜濈紒鍌氱У缁轰粙宕ㄦ繛鐐闂備礁鎲$换鍌溾偓姘槻鍗辩憸鐗堝笚閻撴洟鏌曟繛褍鍟悘鍫ユ倵濞堝灝鏋熼柟顔煎€搁锝夘敋閳ь剙鐣锋總鍛婂亜闁告繂瀚粻浼存⒒閸屾瑧顦﹂柟璇х節瀹曟繆顦寸€垫澘锕幊鐐哄Ψ瑜滃ú鎼佹⒑閸涘﹥瀵欓柛娑卞灲缁卞啿鈹戦悙鑸靛涧缂傚秮鍋撳┑鐐叉嫅缁插潡寮灏栨婵ǹ浜敍婊堟煟鎼搭垳绉甸柛瀣噽娴滄悂骞嶉鍓э紲闂佺ǹ鏈粙鎴澝归鈧弻鈩冩媴缁嬫寧娈婚悗瑙勬礃鐢帡锝炲┑瀣疅閻庯綆鍓欑花銉︾節閻㈤潧校妞ゆ梹鐗犲畷鏉课旈崨顔芥珖闂佸啿鎼幊搴g矆閸儲鐓ラ柡鍥╁仜閳ь剙缍婂畷鎰版偨閸涘﹦鍘甸梺璇″灡濠㈡ǹ顣块梻浣瑰▕閺€杈╂暜閹烘绠掗梻浣瑰缁诲倿骞婅箛娑樼疅闁归棿鐒﹂悡銉︾箾閹寸偍缂氶懖鏍磽娴d粙鍝洪悽顖ょ節閵嗕礁顫濈捄鍝勭獩濡炪倖鎸炬慨鍐差浖閹剧繝绻嗛柕鍫濇搐鍟搁梺绋款儑閸嬨倕鐣疯ぐ鎺戝瀭妞ゆ梻鍋撳▓楣冩⒑閸撴彃浜濇繛璇х畵瀵偊宕卞☉娆戝幈闁诲繒鍋熼崑鎾绘儍閹达附鐓忛柛顐墰閻e灚鎱ㄦ繝鍛仩闁归濞€楠炴捇骞掗幋鐐垫И缂傚倸鍊搁崐鍝ョ矓閺夋嚦娑樷枎閹寸姷鐒块悗骞垮劚椤︻垶宕橀埀顒€顪冮妶鍡樺暗闁稿鍠栧畷顐⑽旀担铏诡啎闁诲海鏁告灙鐎涙繂顪冮妶鍡楃仴婵☆偅绻堥獮鍐灳閺傘儲鐎婚梺鐟板⒔鐞涖儵骞忛崫鍕垫富闁靛牆妫欑亸顏堟煕閺傚潡鍙勯柟顕€绠栧畷锟犳倻閸℃瑥鏁搁柣鐔哥矋缁挸鐣疯ぐ鎺撶劶鐎广儱鎲橀敃鍌涚厱闁哄洢鍔岄悘鐘充繆椤愶綇鑰块柡灞剧洴閳ワ箓骞嬪┑鍥╀簮闂備胶枪椤戝棝骞愭ィ鍐ㄧ疅闁圭虎鍠栫粈瀣亜閹惧鈯曢柡渚€娼ч埞鎴︽偐閸偅姣勬繝娈垮枟濞兼瑧鍙呴梺鎸庢礀閸婂摜澹曡ぐ鎺撯拺闁割煈鍣崕宥吤瑰⿰鍕煉闁绘搩鍋婂畷鍫曞Ω閿曗偓绾板秴顪冮妶鍛疄闁稿﹥绻堝璇测槈濮橈絽浜鹃柨婵嗛娴滄繄鈧娲栭惉濂稿焵椤掍緡鍟忛柛鐘崇墵閸┾偓妞ゆ帒鍊稿▍蹇斾繆娣囧崬濡奸柍瑙勫灴閹瑩骞撻幒鎾斥偓顖炴⒑缂佹﹩娈曟繛鑼枛瀹曟椽鎮欓崫鍕吅闂佹寧妫佸Λ鍕瑜版帗鐓熼幖绮瑰墲鐠愨€斥攽椤旇姤灏﹂挊鐔哥節闂堟侗鍎愰柍閿嬪灩缁辨帞鈧綆鍘奸崝鍨亜椤愵剛鐣甸柡灞剧洴瀵剟宕稿Δ鈧鏉课旈悩闈涗粶妞わ富鍨堕敐鐐哄閻樺灚娈曢梺閫炲苯澧撮柟顔兼健閸┾偓妞ゆ巻鍋撻柍瑙勫灴閹瑩寮堕幋鐘辨閻庡厜鍋撻柨婵嗘噺閸嬨儵鏌熼鍏煎仴鐎规洏鍔庨埀顒佺⊕鑿ら柟閿嬫そ濮婃椽妫冮埡浣烘В闂佸憡鐟㈤崑鎾斥攽閿涘嫬浜鹃柟顔煎€垮璇测槈閵忊€充汗闂佸綊顣﹂悞锕傛偪娓氣偓閹鈻撻崹顔界亶闂佺粯鎼换婵嬫偘椤曗偓瀵粙濡搁敃鈧鎾绘⒑闂堚晛鐦滈柛妯煎帶椤曪綁骞庨懞銉㈡嫽婵炶揪缍€濞咃絿鏁☉娆戠闁告瑥顦辨晶鐢碘偓瑙勬礃閸旀瑥鐣烽悜绛嬫晣婵炴垶眉婢规洖鈹戦缁撶細闁稿鎸鹃埀顒佺啲閹凤拷
核心提示:本文首先考察了 DB2 UDB for Linux®、UNIX® 和 Windows® 中的 IBM DB2® Universal Database™ 数据分区功能(Data Partitioning Feature,DPF)在性能和可伸缩性方面的优点,在 Linux 上利用

本文首先考察了 DB2 UDB for Linux®、UNIX® 和 Windows® 中的 IBM DB2® Universal Database™ 数据分区功能(Data Partitioning Feature,DPF)在性能和可伸缩性方面的优点。然后,完成在 SUSE Linux Enterprise Server 上安装和配置具有 DPF 功能的 DB2 的步骤。您还将学习到一些重要的概念和设计方面的考虑,这些将帮助您快速掌握 SUSE Linux Enterprise 环境中 DPF 的安装。

简介

当一个数据库由两个或更多数据库分区组成,并且每个数据库分区存储位于其中的每个表的一部分表数据时,就属于数据库分区的情况。不同分区可以在不同计算机上,也可以在相同的计算机上(即逻辑分区)。在这种类型的数据库中,数据被根据存储位置进行散列,以标识哪个数据库分区将存储数据。一个数据库分区由它自己的数据、索引、配置文件和事务逻辑组成。在更旧版本的 DB2 中,数据库分区被称作节点(node)或数据库节点。但是在本文中我们使用术语分区(partition)。逻辑分区共享它们所在的同一台计算机上的资源。

在分区数据库中,一个表可以分布在一个或多个数据库分区中。分区背后的思想就是将一个表的数据分布在多个分区中,将该表中的一部分行存储在一个分区中,而将其他行存储在其他分区中。数据库管理器(DBM)通过自动地将 SQL 请求分解成子请求,来处理数据的检索和更新。然后,这些子请求就在相应的数据库分区中并行地执行。将表划分到多个分区的这种行为对于用户来说是透明的,这意味着虽然数据在物理上是存储在多个数据库分区上的,但是访问起来就像是在一个地方一样。

图 1 展示了运行在一台机器上的单个分区,这类似于没有使用 DPF:

图 1. 单个机器上的单个分区

在 Linux 上利用数据分区功能提高可伸缩性和性能

接下来的两个图展示了 DPF 真正起作用的情况。图 2 说明了 DPF 被用于三台机器上的情况,其中每台机器上有一个分区。

图 2. 每台机器上一个分区,使用高速通信

在 Linux 上利用数据分区功能提高可伸缩性和性能

注意这里使用的高速通信互连,这可以是各机器之间使用的一个 TCPIP 网络。接下来的 图 3 展示了同一台机器上的三个分区。这里,分区间的通信是在内存中实现的,而不是通过一个网络(在所有 Linux 平台上,默认情况下 DB2 _FORCE_FCM_BP 是启用的)。

图 3. 同一台机器上的三个分区,通过内存进行通信

在 Linux 上利用数据分区功能提高可伸缩性和性能

特别要注意,在前面几个图中,对称多处理器(SMP)也可以换成单处理器。但是,在 DPF 环境中 SMP 服务器更为常见。

分区键 由表中的一列或多列组成,用于使用户可以选择如何对他们的数据进行分区。用户可以通过使用数据库分区组和表空间,来确定将表数据分布到哪些数据库分区上。

用户交互通过一个数据库分区,即用于该用户的协调分区(coordinator partition)来进行。协调分区与应用程序运行在同一个数据库分区上,或者,对于远程应用程序,协调分区运行在应用程序所连接的那个数据库分区上。任何数据库分区都可以成为协调分区。

理解 DB2 Data Partitioning Feature (DPF)

要对一个数据库进行分区,需要 DB2 的 Database Partitioning Feature (DPF) 功能。这种可选的 Database Partition Feature 许可只对 DB2 Enterprise Server Edition (ESE) 可用,其费用按照分区数据库中所使用的 CPU 的数量来计算。

何时分区,为何分区

具有 DPF 功能的 DB2 UDB ESE 是管理 OLAP、数据仓库和数据挖掘工作负载的理想选择。对于大型 OLTP 工作负载,它也是很好的选择。最常见的分区环境由每个物理系统上的一个数据库分区组成,这些物理系统组成数据库分区集群。每个数据库分区上的数据库管理器使用每个系统上的处理器来管理数据库中属于该分区的那部分数据。

由于数据被划分在多个数据库分区上,因而可以使用多台计算机上的多个处理器的处理能力来满足对信息的请求。数据检索和更新请求被自动分解成一些子请求,然后这些子请求在相应的数据库分区中并行地执行。每多一个服务器,就意味着将有更多的 CPU、内存和更多的磁盘用于分区数据库。

性能的提升源于这样的事实:大量的数据被划分成更小的、更易管理的块,每个分区/系统可以同时运行。如果要处理提取、转换和载入操作(ETL),而批处理窗口又比较小,那么可以考虑使用 DPF。例如,DB2 LOAD 可以在每个分区上同时运行,负载操作可以并行地分摊到多个服务器上。创建索引的性能也将显著提升。而且,通过使用 DPF,可以显著缩短备份和恢复时间,因为每台参与分区的机器需要处理的数据量更小了。

在 SUSE Linux Enterprise Server V9 上安装 DB2 V8.2

下面我们来介绍在 SUSE Server(或多服务器)环境中安装和运行 DB2 DPF 所需的步骤。

步骤 1. 检验其他软件包

DB2 要求在 Linux 系统上安装以下包:

Public domain korn shell (pdksh)

Remote shell (rsh) 或 open source secure shell (OpenSSH)

IBM Java™ 2 Java Run Time

Network File Server (nfs)

使用 rpm 命令来检验这些包是否已安装:

rpm -qa | grep pdksh

rpm -qa | grep rsh 或 rpm -qa | grep openssh

rpm -qa | grep IBMjava

rpm -qa | grep nfs

步骤 2. 检验内核参数

在安装 Linux 之前,请确认目前所推荐的、适合 DB2 的 Linux 版本。链接 “http://www.ibm.com/software/data/db2/linux/validate/” 显示了受支持的 Linux 发行版。确保安装受推荐、受支持版本的 Linux。

在安装 DB2 时,需要注意一些内核参数:

表 1. 对 DB2 有影响的内核参数

内核参数描述
kernel.shmmax定义系统范围内允许的最大共享内存段大小,单位为字节
kernel.msgmni定义在任何时刻系统上允许的最多消息队列标识符个数
fs.file-max定义 Linux 内核最多分配的文件句柄个数
kernel.sem定义信号量限制:

每个数组的最多信号量个数(semmsl)

系统范围内最多允许的信号量个数(semmns)

每次 semop 调用的最大操作数(semopm)

最多允许的数组个数(semmni)

** 信号量提供了进程间的低级同步,使得只有一个进程可以访问共享段,从而确保共享段的完整性。

在 Kernel 2.4.18 及以后版本中,file-max 参数的默认值是 8192,因此可能不需要修改它。可以使用以下命令来检查 file-max 值:

cat /proc/sys/fs/file-max

使用 lpcs 命令显示当前的 Linux 内核设置:

lpcs -l

从 DB2 UDB Version 8.2 以后,DB2 在启动时将检查 semmni、msgmni 和 shmmax 参数的值,如果当前值不是最佳的,则更新之。DB2 自动将内核参数设置如下:

semmni 被改为 1024。

msgmni 被改为 1024。

shmmax 被改为 268435456 (32-位) 或 1073741824 (64-位)。

注意,系统范围内最多信号量个数(semmns)等于:

数组的最多个数 (semmni) * 每个数组的最多信号量个数 (semmsl)

在安装 DB2 后,还可以通过 db2pd 命令检验 semni、msgmni、shmmax 参数:

db2pd -osinfo

在性能调优时,可能还需要调整其他内核参数。手册上的规程如下:

以具有 root 权限的用户登录。

创建一个 /etc/sysctl.conf 文件,如果还没有该文件的话。

在 /etc/sysctl.conf 文件中添加内核条目。

运行 sysctl -p 从默认文件 /etc/sysctl.conf 装载 sysctl 设置。

添加 sysctl -p 到一个系统初始化文件中,以便在每次重新启动时设置内核参数。

步骤 3. 检验网络

文件 /etc/hosts 包含指定给主机名的地址(包括一个 IP 地址、全限定主机名和主机名)。为了得到最佳性能,应确保所有参与的服务器在 /etc/hosts 文件中都有定义。

步骤 4. 启用远程 shell 实用程序

对于数据分区环境,DB2 需要一个远程 shell 实用程序来在远程分区上执行命令。在 DB2 UDB V8.2.2 之前,rsh 实用程序被默认用作远程 shell 机制,用于分区之间的通信。为了强认证和安全网络通信的需要,DB2 UDB V8.2.2 现在允许在一个名为 DB2RSHCMD 的注册表 profile 变量中指定远程 shell 实用程序的完整路径,从而增加了对备用远程 shell 实用程序的支持。

OpenSSH (Open Source Secure Shell) 用于代替 rsh 实用程序,以便在不安全的通道上提供有安全保障的通信。OpenSSH 支持两种类型的加密,即基于主机的认证和公钥认证。关于在 DB2 中使用 OpenSSH 的详细信息,请参考标题为 “配置 DB2 Universal Database for UNIX 以使用 OpenSSH” 的技术文章,这篇文章解释了如何在 DB2 中启用 OpenSSH。

为支持一个受安全保障的环境,在数据库分区环境中,应该使用 OpenSSH,而不是 rsh。如果选择启用 rsh 服务,那么只需去掉 /etc/inetd.conf 文件中与 in.rshd 服务对应的 "#" 字符。为了重新启动 inetd 服务器,可以输入:

/etc/init.d/inetd restart

步骤 5. 设置 Network File System (NFS)

对于一个数据分区配置,必须有一个可供所有参与分区数据库系统的机器使用的文件系统。这个文件系统将用于 DB2 实例的 home 目录。容纳 DB2 实例的机器称作 instance-owning 机器。为了共享该文件系统,必须配置 Network File System。对于 Linux,可以通过发出以下命令来检验 NFS 服务器是否正在运行:

showmount -e hostname

该命令显示在一个 NFS 服务器中定义的文件系统的一个列表。如果 NFS 不在运行,那么将收到以下消息:

showmount: hostname: RPC: Program not registered

可以通过选择 Misc 和 Installation Server 来使用 YaST 配置 NFS。注意,应该以 root ID 登录。

图 4. YaST Installation Server:选择服务器类型

在 Linux 上利用数据分区功能提高可伸缩性和性能

在 instance-owning 机器上设置 NFS 服务器

您需要导出 instance-owner 目录,该目录将被其他数据库分区服务器共享。

创建 instance-owner 目录,确保该目录被挂载。使用如下命令:

mkdir /db2home

mount /db2home

修改 /etc/fstab 中的文件系统表(fstab),使之包括新的文件系统,以便在启动时挂载新的文件系统。条目格式如下:

<device> <mountpoint> <filesystemtype> <options> <dump> <fsckorder>

您的条目看上去可能类似于:

清单 1. 示例 instance-owning /etc/fstab 清单

/dev/had7 /db2home ext3 defaults 1 2

该条目使用一个 ext3 文件系统,这种文件系统在 2.4.16 版或更高版本的 Linux 内核中均受支持,文件系统检查(fsck)程序的顺序被设为 2。

设置好 instance-owning 文件系统后,通过在 /etc/exports 文件中添加以下条目,可以在启动时通过一个 NFS 服务导出这个文件系统:

清单 2. 示例 /etc/exports 清单

db2home InstanceOwnerServer (rw,sync,no_root_squash) db1(rw,sync,no_root_squash)

其中 InstanceOwnerServer 是 instance-owner 服务器的名称,db1 是另一个数据库服务器的名称。

表 2 中列出了导出文件选项:

表 2. 导出文件选项

选项描述
rw使用读写权限来导出文件系统
sync服务器必须等文件被写入到磁盘后才能开始下一次读操作
no_root_squash使 root 权限有效

执行 exportfs 命令,使将挂载的 NFS 客户机能使用 instance-owner 目录

/usr/sbin/exportfs -a

其中选项 a 用于导出 /etc/exports 文件中列出的所有目录。

设置参与机器上的 NFS 客户机

instance-owner 目录可用之后,便可以将该目录导入其他数据库分区服务器。

用以下命令在其他服务器中创建共享目录:

mkdir /db2home

添加一个条目到 /etc/fstab 文件,使 NFS 在启动时自动挂载文件系统:

清单 3. 参与机器的 /etc/fstab 示例

server1:/db2home /db2home nfs rw,timeo=300,retrans=5,hard,intr,bg,suid

其中 server1 是 instance-owner 服务器名称,下表列出了其他一些选项:

表 3. NFS 挂载选项

选项描述
rw使用读写权限来导出文件系统。
timeo这个值的单位是十分之一秒,表示 RPC 超时后进行第一次重传之前所需等待的时间。默认值是7/10。
retrans在重大操作被中止或者控制台上显示 “server not responding” 消息之前必须重传的次数。
hard如果 NFS 文件操作超时较多,则在控制台上报告 “server not responding”,并一直重新尝试。这是默认情况。
intr如果 NFS 文件操作超时较多,并且是硬(hard)挂载,那么允许由信号中断文件操作,使操作中断。
bg如果第一次 NFS 挂载尝试超时,则在后台重试挂载。
suid这个值允许 set-user-identifier 位 (SUID) 或 set group-identifier 位 (SGID) 生效。

用以下命令在其他数据库分区服务器上挂载导出的文件系统:

mount server1:/db2home /db2home

检验 NFS 锁监控程序

DB2 需要一个 NFS 锁监控程序来在集群中所有参与机器之间共享 instance-owner 目录。可以通过使用 chkconfig 命令来检验 NFS 锁监控程序是否已启用:

chkconfig nfslock

可以通过以下命令启用 NFS 锁监控程序和重新启动 nfslock:

chkconfig nfslock on

/etc/rc.d/nfslock restart

检验 NFS 锁和 NSM (Network Status Monitor) 服务

NSM 服务 rpc.statd 实现了一个重启通知服务,NFS 文件锁服务(rpc.lockd)将用到这个服务。可以使用以下命令检验这些服务的状态:

ps -ef | grep rpc.statd

ps -ef| grep rps.lockd

步骤 6. 创建所需的组和用户

在数据库分区环境中,需要为 DB2 创建三个组和用户 ID,如下表所示:

表 4. 所需的 DB2 组和用户

用户 ID组 ID描述
db2inst1db2iadm1DB2 实例用户 ID 和组 ID
db2fenc1db2fadm1DB2 fenced 用户 ID 和组 ID
dasusr1dasadm1DB2 Administration Server 用户 ID 和组 ID

在所有参与机器上的 DB2 instance owner ID 和密码应该是一致的,而且,它的 home 目录应该在 NFS 共享目录中。fenced ID 应该配置为与 DB2 instance owner ID 相同。DAS 用户 ID 和密码在所有参与机器上可以各不相同;但是,为了简化配置和维护,可能需要使 DAS 用户 ID 和密码一致。

例如,您可以用以下命令在所有机器上创建 DB2 组,创建 DB2 用户 ID 以及设置初始密码:

groupadd -g 999 db2iadm1

groupadd -g 998 db2fadm1

groupadd -g 997 dasadm1

useradd -u 1100 -g db2iadm1 -m -d /db2home/db2inst1 db2inst1 -p password1

useradd -u 1101 -g db2fadm1 -m -d /db2home/db22fenc1 db2fenc1 -p password2

useradd -u 1102 -g dasadm1 -m -d /home/dasadm1 dasusr1 -p password3

passwd db2inst1

passwd db2fenc1

passwd dasusr1

步骤 7. 在 instance-owning 机器和所有参与机器上安装 DB2 UDB

可以使用 db2_install 脚本通过 RPM 安装实用程序在 Linux 系统上安装所有的 DB2 ESE 包。您可以使用该脚本首先在 instance-owning 机器上安装 DB2,然后在参与机器上安装 DB2。

由于必须在每个参与机器上安装 DB2,所以最好将安装代码放在一个共享的盘(例如在我们这个例子中是 /db2home)上。也可以将您的设置记录到一个响应文件中,然后使用该文件来配置其他的机器。

首先,为了安装 DB2,必须以 root 用户登录:

输入 db2_install 命令启动 db2_install 脚本,该脚本存放在 CD-ROM 的根目录下。

当 db2_install 提示输入产品关键字时,输入 DB2.ESE。

步骤 8. instance-owning 机器的配置

这台机器将被视作 instance-owning 机器,因为它存储和共享 instance owner 的 home 目录。sqllib 目录正是位于这个目录中,此外在此目录中的还有 Database Manager Configuration 文件 (DBM CFG)、Instance Profile Registry、Node 目录和 System Database 目录。由于这些文件是共享的,所以对任何一个文件的更新在所有参与机器上都可以看到。为了配置 instance-owning 机器,需要执行以下步骤:

创建一个 DB2 实例

您应该使用 DB2 instance owner ID 登录到系统,然后在 /opt/IBM/db2/V8.2/instance 下执行 db2icrt 创建一个供所有机器共享的 DB2 实例:

cd /opt/IBM/db2/V8.1/instance

./db2icrt -u db2fenc1 db2inst1

其中 -u 指定 fenced ID。

需要注意的是,一个 DPF Instance 实际上存在于每个参与机器上,它们都使用相同的实例名、密码和共享 home 目录。当使用 DPF 时,被分区的是数据库,而不是实例。

启用 FCM

所有参与机器必须通过一个通信设施互连,例如一个高速 TCPIP 网络。Fast Communications Manager (FCM) 被设计用来处理数据库分区服务器之间的通信。为了启用 FCM,在所有参与机器上的 /etc/services 文件中必须预留一个端口范围。DB2 提供在 /etc/services 文件中已经被预留的一个默认的端口范围;默认情况下,DB2 会修改 /etc/services 文件,以便将端口 60000-60003 用于分区之间的通信,端口 50000 用于应用程序通信。DB2 在创建实例时会为此预留一些端口。每个逻辑分区需要一个端口,并且每台机器需要预留相同的端口。每个条目包含一个端口名和端口号。

除了基本的配置外,FCM 端口看上去应该如下所示:

清单 4. /etc/services 中的 FCM 端口

DB2c_db2inst1        50000/tcp
#Add FCM port information
#
DB2_db2inst1      60000/tcp
DB2_db2inst1_1     60001/tcp
DB2_db2inst1_2     60002/tcp
DB2_db2inst1_END    60003/tcp

从 清单 4 中可以看出,端口名是由实例名加上前缀 "DB2_" 得到的。最后一个端口名由实例名加上前缀 "DB2_" 和后缀 "_END" 得到。第一个端口名与最后一个端口名之间的端口名以 "_<序列号>" 为后缀。 端口号后面必须跟上 "/tcp"。

更新 DB2 实例参数

使用 instance owner ID 登录到机器,并指定 DB2 将使用哪些协议。为了初始化协议,需要使用以下命令更新 DB2COMM profile 注册表变量:

db2set DB2COMM=TCPIP

此外,需要在数据库管理器(DBM)配置参数中更新服务名,以指示哪些端口名将用于与 DB2 服务器和远程客户机的通信。这可以通过使用以下命令来完成:

db2 update dbm cfg using SVCENAME db2c_db2inst1

创建 DB2 Administration Server (DAS)

如果要使用诸如 Configuration Assistant、Control Center、Replication Center 或 Development Centermust 之类的 GUI 工具,则必须让 DAS 处于运行状态。您可以作为 DAS 用户登录,然后使用以下命令创建一个 DAS 服务器:

cd /opt/IBM/db2/V8.1/instance

./dascrt -u dasusr1

其中选项 -u 指定 DAS 的用户 ID。

可以用 DAS 管理用户 ID 登录,并执行命令 db2admin start 来启动 DAS 服务器。若要自动启动 DAS 服务器,则需要使用 DAS 管理用户 ID 并执行以下命令:

cd /opt/IBM/db2/V8.1/instance

./dasauto -on

为了显示 autostart 状态,可以执行:

./dasauto ?

更新 db2nodes.cfg 文件

最后,需要更新 $HOME/sqllib/db2nodes.cfg 文件。db2nodes.cfg 文件包含配置信息,告诉 DB2 哪个服务器上的哪个分区参与了该实例。该文件有四列:

数据库分区号

服务器主机名

逻辑端口号

用于分区之间通信的网络接口(可选)

每个条目表示一个特定服务器上的一个数据库分区,该分区参与了该实例的数据库分区。例如,下面的 db2nodes.cfg 文件定义了四个数据分区。数据分区 0 和 1 在 server1 上,数据分区 2 和 3 在 server2 上。每个服务器有两个逻辑端口(每个逻辑分区对应一个),即端口 0 和 1。

清单 5. 示例 db2nodes.cfg

0   server1   0
1   server1   1
2   server2   0
3   server2   1

更新 .rhosts 文件以允许远程命令

为了允许执行远程命令,每个数据库分区必须有在所有其他参与服务器上执行远程命令的权限。因此,必须在 /db2home/db2inst1/.rhosts 文件中为每个服务器提供一个条目。.rhosts 文件应该有两列,分别为主机名和 instance owner ID。例如, .rhosts 文件中的下列条目表示参与一个实例的两个服务器。

清单 6. 示例 .rhosts

server1 db2inst1
server2 db2inst1

应该使用以下命令来确保只有 root 拥有读和写的访问权:

chmod 600 /db2home/db2inst1/.rhosts

步骤 9. 参与机器上的配置

为了配置参与机器,需要执行以下步骤:

启用 FCM

必须作为 root 用户登录到每台参与机器上,并将用于 FCM 定义的相同的端口名和端口号添加到 /etc/services 文件中。

创建 DB2 Administration Server

必须在所有参与机器上安装 DAS。关于详细信息,请参考在配置 instance-owning 机器时创建 DB2 Administration Server 的方法。

步骤 10. 检验

完成所有更新后,可能需要重新启动服务器,并在所有参与服务器上执行命令 db2_all date 来确保成功完成。

重要概念

下面是关于具有 DPF 功能的 DB2 的一些重要的概念,您应该清楚这些概念。

编目分区

DB2 编目是由数据库管理器维护的一组表和视图。这些表和视图包含元数据,也就是关于数据库和它的对象的信息,例如对表、视图和索引的描述和关于用户在这些对象上所拥有的权限的安全信息。

编目分区是存放数据库编目表的数据库分区。在分区数据库环境中,每个数据库可以在一个不同的数据库分区服务器上有它的编目分区。数据库的编目分区是在运行 CREATE DATABASE 命令的数据库分区服务器上自动创建的。

协调分区

用户与分区数据库的交互是通过一个数据库分区,即用于那个用户的协调分区创建的。协调分区与应用程序运行在同一个数据库分区上,或者,对于远程应用程序,协调分区运行在应用程序所连接的那个数据库分区上。任何数据库分区都可以用作协调节点,或者被变成协调节点。

协调分区之所以被这样称呼,是因为运行在它上面的、与应用程序通信的协调代理。您可以控制将哪个分区用作协调分区。例如,为了连接到分区 3,可以发出:

set client connect_dbpartitionnum 3

connect to SAMPLE

数据库分区组

数据库分区组是由一个或多个数据库分区组成的一个组。在为数据库创建表之前,首先创建用于存储表空间的数据库分区组,然后创建用于存储表的表空间。

可以在一个数据库中定义包含一个或多个数据库分区的有名称的子集。每个子集称作一个数据库分区组。每个包含不止一个数据库分区的子集称作多分区数据库分区组。多分区数据库分区组只能用属于相同实例的数据库分区来定义。一个数据库分区可以属于不止一个分区组。

例如,图 5 展示了一个由 5 个分区组成的数据库分区组:

图 5. 3 个示例数据库分区组

在 Linux 上利用数据分区功能提高可伸缩性和性能

在这种情况下,Database Partition Group 1 横跨除一个数据库分区外的所有数据库分区。它还包含一个名为 'Database Partition Group 2' 的单分区数据库分区组。另外,'Database Partition Group 3' 也与 Database Partition Group 1 共享了一个数据库分区。

可以用 CREATE DATABASE PARTITION GROUP 语句创建新的数据库分区,用 ALTER DATABASE PARTITION GROUP 语句修改数据库分区。

数据被划分到一个数据库分区组中的所有分区上,可以为数据库分区组添加一个或多个数据库分区,或者从中去掉数据库分区。属于数据库系统配置一部分的每个数据库分区都必须在一个名为 db2nodes.cfg 的分区配置文件中定义。一个数据库分区组最多可以包含为数据库系统定义的所有数据库分区。

当创建或修改一个数据库分区组时,就会有一个与之关联的分区映射。数据库管理器可以通过将分区映射与分区键和散列算法相结合,来确定数据库分区组中的哪些数据库分区将存储给定的数据行。在一个非分区数据库中,不需要分区键或分区映射。过一会儿我们将详细讨论这些概念。

一个数据库分区是数据库的一部分,其中具有用户数据、索引、配置文件和事务日志。有一些默认的数据库分区组是在数据库创建时被创建的:

IBMCATGROUP - 用于包含系统编目的表空间的默认数据库分区组。

IBMTEMPGROUP - 用于系统临时表空间的默认数据库分区组。

IBMDEFAULTGROUP - 用于包含用户表的表空间的默认数据库分区组。

用于已声明的临时表的用户临时表空间可以在 IBMDEFAULTGROUP 或任何用户创建的数据库分区组中创建,但不能在 IBMTEMPGROUP 中创建。

为了创建一个新的由 db2nodes.cfg 中所有分区组成的分区组,可以发出以下命令:

create database partition group ALLPART on all dbpartitionnums

如果您想创建一个新的分区组,且这个分区组只包含分区 1 和 2,可以发出如下命令:

create database partition group PART12 on dbpartitionnums (1,2)

分区兼容性

可对分区键的对应列的基本数据类型进行比较,并可将它们声明为是分区兼容的(partition compatible)。分区兼容的数据类型具有如下属性:具有相同值但有不同类型的两个变量会按相同的分区算法映射至同一个分区号。 分区兼容性具有下列特征:

基本数据类型与另一个相同的基本数据类型兼容。

内部格式用于 DATE、TIME 和 TIMESTAMP 数据类型。它们彼此都不兼容,且都不与 CHAR 兼容。

分区兼容性不受带有 NOT NULL 或 FOR BIT DATA 定义的列的影响。

对兼容数据类型的 NULL 值的处理是完全相同的;对不兼容数据类型的 NULL 值的处理可能不相同。

用户定义的类型的基本数据类型用于分析分区兼容性。

对分区键中相同值的小数的处理是完全相同的,即使它们的标度和精度不同。

字符串中(CHAR、VARCHAR GRAPHIC 或 VARGRAPHIC)的尾部空格会被散列算法忽略。

BIGINT、SMALLINT 和 INTEGER 是兼容的数据类型。

REAL 和 FLOAT 是兼容的数据类型。

不同长度的 CHAR 和 VARCHAR 是兼容的数据类型。

GRAPHIC 和 VARGRAPHIC 是兼容的数据类型。

分区兼容性不适用于 LONG VARCHAR、LONG VARGRAPHIC、CLOB、DBCLOB 和 BLOB 数据类型,因为它们不能作为分区键。

并置

并置(collocation)是安置同一个数据库分区中包含相关数据的不同表中的行。并置的表使 DB2 可以更有效地使用连接策略。

您可能会发现,作为对特定查询的响应,两个或多个表频繁地提供数据。在此情况下,您会希望这样的表中的相关数据的位置尽可能地靠近。在数据库被物理地划分为两个或多个数据库分区的环境中,必须有一种方法可将划分的表的相关碎片尽可能地靠近。完成此过程的功能称为表并置。

当存取用于连接或子查询的多个表时,DB2(R) 通用数据库(DB2 UDB)能够识别要连接的数据是否位于相同数据库分区上。于是 DB2 就可以在存储数据的数据库分区上执行连接或子查询,而不必在数据库分区之间移动数据。这种局部地执行连接或子查询的能力具有显著的性能优点。

要发生并置,表必须:

在相同数据库分区组中,且这个数据库分区组不能处在再分配期间。(在再分配期间,数据库分区组中的表可能使用不同的分区映射 —— 它们不是并置的。)

有包含相同数量的列的分区键。

分区键的相应列是分区兼容的。

如果一个表在一个单分区数据库分区组中,且该分区组是在另一个表所在的同一个分区上定义的,那么也可以发生并置。

缓冲池

缓冲池是处理期间用于存放数据页和从中读取、修改数据页的一个内存区域。默认情况下,当创建一个缓冲池时,在每个分区上都会创建这样的缓冲池。为了容易管理,通常最好的做法是使每个分区上的缓冲池大小一致。但是,也可以改变特定分区上的缓冲池大小。例如,若要将分区 4 的 'BUF8K' 缓冲池改为 400MB,可以发出命令:

alter bufferpool BUF8K dbpartitionnum 4 size 51200

还可以通过指定一个数据库分区组来选择在哪几个分区上创建缓冲池,在此情况下,只有在数据库分区组中的那些分区上才会创建缓冲池。

表空间

表空间是存储数据库对象的容器集合的抽象。表空间在数据库与存储在数据库中的表之间提供了一个间接层。对于每个表空间,在存储设备上都有一个空间与之对应。一个表中的数据、索引、long 字段和 LOB 部分可以存储在相同的表空间中,也可以分别放到不同的表空间中,以提高性能。

数据库分区表达式

当定义一个横跨同一台机器上多个逻辑数据库分区的表空间的容器时,为了避免一个以上的逻辑分区具有相同的路径/设备名称,通常使用数据库分区表达式(Database Partition Expression)。通过使用数据库分区号作为容器名称的一部分,可以确保容器名称在各分区当中是惟一的。这可以作为手动地为每个分区指定位置的替代方法。

可以使用参数 " $N" ([blank]$N) 来表示一个数据库分区表达式,它可以用在容器名称的任何地方,而且可以指定多个数据库分区表达式。数据库分区表达式以一个空格字符结束;数据库分区表达式计算完毕后,空格后的内容附在容器名称的后面。 如果容器名称中在数据库分区表达式后面没有空格字符,则认为剩下的字符串是表达式的一部分。

参数的使用只能以如下一种格式出现(在这个例子中,假设分区号是 5):

表 5. 常见数据库分区表达式

语法例子
[blank]$N" $N"5
[blank]$N+[number]" $N+1011"1016
[blank]$N%[number]" $N%3" (% 是模块) 2
[blank]$N+[number]%[number]" $N+12%13"4
[blank]$N%[number]+[number]" $N%3+20"22

如果使用类似于上面的字符串,并且分区号仍然是 5,那么将看到:

表 6. 数据库分区表达式的使用

例子容器名称
'/dbdir/node $N /cont1''/dbdir/node5/cont1'
'/ $N+1000 /file1''/1005/file1'
' $N%10 /container''5/container'
'/dir/ $N%5+2000 /dmscont''/dir/2000/dmscont'

如果在一个由两个分区组成的数据库上发出以下语句:

CREATE TABLESPACE TBSP1 MANAGED BY DATABASE USING (device '/dev/container $N' 10000)

那么将看到下列容器被创建:

/dev/container0 - on DATABASE PARTITION 0

/dev/container1 - on DATABASE PARTITION 1

分区键

分区键是用于确定特定一行数据存储在哪个分区的一个列(或一组列)。

分区键是在一个表上用 CREATE TABLE 语句定义的。如果没有提供分区键,则默认地从主键的第一个列创建分区键。如果没有主键,则默认的分区键是表上第一个非 long/非 LOB 型的列。如果没有列能满足作为默认分区键的条件,则表在创建后就没有分区键,也就意味着这个表不能横跨一个以上的分区。

在选择分区键时,应该注意以下几点:

表是如何被访问的。

查询工作负载的性质。

数据库系统所采用的连接策略。

如果不需要特别考虑并置,那么能使数据均匀地散布在数据库分区组中所有数据库分区上的分区键就是好的分区键。在与一个数据库分区组相关联的表空间中,每个表的分区键可以确定表是否是并置的。

不恰当的分区键可能导致数据分布不均匀。具有分布不均匀的数据的列和具有少量 distinct 值的列都不应该被选作分区键。distinct 值的数量必须多到足以确保数据行均匀地分布在数据库分区组中的所有数据库分区上。应用分区散列算法的代价与分区键的规模成比例。分区键不能多于 16 个列,列数越少导致的性能就越好。分区键中不应该包括不必要的列。

在定义分区键时,应考虑以下几点:

只包含 long 数据类型(LONG VARCHAR、 LONG VARGRAPHIC、BLOB、CLOB 或 DBCLOB)的多分区的表的创建是不受支持的。

分区键的定义不能修改。

分区键应该包括最频繁参与连接的列。

分区键应该由经常出现在 GROUP 子句中的列组成。

任何惟一键或主键都必须包含分区键中的所有列。

在在线事务处理(OLTP)环境中,分区键中的所有列出现在事务中时应该使用等号(=)加常量或主机变量。例如,假设在事务中经常用到雇员号 emp_no:

UPDATE emp_table SET ... WHERE emp_no = host-variable

在此情况下,EMP_NO 列可以作为 EMP_TABLE 的由单列组成的分区键。

散列分区是用于确定每一行在分区表中的位置的方法。该方法工作原理如下:

散列算法应用于分区键的值,产生 0 到 4095 之间的一个分区号。

当创建数据库分区组时,同时会创建分区映射。每个分区号按循环的方式顺序地填充分区映射。

分区号用作分区映射的索引。分区映射中的号码就是表所在的数据库分区的分区号。

分区映射

在分区数据库环境中,数据库管理器必须有方法知道表的哪些行存储在哪个数据库分区上,以便发现它需要的数据。数据库管理器使用一个称作分区映射的映射来发现数据。

分区映射是内部生成的数组,对于多分区的数据库分区组,这个数组包含 4,096 个条目,对于单分区的数据库分区组,这个数组只包含一个条目。

对于单分区的数据库分区组,分区映射只有一个条目,其中包含数据库表中所有的行所在的数据库分区的分区号。对于多分区数据库分区组,数据库分区组中的分区号是以循环的方式指定的。就像城市地图按网格分成一些区一样,数据库管理器使用分区键来确定数据所存储在的位置(数据库分区)。

例如,假设您在 5 个数据库分区(分区号为 0-4)上有一个数据库。那么,这个数据库的 IBMDEFAULTGROUP 数据库分区组的分区映射为:

0 1 2 3 4 0 1 2 3 4 0 1 2...

如果在使用数据库分区 1 和 2 的数据库中创建了一个数据库分区组,那么这个数据库分区组的分区映射为:

1 2 1 2 1 2 1 2...

如果数据库中所装载的表的分区键是 1 到 500,000 之间的整数,则分区键被散列到 0 到 4 095 之间的一个分区号。这个号码将用于作为分区映射的一个索引,以选择那一行所在的数据库分区。

分区映射是在分区数据库中控制数据存储位置的一种灵活的方式。另外还有一种再分配(redistribution)实用程序,通过它可以改变数据在数据库中的数据库分区上的分布(使之平衡或偏斜),不过这超出了本文的范围。

DB2NODE 环境变量

DB2NODE 环境变量用于指定想要连接到的目标逻辑分区。如果没有设置该变量,那么它将默认地等于用机器上的端口 0 定义的那个分区(在 db2nodes.cfg 文件中)。

如果要连接到逻辑分区 2,那么可以输入以下命令:

DB2NODE=2

export DB2NODE

db2 terminate

为了确保更改生效,必须用 terminate 命令。

为了识别当前活动逻辑节点,可以发出以下命令:

db2 "values (current dbpartitionnum)"

发出横跨多个机器和分区的命令

这两个工具使跨所有机器或所有分区执行命令变得容易。两个工具使用相同的一组有用的选项,这些选项可以在 DB2 Command Window 中通过 "rah ?" 或 "db2_all ?" 命令显示出来。

db2_all

db2_all 用于在所有指定的分区上运行命令。

db2_all ";db2 update db cfg for SAMPLE using NEWLOGPATH /db2_db/logs"

分号用于作为一个前缀,表明该命令将在各分区上并发地运行。

rah

rah 用于在组成分区环境的所有机器上运行一个命令。

数据库备份

当执行离线数据库备份时,需要单独备份编目分区。但是,在线备份时就不需要这样,因为日志是包括在备份镜像中的。例如,我们有一个名为 sample 的数据库和一个 /dev/backup 目录,从所有分区那里都可以访问这个目录。

首先需要备份位于分区 0 上的编目分区,这里只需指定 "<<+0<"" (在这个例子中)

db2_all '<<+0< db2 BACKUP DATABASE sample TO /dev/backup'

接着备份其他分区(除了分区 0),方法是指定 "<<-0<":

db2_all '|<<-0< db2 BACKUP DATABASE sample TO /dev/backup'

注意,前缀 "|" 将导致依次运行 BACKUP 命令。现在,在 /dev/backup 目录中可以找到每个分区的备份镜像。

表中行的分布

DBPARTITIONNUM 函数可用于确定一个行所在的分区。例如,如果用在一个 SELECT 子句中,那么该函数将返回表中组成 SELECT 语句结果的每一行的分区号。

该函数的参数必须是一个表中某一列的全限定或非限定列名。结果的数据类型是 INTEGER,并且不会为 null。由于只返回行这一级的信息,所以不管指定表的哪一列,结果总是相同的。如果没有 db2nodes.cfg 文件,则结果为 0。

例如:

select lastname, dbpartitionnum(lastname) as part_num from employee order by 1

清单 7. 使用 dbpartitionnum 函数的结果集

LASTNAME    PART_NUM
--------------- -----------
ADAMSON          0
BROWN           2
GEYER           1
GOUNOT          1
HAAS           1
HENDERSON         0
JEFFERSON         1
JOHNSON          1
JONES           3

节点和数据库目录

节点(node)目录包含在建立从客户机工作站到所有合适的数据库服务器的通信时所需的信息。

数据库(database)目录包含客户机所连接到的所有数据库的数据库访问信息。

设计上的考虑

DB2 Design Advisor 是获得有效的分区建议的最直接的工具,可以通过 Control Center GUI 或 db2advis 命令行工具来使用它。通过一个可更新的分区映射,结合一个散列算法,可以指定分区键与数据库分区的映射,这个映射可用于确定每个数据行的位置和检索。

于是,对于大型的表,工作负载可以分布在多个分区上,而更小的表也可以存储在一个或多个数据库分区上。由于每个数据库分区都有它的数据上的本地索引,因此提高了本地数据访问的性能。

DB2 还支持部分分块(de-clustering),在此情况下,表和表空间可以分布在可用分区的一个子集上。取决于数据库分区的数量,您可以有一个或多个单分区的数据库分区组,以及一个或多个多分区的数据库分区组。每个分区必须使用一个惟一的分区号,而同一个数据库分区可以属于一个或多个数据库分区组中。

为了确保包含系统编目表的分区能够快速恢复,应避免将用户表也放在那个数据库分区上。为此,可以将用户表放在不包括 IBMCATGROUP 数据库分区组中的数据库分区的数据库分区组中。

除非想要利用与更大的表的并置,否则应该将小型的表放在单分区的数据库分区组中。应避免使中等规模的表横跨太多的数据库分区。例如,对于一个 100 MB 的表,将它放在包含 16 个分区的数据库分区组上可能比将它放在包含 32 个分区的数据库分区组上得到的性能要好。

您可以使用数据库分区组来将在线事务处理(OLTP)表与决策支持(DSS)表隔离开来,以确保 OLTP 事务的性能不受负面影响。

在多分区数据库分区组中,如果索引是分区键的超集,那么只能创建一个惟一的索引。

在创建数据库时,应确保在用于数据库位置的 "ON" 子句中指定一个本地(非共享)目录。例如,

CREATE DATABASE SAMPLE ON /db2_db

其中 /db2_db is 是一个预先存在的本地目录。

在默认情况下,数据库管理器配置中的默认数据库路径(DBTDBPATH)参数是 instance owner(被 NFS 共享)的 home 目录的位置。如果在不指定数据库位置的情况下创建数据库,那么将使用 DBTDBPATH 创建数据库,这里 DBTDBPATH 指向共享的 instance-owner 目录。这样将降低性能。

创建数据库之后,应该确保每个数据分区还有它自己的日志本地目录。您可以使用以下命令:

db2_all ";db2 update db cfg for SAMPLE using NEWLOGPATH /db2_db/logs"

节点号被自动附加在路径的后面。这样做是为了维护多逻辑节点配置中路径的惟一性。

结束语

本文讲解了在 DB2 UDB 中使用 Data Partitioning Feature (DPF) 的理论基础,详细解释了 DPF 的安装过程和一些重要概念,并且谈到在 SUSE Linux Enterprise 环境中启用 DPF 时在设计上的一些考虑。更好地理解了 SUSE Linux 环境中的 DB2 DPF 之后,就可以很快地掌握如何在 SUSE Linux 环境中启用 DPF。

Tags:Linux 利用 数据

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