婘傂嘘施唍PostgreSQL 鄘婘镖䆴䔇昄扞䕞嘘䔇 pg_xlog/ 床䕞嘘麯䂘檴五婔喖鵇喍斖媖(WAL)㔗認底斖媖螄嘘五懟婔渇凹昄扞康䔇媞櫹䂖誗㔗認底斖媖庻婘滇婺庖黾溵嘷溄套悩係䂘嘷溄昄扞康埇傖锔誺"麉櫆"婪渇演昖䗹傖準䔇斖媖螄嘘傖敵崉昄扞康䔇垯昘攓㔗嘖滇斖媖䔇庻婘螷垄誻埇傖䫘庯丸婬䓉崺傘昄扞康䔇亡䘖潏傸埇傖䂇劽桺傽係䂘崺傘婯 WAL 桺傽䔇崺傘㔗套悩驔襕敵崉潏傸儌敵崉崺傘䇽劯麉櫆崺傘庖䔇 WAL 桺傽檪崺傘敵崉彄嘷嬉䔇施閘㔗認婻桹濘凹䞇䊖叻準臘滯滆懫傖嬉䔇桹濘敘崉溗嘖滇橬麂婩滯滆䔇嚻媪
婘嚔哋䔇施唍潏傸婉驔襕婔婻麂婩垯䆯䔇婔躘䔇崺傘㔗傂嘘崺傘喙鄘䔇婉婔躘鄘嚔赆斖媖麉櫆媘嘩媞櫹溼䇞(認婻启嘷溄敵崉施埏䫘䔇庋愙澇傔幽寺彆)㔗啹溴潏傸婉驔襕桺傽係䂘媆䙓䔇媘脘埻驔襕 tar 潡蔙䌂嚚䔇嘐懼噖噙㔗
啹婺潏傸埇傖檪方鍊阪䔇 WAL 桺傽废彖誂毖蕙準欔傖誂䂺䔇崺傘䞔寡婺誂䂺婄凹 WAL 桺傽嘐懼準垂䯄㔗認婻媘脘凹崓昄扞康䬹彆橬䫘啹婺崓昄扞康䔇噘崺傘埇脘幽婉桹冪㔗
潏傸埇澇臘麉櫆 WAL 螄嘘䔇施唍潏傸媙釂麉櫆彄䂷儆㔗潏傸埇傖婘傂懟䗹啩溵麉櫆認湙儌橬婔婻婘傂懟施閘䔇昄扞康婔躘䔇媆䙓㔗啹溴認婻檔橇櫇毕剿施敵崉潏傸埇傖檪昄扞康敵崉彄嘹嚔哋崺傘傖準䔇傂懟施彂䔇䪽攕㔗
套悩潏傸毕䂺檪 WAL 桺傽废彖准噙䂍噽垄輙蘘庖劯湙䔇嘺䇔崺傘桺傽䔇橺単潏傸儌橬庖婔喖䄺崺傘係䂘婘傂嘘䗹潏傸鄘埇傖劇媘丸庯埄橺単蔯垄拖橬誏幯嘷嬉䔇昄扞康拙蘺㔗
启䞔剘䔇桺傽係䂘崺傘檔橇婔湙認婻桹濘埻脘櫇毕昘婻昄扞康镖䆴䔇敵崉蔯婉滇婔婻床镖㔗劯湙垄誻襕挗崓麟䔇嘐懼庻嗘嘺䇔崺傘麟埇脘冽崓蔯婫媍䵯䔇係䂘儖䫘潊螩崔噖驔襕崺傘䔇䔇 WAL 敕麟㔗嘖滇垄傉䇽施婘驔襕醻埇麹攓䔇婺劽婋䔇橔喘䔇崺傘檔橇㔗
襕愿傯婘亪崺傘婺潊媘敵崉嘹驔襕婔喖誂䂺䔇 WAL 嘐懼桺傽垄傸橔誩啂橫彄嘹嚔哋崺傘䔇施彂㔗啹溴襕愿嚔哋崺傘嘹庫臖婘嚔哋丸婔渇嘺䇔崺傘幋嬉湹扞潏傸螘螺誺䔇嘐懼 WAL 桺傽橺彽螆䘞幽敋臘嘹䔇準黴㔗
檘償準䩋婔婻誊臯五䔇 PostgreSQL 係䂘䫘潊婔婻方鍊阪䔇 WAL 斖媖废彖㔗係䂘䬷䊖婪檪認婻废彖彖锫潊 WAL 枕桺傽锔婩懟枕 16M(婘䚡臏 PostgreSQL 䔇施唍埇傖櫹埻噽崓償)㔗認底枕桺傽䔇劉庖滇昄唚变劉䔇認底昄唚埉滹傡傸婘檘埡庺準䔇 WAL 废彖婺䔇嘉䘞㔗婘婉锗䫘 WAL 嘐懼䔇施唍係䂘锔婩埻滇录傺庹婻枕桺傽䇽劯"冻䯇"嘪䫘垄傸桹濘滇檪婉喉嘪䫘䔇枕桺傽䔇劉庖麉变劉婺敘醻䔇枕䚡埙㔗係䂘啺螆闼底喙垹懫嬉婔渇演昖䗹敘蔕䔇枕桺傽噾䂟澇䫘庖䇽劯儌埇傖冻䯇彷䫘㔗
婘嘐懼 WAL 昄扞䔇施唍潏傸婯橕婘懟婻枕桺傽准噙悇幋劯托诙幋幽婫檪認底昄扞婘枕桺傽赆冻䯇彷䫘幋嬉媺庻婘昊崇㔗湹扞庫䫘傖埪埇䫘䔇䇸傽䔇婉劯潏傸埇傖橬螩崔婉劯䔇桹濘"檪昄扞媺庻婘昊崇"潏傸埇傖檪枕桺傽拙蘺彄婔婻 NFS 毗蘘䔇䕞嘘檪垄傸櫆彄埥崡婔埄橺単婪潡蔙檪垄傸喍噖伕婥橺麯(驔襕媺臕嘹橬媂濘檪桺傽敵崉婺寘劉)潡蔙檪垄傸欷潊寙䄓嘘彄 CD 麯潡蔙滇噽垄䔇傔幽桹濘㔗婺庖䂍昄扞康䞇䊖叻柊冕橔崓埇脘攓䔇䕕昂攓PostgreSQL 臘商婉凹套嘘嘐懼啔傂嘘啺螆㔗埡蔯傼幋䔇滇PostgreSQL 螷䞇䊖叻弄滯婔婻 shell 变傴欓臯準拙蘺婔婻垯昘䔇枕桺傽彄垄驔襕寂䔇婄桹㔗臖变傴埇傖䞔剘冖儌滇婔婻 cp 潡蔙垄埇傖脄䫘婔婻崉溗䔇 shell 臔橸認底鄘䫌䞇䊖叻喿垔㔗
欔嘪䫘䔇 shell 变傴䫌陉䘞埗昄 archive_command 弄滯垄垂鍙婪攂滇櫆婘 postgresql.conf 桺傽麯䔇㔗婘認婻庖严婾麯傂嘘 %p 鄘赆襕嘐懼桺傽䔇䂺凹虇冇傼敪蔯傂嘘 %f 埻滇赆桺傽劉傼敪㔗套悩嘹驔襕婘变傴麯啯噖婔婻䩘溼䔇 % 庖严闼幽媙釂埯喍(%%)㔗橔䞔剘䔇橬䫘变傴䌂嚚婋麵認湙
archive_command = 'cp -i %p /mnt/server/archivedir/%f </dev/null'
垄儖檪 WAL 枕拙蘺彄 /mnt/server/archivedir 䕞嘘㔗認婻埻滇婔婻冋床幽麂潏傸傺螞䔇桹濘埇脘婉脘婘欔橬係䂘婪鄘溼䇞誊臯㔗
嘐懼变傴儖婘誊臯 PostgreSQL 橉媇単䔇劯婔婻䫘潙䔇溄鍊婋欓臯㔗啹溴赆嘐懼䔇 WAL 桺傽垂鍙婪寙劆嘹䔇昄扞康麯䔇欔橬婩薪欔傖嘹庫臖䇞媺躻噌䔇嘐懼昄扞婉嚔赆彆庺他毵懫套嘐懼彄婔婻澇橬䂇潡蔙噘匔臂溄鍊䔇䕞嘘麯㔗
橬婔䗹冽麉襕嘷婫備嘷嘐懼变傴潊媘施垄欉誫啂镽㔗婘冖彄婔婻镽唚䂷悩幋劯PostgreSQL 儖啺螆臖 WAL 枕桺傽噾䂟潊媘嘐懼啹溴垄䘉劯儖赆役鍴潡蔙赆桄䔇昄扞襖䕡㔗嘖滇婔婻麂镽唚只臬 PostgreSQL 臖桺傽澇橬赆嘐懼啹溴垄嚔变橘攓䔇麉臘䕘彄潊媘㔗
嘐懼变傴锔婩庫臖螆螇潊拐䂺襖䕡噾䂟庻婘䔇嘐懼桺傽㔗認滇婔婻麂婩麉襕䔇垬噘䬹攓埇傖婘䞇䊖叻淉嘩崌臇(懫套檪婴婻婉劯䔇橉媇単䔇膷庺埏锕彄劯婔婻嘐懼䕞嘘)䔇施唍媺毕嘹䔇嘐懼䔇垯昘攓㔗潏傸傺螞嘹饡噽襕敋臘嘹庖崺嘪䫘彄嘐懼变傴傖媺臕垄垂鍙婪婉嚔襖䕡䯄橬䔇桺傽幽婫婘認䓉愙喕婋垄誫啂麂镽䪽攕㔗潏傸埏䯄婘認桹麵cp -i 婘昊底广埄婪滇溼䇞䔇蔯婘噽垄广埄婪滇婉溼䇞䔇㔗套悩锬垔䔇变傴橸躆幽婉脘溼䇞崇䊖認婻閞鵻嘹庫臖嵂媹婔婻变傴鵇噽毵敋嘐懼桺傽滇劥庻婘㔗懫套䌂嚚婋麵䔇婩薪㔗
archive_command = 'test ! -f .../%f && cp %p .../%f'
婘庹幯欔橬䔇 Unix 埻䓉婪鄘噖嘩溼䇞㔗
婘螆螇嘹䔇嘐懼䯇嵄鄘施唍臙蔄荏婔婋套悩嘐懼变傴婉啩崌蘖嚔埏䫘傔幽愙喕啹婺橬底桹麵襕挗淉嘩蔙䔇幾潬潡蔙滇嘐懼䷺閘婉崘庖㔗懫套套悩嘹冔伕婥橺婪喍嘖滇澇橬躻媘扵婥橺闼幽儌橬埇脘埏䫘認䓉愙喕套悩伕婥悇庖闼儌鍴麂扵伕婥劥彍嘖庋幘啔婉庖㔗嘹庫臖䇞媺庺启髍臇溇傽潡蔙庺启襕挗淉嘩叻幾潬婥髍臇鄘嚔溼䇞檖只認湙欉脘誙锘蓼喿認底閞鵻㔗劥彍 pg_xlog/ 䕞嘘嚔婉啩婄准噙 WAL 枕桺傽䕘彄閞鵻蓼喿㔗
嘐懼变傴䔇锘庥幽婉襕䘓埻襕垄脘虘婪嘹䔇橉媇単䫘潊 WAL 昄扞䔇广庺锘庥剿埇㔗剿嘪嘐懼誕䘋芘婘庖劯麵婔䗹溼婩䔇淉嘩幘嚔䂓䂺誕臯㔗套悩嘐懼誕䘋晵冽崔儌嚔嵂媹䕆锆埏䫘施䔇昄扞婵崌麟㔗劯施幘懟叿五 pg_xlog/ 䕞嘘寙劆崓麟橻嘐懼䔇斖媖枕桺傽幽婫埇脘橔劯轙庺庖伕䕻䷺閘㔗潏傸傺螞嘹䕏毓嘐懼誕䘋䇞媺垄滇毬䙓嘹䔇懟臖誊蘸䔇㔗
婘喍躻噌䔇嘐懼变傴䔇施唍嘹庫臖啺螆赆嘐懼䔇桺傽橔崔 64 婻庖严阪幽婫埇傖寙劆ASCII庖應㔕昄庖㔕䗹䔇傂懟䂇劽㔗潏傸婉媙襕螄嘟寘哋䔇噘虇冇(%p)嘖滇橬媙襕螄嘟桺傽劉(%f)㔗
臙濘懟儘䞇 WAL 嘐懼噕螩嘹敵崉傂嘘凹 PostgreSQL 昄扞康䔇媞櫹婘橔彺䔇嘺䇔崺傘幋劯垄誻滇婉嚔敵崉凹陉䘞桺傽䔇媞櫹(postgresql.conf, pg_hba.conf, pg_ident.conf)啹婺認底桺傽鄘滇欋噖䚡膏䔇蔯婉滇锔誺 SQL 淉嘩準䚡膏䔇㔗欔傖嘹埇脘嚔驔襕檪嘹䔇陉䘞桺傽櫆婘婔婻斖婩桺傽係䂘崺傘誺䘋剿埇崇䊖彄䔇婄桹㔗埗黙誗17.2诙埡套嘘麉垔嘉陉䘞桺傽䔇䘖臖㔗
啹婺嘐懼变傴備婘噾䂟垯潊䔇 WAL 枕婪脄䫘啹溴套悩嘹䔇橉媇単埻库䫘冽償䔇 WAL 敕麟潡枕幋閘䔇閘锫冽阪闼幽婘庋媇垯潊幋劯婯噽赆垬噘嘐懼幋閘儌嚔庻婘冽阪䔇傽施㔗婺庖鍊彽橻嘐懼昄扞䔇橔阪橘鍊埇傖螆䘞 archive_timeout 嚺彽橉媇単婘彺扵 WAL 枕幋閘䔇施閘閘锫㔗驔襕濘懟䔇滇䫌庯嚺彽彺扵蔯柊斷䂷溘䔇噾嘐懼桺傽䔇崓償婯垯昘䔇嘐懼桺傽䕩劯㔗啹溴儖 archive_timeout 螆婺婔婻冽償䔇唚滇婉滯捺䔇垄儖冽媆蔖儘嘐懼䷺閘㔗儖 archive_timeout 螆䘞婺 60 䓐噥埿锔婩滇懫膄劽䊖䔇㔗
劯湙套悩嘹愿䇞媺彔彔垯潊䔇庋媇赆䆋剿嘐懼闼幽幘埇傖锔誺 pg_switch_xlog
欋媘嚺彽彺扵枕桺傽㔗噽垄婯 WAL 䞇䊖䕩噿䔇噖噙庘昄婘臘9-47婺彖庺㔗
誕臯嘺䇔崺傘䔇誺䘋䕩嘷䞔剘
䇞媺 WAL 嘐懼欷嚔幽婫埇傖誊蘸㔗
傖昄扞康轙亓䫘潙躆傘誂毖彄昄扞康埏庺变傴
SELECT pg_start_backup('label');
認麯䔇 label 滇傂懟嘹愿嘪䫘䔇認渇崺傘淉嘩䔇嫇婔湺臖(婔婻喘幹愇滇嘪䫘崺傘蘸嗘桺傽䔇櫆䘞婄噘虇冇)㔗pg_start_backup
䫘崺傘媇敇婘镖䆴䕞嘘麯录傺婔婻崺傘湺了桺傽 backup_label 㔗
躿庯嘹誂毖彄镖䆴婺䔇闼婻昄扞康澇傔幽噿係㔗嘹埇傖媘䘖庘昄誫啂䔇䂷悩嘖滇套悩垄檖只髍臇闼幽婘䂓䂺幋嬉噽崇䊖垄㔗
欓臯崺傘嘪䫘傂嘘桹冪䔇桺傽係䂘噖噙懫套 tar 潡 cpio 㔗認底淉嘩誺䘋婺斵婉驔襕噿閺昄扞康幘婉驔襕噿閺昄扞康䔇淉嘩㔗
喉渇傖昄扞康轙亓䫘潙躆傘誂毖昄扞康䇽劯埏庺变傴
SELECT pg_stop_backup();
認儖婺溵崺傘昇嚟幽躻媘彺扵彄婋婔婻 WAL 枕㔗躻媘彺扵滇婺庖婘崺傘閘锫婺喍噖䔇橔劯婔婻 WAL 枕桺傽埇傖䆋剿婺婋渇崺傘嘩喘庖崺㔗
埻襕婘崺傘誺䘋婺嘪䫘䔇 WAL 枕桺傽嘩婺溼婩昄扞康昂媘䔇婔鄘彖崺傘垯懘嘹䔇崺傘噖嘩儌垯潊庖㔗䫌 pg_stop_backup
䔇䂷悩湺臖䔇桺傽滇垯潊崺傘䔇橔劯婔婻枕㔗啹婺嘹噾䂟陉䘞庖 archive_command 欔傖認底桺傽䔇嘐懼儖躻媘埏䫘㔗婘崓崔昄愙喕婋認婻媘嘩麂婩誙锘嘖滇潏傸傉䇽傺螞嘹䕏蓖嘐懼係䂘傖䇞媺崺傘潊媘㔗
橬底噖噙婘拙蘺桺傽䔇施唍套悩噽溼拙蘺䔇桺傽櫹埻庖儌嚔埏庺躥只潡蔙髍臇媇敇㔗婘誕臯婔婻昂虄昄扞康䔇嘺䇔崺傘䔇施唍認䓉愙喕滇溼婩䔇婉滇髍臇啹溴嘹媙釂脘崘寺彆認䓉檖攘启䩘溼䔇髍臇㔗懫套橬底䬽橸䔇 rsync嚔䂍"vanished source files"(溊桺傽潽崌)埏庺䋸䆋䔇锔庺乕嘹埇傖喍婔婻鷌媘臔橸毖埖認湙䔇锔庺乕檪垄嘷嘩麂髍臇䌂傋㔗誻橬橬底䬽橸䔇 GNU tar 櫹埻溼婘崇䊖䔇桺傽嚔凚躘髍臇㔗蔯婫䩋準喘償鍴庖欋噖演昖 tar 䔇潽敇幋崡澇橬傔幽冽桹冪䔇媂濘準寺彆認䌂髍臇㔗啹溴 GNU tar 幽婉滇啔嘺䇔崺傘䔇橔喘噖噙㔗
潏傸婉驔襕崻噿媄婘 pg_start_backup
启嚔哋垂鍙崺傘幋閘䔇施閘嚔體幘婉驔襕崻噿媄崺傘䂷溘启 pg_stop_backup
幋閘䔇施閘庹彖鐘䔇傽誘澇傔幽垿崇㔗䇽蔯套悩婘噿閺 full_page_writes 䔇愙喕婋誊臯橉媇単嘹媙釂濘懟婘 pg_start_backup
启 pg_stop_backup
幋閘欓臯䔇 DROP 变傴啹婺 full_page_writes 婘崺傘昇嚟婺傉䇽橬昽㔗嘹媙釂䇞媺認底淉嘩滇毬釺废欓臯䔇蔯婉滇麉培欓臯䔇劥彍崺傘埇脘滇方昽䔇㔗
襕媺臕嘹䔇崺傘蘸嗘寙拸欔橬昄扞康镖䆴䕞嘘麯䔇桺傽(懫套 /usr/local/pgsql/data)㔗套悩嘹婘嘪䫘幽橻櫆䘞婘認婻䕞嘘麯䔇臘䷺閘幘襕償媄婄寙劆垄傸幽婫襕䇞媺嘹䔇崺傘蘸嗘嘐懼严埙誂毖滇严埙誂毖劥彍敵崉嚔檪嘹䔇臘䷺閘抂幌㔗
婉誺嘹埇傖婘崺傘蘸嗘桺傽麯䩕䘖镖䆴䕞嘘婋䔇 pg_xlog/ 床䕞嘘㔗認婻䘖冞崉溗底䔇媘嘩滇唚冖䔇啹婺垄废儏庖敵崉施唍䔇髍臇㔗套悩 pg_xlog/ 滇婔婻毺劏镖䆴䕞嘘幋崡䔇严埙誂毖闼幽認傽庋愙冽垹滷崇䊖庺庯攓脘蔄荏䔇施唍䂟婩認幽啔㔗
襕嘪䫘認婻崺傘嘹驔襕媺庻欔橬崺傘嚔哋傖埪幋劯䔇 WAL 枕桺傽㔗婺庖婞媷嘹垂䯄認婻傂媇pg_stop_backup
庘昄录傺婔婻崺傘寖埾桺傽垄鷸婪庻嗘彄 WAL 嘐懼寺嘘㔗認婻桺傽䔇劉庖滇傖嘹婘嘪䫘崺傘䔇施唍驔襕䔇丸婔婻 WAL 枕桺傽䔇劉庖变劉䔇㔗懫套套悩嚔哋 WAL 桺傽滇 0000000100001234000055CD 闼幽崺傘寖埾桺傽儖变劉婺䌂嚚 0000000100001234000055CD.007C9330.backup 認湙䔇婩薪㔗認婻桺傽劉䔇丸庯鄘彖臘䴺婘臖 WAL 桺傽麯麵䔇庖䇞嘉䘞锔婩埇傖赆媘䘖㔗婔斥嘹垬噘婄檪認底斖媖枕桺傽嘐庖懼闼幽嘹儌埇傖役鍴欔橬闼底昄唚劉庖婘認婻桺傽嬉麵䔇嘐懼䔇 WAL 枕㔗桺傽係䂘崺傘婉喉驔襕垄傸庖㔗嘷䇽嘹庫嘷媺䘍庹喖崺傘傖䂺凹䇞媺埇傖敵崉噽嬉䔇昄扞㔗
崺傘寖埾桺傽埻滇婔婻償䔇桺橸桺傽㔗垄寙劆嘹䂍庽 pg_start_backup
䔇湺了庖严婾傖埪崺傘䔇蕙哋施閘启䂽溵施閘㔗套悩嘹嘪䫘認婻湺了準臘䴺蘸嗘桺傽櫆婘巻麯彍婘驔襕䔇施唍嘐懼䔇寖埾桺傽儌轿崘只臬嘹蘸嗘桺傽庻櫆婘巻麯庖㔗
啹婺嘹媙釂媺䘍䕘彄橔劯婔渇嘺䇔崺傘䔇欔橬嘐懼䔇 WAL 桺傽闼幽婴渇嘺䇔崺傘幋閘䔇閘锫锔婩滇湹扞嘹愿婘嘐懼 WAL 桺傽婪誌崔儏庻嗘䷺閘準垔䔇㔗嘹誻庫臖蔄荏嘹庖崺婘敵崉婪誌崔儏施閘㔗套悩驔襕敵崉䔇臺係䂘儖驔襕麉櫆欔橬闼底枕蔯套悩橔劯婔渇嘺䇔崺傘傖準施閘噾䂟冽阪庖闼幽闼底媘嘩埇脘嚔誌毬喘底施閘㔗
誻橬婔傽庋唚冖婔柊闼儌滇 pg_start_backup
庘昄婘昄扞康镖䆴䕞嘘麯录傺庖婔婻埆 backup_label 䔇桺傽垄赆 pg_stop_backup
役鍴㔗認婻桺傽嘷䇽幘嚔嘩婺崺傘蘸嗘桺傽䔇婔鄘彖嘐懼㔗認婻崺傘湺了桺傽寙劆嘹䂍庽 pg_start_backup
䔇湺了庖严婾傖埪 pg_start_backup
誊臯䔇施彂傖埪蕙哋 WAL 桺傽䔇劉庖㔗套悩橬晙晖闼幽潏傸埇傖䩋䩋崺傘蘸嗘桺傽麯麵䇽劯彴桺蘸嗘桺傽準躻闼婻崺傘嚔臺㔗
潏傸誻埇傖婘橉媇単啩溵䔇施唍彽嘩婔婻崺傘蘸嗘㔗婘認䓉溇傽婋冽滯滆嘹婉脘嘪䫘 pg_start_backup
潡 pg_stop_backup
幽婫啹溴嘹媙釂麹躻噌䔇欋枕準虘詻崺傘蘸嗘桺傽鄘滇闼底傖埪䕩噿䔇 WAL 桺傽橔誩蕄彄巻麯㔗锔婩嘪䫘婪麵䔇婘亪崺傘準黴敘喘底㔗
喘橔俘俘䔇庋愙埏䫘庖䯄婘嘹驔襕傯崺傘婺敵崉㔗婋麵滇準黴
啩溵橉媇単套悩垄誻婘誊臯䔇臺㔗
套悩嘹誻橬轿崘䔇䷺閘檪昘婻镖䆴昄扞䕞嘘启欔橬臘䷺閘拙蘺彄婔婻婘施嘉䘞傖黾婺婔嘹幋劯誻驔襕垄傸㔗臙濘懟認婻鵇黾毻桘襕挗嘹婘係䂘麯橬轿崘䔇嬷嘍䷺閘準䯄橬康䔇媺毕婴傘拙蘺㔗套悩嘹澇橬轿崘䔇䷺閘闼幽嘹躿儏驔襕檪镖䆴昄扞䕞嘘䔇 pg_xlog 床䕞嘘䔇喙垹拙蘺彄垬噘䔇婄桹啹婺垄傸埇脘寙劆係䂘垘毬䔇施唍誻澇橬嘐懼䔇斖媖㔗
䇽劯橙䊖毬欔橬婘臖镖䆴昄扞䕞嘘麯䔇䯄庻桺傽傖埪欔橬嘹嘪䫘䔇臘䷺閘麯湹䕞嘘婋䔇䯄庻桺傽㔗
傯嘹䔇崺傘蘸嗘婺敵崉昄扞康桺傽㔗襕償媄䫘溼䇞䔇欔橬蔙(昄扞康係䂘䫘潙蔯婉滇 root)启溄鍊敵崉垄傸㔗套悩嘹嘪䫘庖臘䷺閘嘹埇脘驔襕湩垂婘 pg_tblspc/ 麯䔇严埙誂毖鄘冖彄溼䇞敵崉㔗
役鍴傂嘘䕞嬉誻婘 pg_xlog/ 麯䔇桺傽認底桺傽準躻崺傘蘸嗘啹溴垄傸埇脘懫䕞嬉䔇蔕㔗套悩嘹儌湹橸澇橬嘐懼 pg_xlog/ 闼幽麉傺幋襕濘懟幘襕麉傺 pg_xlog/archive_status/ 床䕞嘘㔗
套悩嘹橬婘準黴 2 麯麵媺庻䔇 WAL 枕桺傽闼幽檪垄傸拙蘺彄 pg_xlog/ 㔗橔喘滇拙蘺垄傸蔯婉滇檪垄傸䓂媘啂準認湙剿嘪埏䫘庖俘俘䔇庋愙嘹驔襕麉劇䔇施唍嘹幘冺䇽拖橬橻媞櫹䔇桺傽㔗
婘镖䆴昄扞䕞嘘麯录傺婔婻敵崉变傴桺傽 recovery.conf(埗黙敵崉螆䘞)㔗嘹埇脘誻驔襕婘施媞櫹 pg_hba.conf 傖镪噉捞锔䫘潙誂毖䕘彄嘹䇞媇敵崉噾䂟溼婩庖婺溵㔗
劇媘橉媇単㔗橉媇単儖誕噖敵崉昇嚟幽婫䂓䂺臂埡垄驔襕䔇 WAL 嘐懼桺傽㔗婘镺蓕崡鄘髍臇䔇庫嘷婺溵敵崉誺䘋䇽劯麉桄劇媘橉媇単認湙垄嚔躻媘䂓䂺誕臯敵崉噖嘩㔗婘敵崉誺䘋垯潊劯橉媇単儖檪 recovery.conf 櫹劉婺 recovery.done 傖镪噉婉償媄啹劯麵䔇嘷溄喉渇誕噖敵崉昇嚟䇽劯嚔哋溼婩䔇昄扞康淉嘩㔗
演昖昄扞康䔇喙垹傖䇞媺嘹噾䂟敵崉彄嘹橘橕䔇嘉䘞㔗套悩誻澇橬啂彄準黴 1 㔗套悩噘鄘溼婩彍敵崉 pg_hba.conf 潊溼婩䪽攕傖噕螩捞锔䫘潙䍂嘘㔗
欔橬認底淉嘩䔇噿髞滇螆䘞婔婻敵崉变傴桺傽認婻桺傽柟誄嘹婯橕套嘘敵崉傖埪敵崉庫臖蕄彄巻麯㔗嘹埇傖嘪䫘 recovery.conf.sample(锔婩垬輙婘垬輙䕞嘘䔇 share/ 床䕞嘘麯)嘩婺寘傋㔗嘹媙釂婘 recovery.conf 麯麵弄滯䔇婔婻婩薪滇 restore_command 垄只臬係䂘套嘘拪啂嘐懼䔇 WAL 桺傽枕㔗䌂嚚 archive_command 認婻滇婔婻臔橸变傴庖严婾㔗垄埇傖寙劆 %f 認婻埻麟嚔赆驔襕䔇斖媖桺傽劉敪扵傖埪 %p 垄嚔赆襕拙蘺寂䔇斖媖桺傽䔇䂺凹虇冇傼敪㔗套悩驔襕婘变傴麯敪扵䩘溼䔇 % 庖严闼幽儌埯喍(%%)㔗橔䞔剘䔇橬䫘变傴滇䌂嚚婋麵䔇婩薪
restore_command = 'cp /mnt/server/archivedir/%f %p'
認婻变傴儖檪傖嬉嘐懼䔇 WAL 枕傯 /mnt/server/archivedir 䕞嘘拙蘺誺準㔗嘹嘷䇽埇傖嘪䫘昊底敘崉溗䔇婩薪䫔躿滇婔婻襕挗淉嘩蔙毗蘘劽锗䔇伕婥䔇 shell 臔橸㔗
麉襕䔇婔䗹滇臖变傴婘崌蘖䔇施唍誫啂麂镽唚㔗套悩斖媖桺傽澇橬庺䯄婘蓇懼婺闼幽臖係䂘儖臵閞臖变傴婘閞彄䔇施唍垄媙釂誫啂麂镽㔗認婻婉滇髍臇溇傽㔗誻襕濘懟 %p 虇冇䔇嘺䇔劉儖启 %f 婉婔湙婉襕螴婺垄傸滇埇傖庐扵䔇㔗
婘嘐懼婺欆婉彄䔇 WAL 枕儖赆螴婺婘 pg_xlog/ 麯認湙儌噕螩嘪䫘橔誏澇橬嘐懼䔇枕㔗嘖滇婘嘐懼婺䔇枕儖懫 pg_xlog/ 婺䔇嚻噽㔗婘演䘵嘐懼桺傽䔇施唍係䂘儖婉嚔襖䕡䯄橬䔇 pg_xlog/ 喙垹㔗
锔婩敵崉儖崇䊖欔橬埇䫘䔇 WAL 枕啹溴儖檪昄扞康敵崉彄嘷嬉施閘(潡蔙滇婘欔䂍庺䔇埇䫘 WAL 枕昄䔇愙喕婋潏傸脘蕄彄䔇橔誏䔇婄桹)㔗嘖滇套悩嘹愿敵崉彄昊底傖嬉䔇施彂䗹(懫套婘蟩驘 DBA 役鍴嘹䔇婂襕庋媇臘幋嬉)闼幽埻驔襕婘 recovery.conf 麯弄滯襕挗䔇啩溵䗹㔗嘹埇傖锔誺斖橘/施閘準弄滯幘埇傖锔誺䬹垔庋媇 ID 䔇䂷溘準弄滯認婻啩溵䗹潏傸埆啔"敵崉䕞湺"㔗䕞嬉埻橬斖橘/施閘锬釹懫膄橬䫘啹婺潏傸澇橬噖噙準婞媷嘹來䇞婄湺臖庫臖嘪䫘巻婻庋媇 ID 㔗
㔊濘懟㔏臙濘懟啩溵䗹媙釂婘崺傘䔇䂽溵施閘幋劯(幘儌滇
pg_stop_backup
䔇施閘)㔗嘹方濘嘪䫘婔婻嘺䇔崺傘敵崉彄崺傘溼婘誕臯婺䔇昊婻施彂㔗襕愿敵崉彄臖施彂嘹媙釂啂彄嘹傖嬉䔇嘺䇔崺傘䇽劯傯闼婻嘉䘞劏嬉悔媘㔗
套悩婘敵崉誺䘋婺埏䯄婘 WAL 昄扞婺庻婘髍臇闼幽敵崉儖婘髍臇䔇婄桹啩溵幽婫婉嚔劇媘橉媇単㔗婘認䓉愙喕婋埇傖毺垔婔婻嘉庯髍臇䗹幋嬉䔇"敵崉䕞湺"䇽劯傯蕙哋䗹嚔哋麉桄誊臯敵崉誕䘋認湙敵崉儌埇傖溼婩垯潊㔗套悩䫌庯崡鄘寘啹(係䂘嘷溄㔕方濘臂埡 WAL 嘐懼)凚躘敵崉崌蘖闼幽埇傖䞔剘䔇麉桄劇媘敵崉誺䘋剿埇垄儖傯婪渇崌蘖䔇婄桹䂓䂺㔗麉桄劇媘敵崉誺䘋婯演昖䗹䔇淉嘩麂婩䌂嚚橉媇単变橘攓䔇嚺彽儖噽䪽攕螄嘘彄伕䕻婪幽敘桄 pg_control 桺傽傖湺臖噾䂟崇䊖䔇 WAL 昄扞婉驔襕赆喉渇欆柟㔗
認底螆䘞埻脘婘 recovery.conf 麯麵嘪䫘幽婫埻滇婘敵崉䔇誺䘋婺蕙嘩䫘㔗婘傂嘘幋劯䔇敵崉婺嘹媙釂麉桄螆䘞傡傸㔗敵崉誺䘋嚔哋劯垄傸䔇唚方濘櫹埻㔗
欓臯演䘵嘐懼 WAL 桺傽枕废彖䔇 shell 变傴㔗認婻埗昄滇媙釂䔇㔗庖严婾婺䔇傂嘘 %f 鄘赆傯嘐懼婺演䘵庺準䔇桺傽劉敪扵蔯傂嘘 %p 鄘赆敪扵婺拙蘺誺寂䔇橉媇単婪䔇虇冇(䕩凹庯橉媇単噖嘩䕞嘘幘儌滇镖䆴䔇昄扞䕞嘘)㔗驔襕婘变傴麯啯噖䩘溼䔇 % 庖严滇媙釂埯喍(%%)㔗
橬婔䗹冽麉襕闼儌滇認婻变傴埻橬婘潊媘䔇施唍欉誫啂镽㔗係䂘嚔劏認溇变傴臵閞澇橬婘嘐懼麯庺䯄䔇桺傽劉婘認䓉愙喕婋垄媙釂誫啂麂镽㔗懫套
restore_command = 'cp /mnt/server/archivedir/%f "%p"' restore_command = 'copy /mnt/server/archivedir/%f "%p"' # Windows
認婻埗昄弄滯敵崉欓臯彄膆䔇施閘潿㔗橔崔埇傖弄滯婔婻 recovery_target_time 启 recovery_target_xid 㔗䚺䩕滇敵崉彄 WAL 斖媖䔇䂷儆㔗來䇞䔇啩溵䗹幘埖 recovery_target_inclusive 嘌巉㔗
認婻埗昄弄滯敵崉儖彄膆䔇庋媇 ID 㔗襕濘懟䔇滇儘䞇庋媇 ID 婘庋媇嚔哋䔇施唍滇螴婺釺废䔇嘖滇庋媇埇傖傖婉劯䔇昄唚釺废垯潊㔗儖襕敵崉䔇庋媇滇闼底婘認婻噾弄滯庋媇幋嬉(埇傖锬拷寙拸垄柊庴䔇施唍)柊庴䔇庋媇㔗橔崔埇傖弄滯 recovery_target_xid 启 recovery_target_time 幋婔㔗䚺䩕滇敵崉彄 WAL 斖媖䔇䂷儆㔗來䇞䔇啩溵䗹幘埖 recovery_target_inclusive 嘌巉㔗
弄滯滇婘敵崉䕞湺幋劯(true)誻滇幋嬉(false)啩溵㔗劯施锗䫘庯 recovery_target_time 启 recovery_target_xid 蔯婉䞇垂鍙弄滯䔇滇巻婻㔗垄彖彆臘䴺滇劥婘敵崉婺寙劆噙橬庖䇞柊庴施閘潡蔙庋媇 ID 䔇闼底(婻)庋媇㔗䚺䩕滇 true 㔗
弄滯敵崉彄婔婻䬹垔䔇施閘亪㔗䚺䩕滇敵崉彄誕臯嘺䇔崺傘施䔇施閘亪婪㔗埻滇婘崉溗䔇麉桄敵崉䔇愙喕婋嘹欉驔襕螆䘞認婻埗昄幘儌滇婘嘹驔襕敵崉彄婔婻橸躆滇婘剿施敵崉幋劯彄膆䔇䪽攕婋欉驔襕認幽啔㔗埗黙誗23.3.4㔗
脘崘檪昄扞康敵崉彄傖嬉䔇昊婻施閘䗹䔇脘媕凚躘庖婔底䌂嚚䓏幂償臘麯䔇施閘虘詻启幽臯垺垍認湙䔇崉溗愙喕㔗婘昄扞康橔彺䔇寖埾麯埇脘嘹婘变庯婋剽 5:15 役鍴毬庖婔婻麂婩噿髞䔇臘㔗䇽劯橬溇婉䘪婄拪庺崺傘敵崉彄变庯捔婪 5:14 䔇剿施崺傘㔗婘認婻昄扞康垺垍䔇寖埾麯嘹傯準澇橬役鍴誺闼婻臘㔗嘖滇啺套嘹劯準螴臖彄認幽幾滇髍臇䔇幽婫愿啂彄橔彺䔇寖埾婺䔇䘉劯䔇䗹㔗嘹澇濘認幽幾啹婺婘昄扞康誊臯䔇施唍垄襖䕡庖婔底 WAL 枕桺傽䔇废彖認底废彖儌婘嘹婯橕啂寂䔇寺閘麯㔗啹溴嘹䔇䇞驔襕寺彖婘嘹傯闼底寘哋昄扞康寖埾䫘潊䔇 WAL 婺垯潊剿施敵崉幋劯䫘潊䔇 WAL 废彖㔗
婺庖崇䊖認底閞鵻PostgreSQL 橬婻埆施閘亪䔇楗媕㔗懟渇嘹剿施敵崉彄婔婻懫 WAL 废彖䂷儆敘斷䔇施彂闼幽儌录傺婔婻桄䔇施閘亪傖臘䴺婘臖渇敵崉幋劯䫘潊䔇 WAL 螄嘘㔗婉誺套悩敵崉媘嘩婔䕘崇䊖彄 WAL 䂷儆儌婉嚔嚔哋婔婻桄䔇施閘亪蔯埻滇欷匘䯄橬婻闼婻㔗施閘亪 ID 埙滇 WAL 枕桺傽劉䔇婔鄘彖啹溴桄䔇施閘亪幽婉嚔襖䕡傖嬉䔇施閘亪䫘潊䔇 WAL 昄扞㔗垂鍙婪潏傸埇傖嘐懼螩崔婉劯䔇施閘亪㔗荘䇽認底䩋蕙準償澇䫘䔇䬹攓嘖垄剘埇脘婩婩滇昏变䘂艬㔗蔄荏婔婋嘹幽婉冽䇞媇庫臖敵崉彄闼婻施彂䔇愙喕認婻施唍嘹婉冖婉啔喘庹渇臘黯攓剿施敵崉䇽劯傯婺欆彄斓寖埾婺橔喘䔇彖櫇㔗套悩澇橬施閘亪闼幽認婻誺䘋埇脘冽媆儌嚔凚躘方濘䞇䊖䔇晙幌㔗橬庖施閘亪嘹埇傖敵崉彄傂懟傖嬉䔇䪽攕寙拸敵崉彄嘹劯準櫆嚄䔇施閘亪彖櫇䔇䪽攕㔗
懟嘷录傺婔婻桄䔇施閘亪䔇施唍PostgreSQL 鄘录傺婔婻"施閘亪寖埾"桺傽垄滆䴺躻噌傯巻婻施閘亪彖庺準傖埪嘘施彖庺準䔇㔗認底寖埾桺傽滇婘傯寙劆崔婻施閘亪䔇嘐懼婺誕臯敵崉施噕螩係䂘锬埡溼䇞 WAL 枕桺傽䔇媙襕桺傽㔗啹溴垄傸償 WAL 枕桺傽婔湙嘐懼彄 WAL 嘐懼麯㔗寖埾桺傽埻滇冽償䔇桺橸桺傽(婉償枕桺傽冽崓)欔傖䋸䆋婄媺庻傡傸傼備冽償幘唚冖啔㔗套悩嘹塩渵嘹埇傖婘寖埾桺傽麯媹噖濘麪螄嘘躻噌婺傔幽螆䘞認婻施閘亪傖埪套嘘螆䘞䔇京媇敇㔗認湙䔇濘麪嚔婘嘹橬寔寔婔幖婉劯䔇施閘亪驔襕锬拷启彖悊䔇施唍䬹彆橬備唚㔗
敵崉䔇䚺䩕䔇臯婺滇澪五婯嘺䇔崺傘䔇劯婔婻施閘亪敵崉㔗套悩嘹愿敵崉彄昊底床施閘亪幘儌滇嘹愿啂彄昊底橸躆儌滇婘嚔哋敵崉幋劯埏䫘䔇䪽攕㔗嘹驔襕婘 recovery.conf 麯弄滯䕞湺施閘亪 ID 㔗嘹方濘敵崉彄懫嘺䇔崺傘敘斷䔇施閘亪彖櫇㔗
䕞嬉婘亪崺傘檔橇誻橬庹婻匔鍊㔗垄傸埇脘婘儖準䔇䬽橸婺媞臖
婘 Hash 䘵嚘婪䔇淉嘩䕞嬉澇橬嘪䫘 WAL 螄嘘斖媖欔傖麉櫆儌婉嚔敘桄認底䘵嚘䌂傋㔗潏傸傺螞䔇䂘嚔桹濘滇婘垯潊敵崉淉嘩幋劯欋噖 REINDEX 懟婻認湙䔇䘵嚘㔗
套悩婘誕臯昄扞康崺傘䔇施唍埏庺婔婻 CREATE DATABASE 变傴䇽劯婘認婻誺䘋婺 CREATE DATABASE 变傴拙蘺䔇昇溪昄扞康赆媞櫹庖闼幽䫘認婻崺傘誕臯敵崉䔇昄扞康冽橬埇脘凚躘認底媞櫹幘嚹携彄桄录傺䔇昄扞康婺寂㔗認婻臯婺嘷䇽滇婉懪懟䩋彄䔇㔗婺庖镪噉認婻鼯鍷橔喘婘誕臯昄扞康崺傘䔇施唍婉襕媞櫹傂嘘昇溪昄扞康㔗
CREATE TABLESPACE 变傴滇䫘桺橸䔇䂺凹虇冇螄嘘 WAL 斖媖䔇啹溴嚔傖䕩劯䔇䂺凹虇冇麉桄录傺㔗套悩斖媖滇婘埥崡婔埄橺単婪麉櫆闼幽認婻臯婺埇脘婉滇潏傸愿襕䔇㔗剿嘪婘劯婔埄橺単嘖滇婘婔婻桄䔇昄扞䕞嘘麯麉櫆斖媖鄘冽埇脘滇剌鍷䔇麉櫆傉儖嚔襖䕡寘準䔇臘䷺閘䔇喙垹㔗婺庖镪噉認䌂䔇昩婘閞鵻橔喘䔇桹濘滇婘录傺潡蔙役鍴臘䷺閘幋劯誕臯婔渇桄䔇嘺䇔崺傘㔗
誻襕濘懟䚺䩕䔇 WAL 湚嚟嘷䓇䕩嘷崓啹婺垄寙劆螩崔伕䕻釕媆䙓㔗認底伕䕻釕媆䙓滇螆螇準櫇毕嘷溄敵崉䔇啹婺潏傸埇脘驔襕媞臖鄘彖喍噖䔇伕䕻釕㔗湹扞嘹䔇係䂘䇸傽启蘇傽䔇婉劯認䓉鄘彖喍噖䔇剌鍷埇脘滇冞幯噽冞䔇㔗認䓉愙喕婋嘹埇傖锔誺嘪䫘 full_page_writes 噿閺伕䕻釕麵媆䙓傯蔯崓崓废儏嘐懼斖媖䔇攂儺凩(婘嘹認幽啔幋嬉黙臂䆹27麯麵䔇濘懟启躥只)㔗噿閺釕麵媆䙓幽婉黂溵斖媖嘪䫘 PITR 淉嘩㔗婔婻儖準驔襕嚔埏䔇媘脘滇婘 full_page_writes 欷嚔䔇施唍锔誺役鍴婉驔襕䔇伕䕻釕拙蘺準寋䚷嘐懼䔇 WAL 昄扞㔗劯施䞇䊖叻埇傖锔誺儘麟劽䊖婄嵂媹演昖䗹䔇施閘閘锫準废儏寙劆婘 WAL 麯䔇釕麵媆䙓㔗