成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

利用WalMiner解析PostgreSQL的WAL日志

IT那活兒 / 1976人閱讀
利用WalMiner解析PostgreSQL的WAL日志
點擊上方“IT那活兒”公眾號,關(guān)注后了解更多內(nèi)容,不管IT什么活兒,干就完了?。?!

前奏

WalMiner是從PostgreSQL的WAL(write ahead logs)日志的解析工具,旨在挖掘wal日志所有的有用信息,從而提供PG的數(shù)據(jù)恢復(fù)支持。如果出現(xiàn)業(yè)務(wù)誤操作DML的情況,可以及時挽回數(shù)據(jù)。

1.1 安裝WalMiner

上來就踩坑,編譯報錯:
make: /opt/rh/llvm-toolset-7/root/bin/clang: Command not found
make: *** [pg_logminer.bc] Error 127
處理方式,注釋插件控制bc:
cd /app/pg/pg_156_5432/postgresql/lib/postgresql/pgxs/src/makefiles/
vi pgxs.mk

#
ifeq ($(with_llvm), yes)

#all: $(addsuffix .bc, $(MODULES)) $(patsubst %.o,%.bc, $(OBJS))
#endif

#ifeq ($(with_llvm), yes)
#       $(foreach mod, $(MODULES), $(call install_llvm_module,$(mod),$(mod).bc))
#endif # with_llvm

#
ifeq ($(with_llvm), yes)

#       $(call install_llvm_module,$(MODULE_big),$(OBJS))
#endif # with_llvm

#
ifeq ($(with_llvm), yes)

#       $(foreach mod, $(MODULES), $(call uninstall_llvm_module,$(mod)))
#endif # with_llvm

#
ifeq ($(with_llvm), yes)

#       $(call uninstall_llvm_module,$(MODULE_big))
#endif # with_llvm

1.2 重新編譯,記得刷新postgresql環(huán)境變量

/usr/bin/mkdir -p /app/pg/pg_156_5432/postgresql/lib/postgresql
/usr/bin/mkdir -p /app/pg/pg_156_5432/postgresql/share/postgresql/extension
/usr/bin/mkdir -p /app/pg/pg_156_5432/postgresql/share/postgresql/extension
/usr/bin/install -c -m 755  walminer.so /app/pg/pg_156_5432/postgresql/lib/postgresql/walminer.so
/usr/bin/install -c -m 644 .//walminer.control /app/pg/pg_156_5432/postgresql/share/postgresql/extension/
/usr/bin/install -c -m 644 .//walminer--1.0.sql /app/pg/pg_156_5432/postgresql/share/postgresql/extension/

1.3 進庫創(chuàng)建

postgres=# create extension walminer;
CREATE EXTENSION
postgres=# dx
List of installed extensions
Name | Version |   Schema | Description
--------------------+---------+------------+-----------------------------------------------------------
pg_stat_statements |
 1.7     | public | track execution statistics of all SQL statements executed
plpgsql | 1.0 | pg_catalog | PL/pgSQL procedural language
telepg_monitor |
 2.7.6   | public | Expansion monitoring module
walminer | 1.0 | public | inspect the contents of database pages at a low level


解析步驟

2.1 添加要解析的wal日志文件

postgres=# select walminer_wal_add(/app/pg/data_156_5432/data/pg_wal);
NOTICE: Get data dictionary from current database.
walminer_wal_add
---------------------
13 file add success
(1 row)

2.2 查看可以解析的文件

postgres=# select walminer_wal_list();
walminer_wal_list
---------------------------------------------------------------
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000001)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000002)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000003)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000004)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000005)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000006)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000007)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000008)
(/app/pg/data_156_5432/data/pg_wal/000000010000000000000009)
(/app/pg/data_156_5432/data/pg_wal/00000001000000000000000A)
(/app/pg/data_156_5432/data/pg_wal/00000001000000000000000B)
(/app/pg/data_156_5432/data/pg_wal/00000001000000000000000C)
(/app/pg/data_156_5432/data/pg_wal/00000001000000000000000D)
(13 rows)

2.3 解析wal

postgres=# select walminer_start(null,null,0,0);
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000001
NOTICE: wal record after time 2022-02-24 18:17:44+08 or 0/166aff0 will be analyse completely
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000002
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000003
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000004
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000005
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000006
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000007
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000008
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/000000010000000000000009
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/00000001000000000000000A
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/00000001000000000000000B
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/00000001000000000000000C
NOTICE: Change Wal Segment To:/app/pg/data_156_5432/data/pg_wal/00000001000000000000000D
walminer_start
---------------------
walminer sucessful!
(1 row)

2.4 查看解析結(jié)果

postgres=# select * from walminer_contents;
-[ RECORD 1 ]-----+-------------------------------------------------------------
xid | 609
virtualxid |
 1
timestamptz | 2022-06-13 16:25:42.259986+08
record_database |
 postgres
record_user | root
record_tablespace |
 pg_default
record_schema | public
op_type |
 INSERT
op_text | INSERT INTO "public"."test"("id") VALUES(1);
op_undo |
 DELETE FROM "public"."test" WHERE "id"=1 AND ctid = (0,1);
lsn | 0/DAA6138
commit_end_lsn |
 0/DAA61A8

walminer_contents字段含義:

  • sqlno int, --本條sql在其事務(wù)內(nèi)的序號;
  • xid bigint, --事務(wù)ID;
  • topxid bigint, --如果為子事務(wù),這是是其父事務(wù);否則為0;
  • sqlkind int, --sql類型1->insert;2->update;3->delete(待優(yōu)化項目);
  • minerd bool, --解析結(jié)果是否完整(缺失checkpoint情況下可能無法解析出正確結(jié)果);
  • timestamp timestampTz,   --這個SQL所在事務(wù)提交的時間;
  • op_text text, --sql;
  • undo_text text,  --undo sql;
  • complete bool, --如果為false,說明有可能這個sql所在的事務(wù)是不完整解析的;
  • schema text, --目標(biāo)表所在的模式;
  • relation text, --目標(biāo)表表名;
  • start_lsn pg_lsn,  --這個記錄的開始LSN;
  • commit_lsn pg_lsn    --這個事務(wù)的提交LSN。

2.5 結(jié)束walminer操作

select walminer_stop();


常規(guī)操作

3.1 根據(jù)時間解析
select walminer_by_time(starttime, endtime);
3.2 精確到表的解析
select walminer_by_xid(xid,true,reloid);

注:true和‘false’代表是否為精確解析模式,reloid為目標(biāo)表的oid(注意不是relfilenode)


適用性

4.1 優(yōu)點
walminer可執(zhí)行的騷操作:walminer是提供解析功能,可以挪用別的數(shù)據(jù)庫的wal日志到有插件的數(shù)據(jù)上執(zhí)行(數(shù)據(jù)庫版本一致,要依靠數(shù)據(jù)字典),并查看。避免沒有插件,再安裝插件耽誤時間。

4.2 使用注意事項

  • 1)walminer對DDL支持力度不大,很多無法解析,不建議作為解析DDL依靠。
  • 2)walminer版本有三個,建議用2.0,telepg12.4不支持3.0。
  • 3)PG11/PG12中WAL文件大小必須16MB。


本文作者:饒茂林(上海新炬中北團隊)

本文來源:“IT那活兒”公眾號


文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/129118.html

相關(guān)文章

發(fā)表評論

0條評論

IT那活兒

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<