主機 | 操作系統(tǒng) | IP | 數(shù)據(jù)庫 |
postgresql1 | Red Hat Enterprise 6.5 | 192.168.20.101 | PostgreSQL10.0 |
postgresql2 | Red Hat Enterprise 6.5 | 192.168.20.102 | PostgreSQL10.0 |
rpm -qa --queryformat "%{NAME}-%{VERSION}-%{RELEASE} (%{ARCH}) " | grep -E "perl-ExtUtils-Embed|readline-devel|zlib-devel|pam-devel|libxml2-devel|libxslt-devel|openldap-devel| python-devel|gcc-c++|openssl-devel|cmake|readline|openssl|zlib" |
vi source.repo [rhel-source-beta] name=Source baseurl=file:///media enabled=1 gpgcheck=0 |
yum install -y readline-devel zlib-devel pam-devel libxml2-devel libxslt-devel openldap-devel python-devel gcc-c++ openssl-devel cmake |
groupadd -g 1000 postgres useradd -u 1100 -g postgres -G postgres -d /home/postgres postgres mkdir -p /pgadmin/pg_data mkdir -p /pgadmin/postgres10 chown -R postgres:postgres /pgadmin/pg_data chown -R postgres:postgres /pgadmin/postgres10 |
下載源碼包postgresql-10.0.tar.gz上傳到服務(wù)器
cp postgresql-10.0.tar.gz /tmp/soft tar -xvf postgresql-10.0.tar.gz --編譯安裝 cd postgresql-10.0 ./configure --prefix=/pgadmin/postgres10 make world make install-world |
日志:
./configure--prefix=/pgadmin/postgres10
makeword
makeinstall-world
初始化(密碼:postgres) mkdir -p /pgadmin/pg_data/10.0/{data,backups,scripts,archive_wals} /pgadmin/pgsql/bin/initdb -D /pgadmin/pg_data/10.0/data/ -W |
日志:
[postgres@postgresql2 ~]$ /pgadmin/pgsql/bin/initdb -D /pgadmin/pg_data/10.0/data/ -W The files belonging to this database system will be owned by user "postgres". This user must also own the server process. The database cluster will be initialized with locale "en_US.UTF-8". The default database encoding has accordingly been set to "UTF8". The default text search configuration will be set to "english". Data page checksums are disabled. Enter new superuser password: Enter it again: fixing permissions on existing directory /pgadmin/pg_data/10.0/data ... ok creating subdirectories ... ok selecting default max_connections ... 100 selecting default shared_buffers ... 128MB selecting dynamic shared memory implementation ... posix creating configuration files ... ok running bootstrap script ... ok performing post-bootstrap initialization ... ok syncing data to disk ... ok WARNING: enabling "trust" authentication for local connections You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb. Success. You can now start the database server using: /pgadmin/pgsql/bin/pg_ctl -D /pgadmin/pg_data/10.0/data/ -l logfile start [postgres@postgresql2 ~]$ |
ln -s /pgadmin/postgres10 /pgadmin/pgsql |
如果不配置PGHOST,后面通過psql登陸會報錯
export PGSQL_HOME=/pgadmin/pgsql export PGHOST=/pgadmin/pg_data/10.0/data export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PGSQL_HOME/lib export PATH=$PGSQL_HOME/bin:$PATH export PGDATA=/pgadmin/pg_data/10.0/data |
在兩個節(jié)點執(zhí)行 mkdir /home/postgres/.ssh chmod 600 /home/postgres/.ssh ssh-keygen -t dsa ssh-keygen -t rsa cd /home/postgres/.ssh cat id_dsa.pub > authorized_keys cat id_rsa.pub >> authorized_keys 在node1執(zhí)行 ssh postgresql2 cat /home/postgres/.ssh/authorized_keys >>authorized_keys scp authorized_keys postgresql2:/home/postgres/.ssh/ |
2.10、修改配置文件
cd /pgadmin/pg_data/10.0/data cp pg_hba.conf pg_hba.conf20200904 vi pg_hba.conf(增加如下信息) host all all 0.0.0.0/0 md5 |
vi postgresql.conf #添加如下內(nèi)容 listen_addresses = * port = 5432 superuser_reserved_connections = 20 unix_socket_directories = /pgadmin/pg_data/10.0/data unix_socket_permissions = 0700 tcp_keepalives_idle = 60 tcp_keepalives_interval = 10 tcp_keepalives_count = 10 vacuum_cost_delay = 10 bgwriter_delay = 10ms synchronous_commit = off #checkpoint_segments = 8 wal_writer_delay = 10ms log_destination = csvlog logging_collector = on log_directory = pg_log log_filename =postgresql-%Y-%m-%d_%H%M%S.log log_file_mode = 0600 log_truncate_on_rotation = on log_rotation_age = 1d log_rotation_size = 10MB pg_ctl start 啟動數(shù)據(jù)庫 pg_ctl -m fast stop 停止數(shù)據(jù)庫 pg_ctl restart 重啟數(shù)據(jù)庫 ps -ef | grep postgres 數(shù)據(jù)庫服務(wù)是否正常啟動 psql -h 127.0.0.1 -d postgres -U postgres 登錄數(shù)據(jù)庫測試 |
[postgres@postgresql1 data]$ pg_ctl start pg_ctl: another server might be running; trying to start server anyway waiting for server to start....2020-09-04 02:04:48.182 GMT [3524] LOG: listening on IPv4 address "0.0.0.0", port 5432 2020-09-04 02:04:48.182 GMT [3524] LOG: listening on IPv6 address "::", port 5432 2020-09-04 02:04:48.186 GMT [3524] LOG: listening on Unix socket "/pgadmin/pg_data/10.0/data/.s.PGSQL.5432" 2020-09-04 02:04:48.222 GMT [3524] LOG: redirecting log output to logging collector process 2020-09-04 02:04:48.222 GMT [3524] HINT: Future log output will appear in directory "pg_log". done server started [postgres@postgresql1 data]$ [postgres@postgresql1 data]$ ps -ef|grep postgres root 3465 2596 0 09:59 pts/0 00:00:00 su - postgres postgres 3466 3465 0 09:59 pts/0 00:00:00 -bash postgres 3524 1 0 10:04 pts/0 00:00:00 /pgadmin/postgres10/bin/postgres postgres 3525 3524 0 10:04 ? 00:00:00 postgres: logger process postgres 3527 3524 0 10:04 ? 00:00:00 postgres: checkpointer process postgres 3528 3524 0 10:04 ? 00:00:00 postgres: writer process postgres 3529 3524 0 10:04 ? 00:00:00 postgres: wal writer process postgres 3530 3524 0 10:04 ? 00:00:00 postgres: autovacuum launcher process postgres 3531 3524 0 10:04 ? 00:00:00 postgres: stats collector process postgres 3532 3524 0 10:04 ? 00:00:00 postgres: bgworker: logical replication launcher postgres 3533 3466 7 10:04 pts/0 00:00:00 ps -ef postgres 3534 3466 0 10:04 pts/0 00:00:00 grep postgres [postgres@postgresql1 data]$ [postgres@postgresql1 data]$ pg_ctl -m fast stop waiting for server to shut down.... done server stopped [postgres@postgresql1 data]$ pg_ctl restart pg_ctl: PID file "/pgadmin/pg_data/10.0/data/postmaster.pid" does not exist Is server running? starting server anyway waiting for server to start....2020-09-04 02:05:25.327 GMT [3538] LOG: listening on IPv4 address "0.0.0.0", port 5432 2020-09-04 02:05:25.327 GMT [3538] LOG: listening on IPv6 address "::", port 5432 2020-09-04 02:05:25.330 GMT [3538] LOG: listening on Unix socket "/pgadmin/pg_data/10.0/data/.s.PGSQL.5432" 2020-09-04 02:05:25.336 GMT [3538] LOG: redirecting log output to logging collector process 2020-09-04 02:05:25.336 GMT [3538] HINT: Future log output will appear in directory "pg_log". done server started [postgres@postgresql1 data]$ ps -ef | grep postgres root 3465 2596 0 09:59 pts/0 00:00:00 su - postgres postgres 3466 3465 0 09:59 pts/0 00:00:00 -bash postgres 3538 1 0 10:05 pts/0 00:00:00 /pgadmin/postgres10/bin/postgres postgres 3539 3538 0 10:05 ? 00:00:00 postgres: logger process postgres 3541 3538 0 10:05 ? 00:00:00 postgres: checkpointer process postgres 3542 3538 0 10:05 ? 00:00:00 postgres: writer process postgres 3543 3538 0 10:05 ? 00:00:00 postgres: wal writer process postgres 3544 3538 0 10:05 ? 00:00:00 postgres: autovacuum launcher process postgres 3545 3538 0 10:05 ? 00:00:00 postgres: stats collector process postgres 3546 3538 0 10:05 ? 00:00:00 postgres: bgworker: logical replication launcher postgres 3547 3466 2 10:05 pts/0 00:00:00 ps -ef postgres 3548 3466 0 10:05 pts/0 00:00:00 grep postgres [postgres@postgresql1 data]$ psql -h 127.0.0.1 -d postgres -U postgres psql (10.0) Type "help" for help. postgres=# |
create role cyl superuser; alter role cyl password cyl; alter role cyl login; |
創(chuàng)建
cd $PGDATA vi pg_hba.conf #添加如下內(nèi)容 host replication replica 0.0.0.0/0 md5 vi postgresql.conf #添加如下內(nèi)容 listen_addresses = * port = 5432 max_connections = 500 #然后重啟一下數(shù)據(jù)庫就可以正常使用了,至此前期準備工作已經(jīng)完成 pg_ctl start 啟動數(shù)據(jù)庫 |
vi postgresql.conf 接著在文件末尾添加如下 wal_level = hot_standby checkpoint_segments = 16 checkpoint_timeout = 5min archive_mode = on max_wal_senders = 3 wal_keep_segments = 16 wal_level = hot_standby 這個是設(shè)置主為wal的主機 max_wal_senders = 3 這個設(shè)置了可以最多有幾個流復制連接,差不多有幾個從,就設(shè)置幾個 wal_keep_segments = 16 設(shè)置流復制保留的最多的xlog數(shù)目 checkpoint_segments = 16 WAL log的最大數(shù)量,系統(tǒng)默認值是3。超過該數(shù)量的WAL日志,會自動觸發(fā)checkpoint checkpoint_timeout=5min 系統(tǒng)自動執(zhí)行checkpoint之間的最大時間間隔。系統(tǒng)默認值是5分鐘。 然后重啟報錯,將剛才的文件postgresql.conf中的checkpoint_segments這行注釋掉 |
暫時還沒研究透這個用戶的作用
su - postgresql psql -h 127.0.0.1 -d postgres -U postgres 登錄數(shù)據(jù)庫 create role replica login replication encrypted password replica; 創(chuàng)建用戶 |
cd /home/postgresql vi .pgpass #主數(shù)據(jù)庫IP:主數(shù)據(jù)庫端口號:replication:replica:replica 192.168.20.101:5432:replica:replica chmod 400 .pgpass #重啟數(shù)據(jù)庫 pg_ctl restart |
pg_ctl stop |
mv /pgadmin/pg_data/10.0/data /pgadmin/pg_data/10.0/data_bak |
pg_basebackup -D $PGDATA -F p -X stream -v -P -h 192.168.20.101 -U cyl |
報錯:
在主節(jié)點的pg_hba.conf中加入如下內(nèi)容
host replication cyl 0.0.0.0/0 md5
重新執(zhí)行pg_basebackup,成功:
[postgres@postgresql2 10.0]$ pg_basebackup -D $PGDATA -F p -X stream -v -P -h 192.168.20.101 -U cyl pg_basebackup: could not connect to server: FATAL: no pg_hba.conf entry for replication connection from host "192.168.20.102", user "cyl" pg_basebackup: removing contents of data directory "/pgadmin/pg_data/10.0/data" [postgres@postgresql2 10.0]$ pg_basebackup -D $PGDATA -F p -X stream -v -P -h 192.168.20.101 -U cyl Password: pg_basebackup: initiating base backup, waiting for checkpoint to complete WARNING: skipping special file "./.s.PGSQL.5432" pg_basebackup: checkpoint completed pg_basebackup: write-ahead log start point: 0/2000028 on timeline 1 pg_basebackup: starting background WAL receiver WARNING: skipping special file "./.s.PGSQL.5432"/10.0/data/backup_label) 31296/31296 kB (100%), 1/1 tablespace pg_basebackup: write-ahead log end point: 0/20000F8 pg_basebackup: waiting for background process to finish streaming ... pg_basebackup: base backup completed [postgres@postgresql2 10.0]$ |
#添加 cd $PGDATA vi postgresql.conf hot_standby = on |
vi recovery.conf standby_mode = on recovery_target_timeline = latest primary_conninfo = host=192.168.20.101 port=5432 user=cyl password=cyl 賦予權(quán)限 chmod 755 recovery.conf |
[postgres@postgresql2 data]$ pg_ctl start waiting for server to start....2020-09-04 03:11:25.151 GMT [11232] FATAL: data directory "/pgadmin/pg_data/10.0/data" has group or world access 2020-09-04 03:11:25.151 GMT [11232] DETAIL: Permissions should be u=rwx (0700). stopped waiting pg_ctl: could not start server Examine the log output. [postgres@postgresql2 data]$ |
啟動時出現(xiàn)報錯,data目錄權(quán)限錯誤,需要修改成700
修改data的權(quán)限為700 [postgres@postgresql2 10.0]$ ls -trl total 20 drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 scripts drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 backups drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 archive_wals drwx------. 20 postgres postgres 4096 Sep 4 10:37 data_bak drwxrwxr-x. 20 postgres postgres 4096 Sep 4 11:08 data [postgres@postgresql2 10.0]$ chmod 700 data [postgres@postgresql2 10.0]$ ls -trl total 20 drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 scripts drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 backups drwxrwxr-x. 2 postgres postgres 4096 Sep 4 10:12 archive_wals drwx------. 20 postgres postgres 4096 Sep 4 10:37 data_bak drwx------. 20 postgres postgres 4096 Sep 4 11:08 data [postgres@postgresql2 10.0]$ --修改權(quán)限后正常拉起數(shù)據(jù)庫 [postgres@postgresql2 data]$ pg_ctl start waiting for server to start....2020-09-04 03:12:29.191 GMT [11242] LOG: listening on IPv4 address "0.0.0.0", port 5432 2020-09-04 03:12:29.191 GMT [11242] LOG: listening on IPv6 address "::", port 5432 2020-09-04 03:12:29.195 GMT [11242] LOG: listening on Unix socket "/pgadmin/pg_data/10.0/data/.s.PGSQL.5432" 2020-09-04 03:12:29.221 GMT [11242] LOG: redirecting log output to logging collector process 2020-09-04 03:12:29.221 GMT [11242] HINT: Future log output will appear in directory "pg_log". done server started [postgres@postgresql2 data]$ ps -aux | grep postgres Warning: bad syntax, perhaps a bogus -? See /usr/share/doc/procps-3.2.8/FAQ root 10971 0.0 0.1 163748 2012 pts/0 S 10:22 0:00 su - postgres postgres 10972 0.0 0.1 108472 1972 pts/0 S 10:22 0:00 -bash root 11148 0.0 0.1 163748 2008 pts/1 S 10:59 0:00 su - postgres postgres 11149 0.0 0.0 108340 1824 pts/1 S+ 10:59 0:00 -bash postgres 11242 0.0 0.9 152440 18452 pts/0 S 11:12 0:00 /pgadmin/postgres10/bin/postgres postgres 11243 0.0 0.0 117072 884 ? Ss 11:12 0:00 postgres: logger process postgres 11244 0.0 0.0 152560 1692 ? Ss 11:12 0:00 postgres: startup process waiting for 000000010000000000000003 postgres 11245 0.0 0.0 152440 1108 ? Ss 11:12 0:00 postgres: checkpointer process postgres 11246 0.2 0.0 152440 1092 ? Ss 11:12 0:00 postgres: writer process postgres 11247 0.0 0.0 119168 836 ? Ss 11:12 0:00 postgres: stats collector process postgres 11279 10.0 0.0 110236 1148 pts/0 R+ 11:14 0:00 ps -aux postgres 11280 0.0 0.0 103252 836 pts/0 S+ 11:14 0:00 grep postgres [postgres@postgresql2 data]$ |
1、在主庫的服務(wù)器上輸入命令,會看到多出一個walsender process的進程:#ps -aux | greppostgres
2、在備庫的服務(wù)器上輸入命令,會看到多出一個wal receiver process的進程:#ps -aux | greppostgres
在主庫的服務(wù)器上輸入命令,會看到多出一個wal sender process的進程: #ps -aux | grep postgres [postgres@postgresql1 data]$ ps -aux | grep postgres Warning: bad syntax, perhaps a bogus -? See /usr/share/doc/procps-3.2.8/FAQ root 3614 0.0 0.0 163748 2004 pts/0 S 10:21 0:00 su - postgres postgres 3615 0.0 0.0 108440 1892 pts/0 S 10:21 0:00 -bash postgres 3870 0.0 0.4 152440 18468 pts/0 S 11:03 0:00 /pgadmin/postgres10/bin/postgres postgres 3871 0.0 0.0 117072 884 ? Ss 11:03 0:00 postgres: logger process postgres 3873 0.0 0.0 152708 3132 ? Ss 11:03 0:00 postgres: checkpointer process postgres 3874 0.3 0.0 152572 1588 ? Ss 11:03 1:07 postgres: writer process postgres 3875 0.0 0.0 152440 1496 ? Ss 11:03 0:02 postgres: wal writer process postgres 3876 0.0 0.0 153204 2028 ? Ss 11:03 0:00 postgres: autovacuum launcher process postgres 3877 0.0 0.0 119168 956 ? Ss 11:03 0:00 postgres: archiver process postgres 3878 0.0 0.0 119300 1100 ? Ss 11:03 0:00 postgres: stats collector process postgres 3879 0.0 0.0 153044 1680 ? Ss 11:03 0:00 postgres: bgworker: logical replication launcher root 4009 0.0 0.0 163748 2008 pts/1 S 11:23 0:00 su - postgres postgres 4010 0.0 0.0 108340 1892 pts/1 S 11:23 0:00 -bash postgres 4050 0.0 0.0 153724 2904 ? Ss 11:29 0:00 postgres: wal sender process cyl 192.168.20.102(34150) streaming 0/3104F00 postgres 5058 0.0 0.0 117304 1756 pts/0 S+ 15:46 0:00 psql postgres 5059 0.0 0.0 153732 2936 ? Ss 15:46 0:00 postgres: postgres postgres [local] idle postgres 5510 7.0 0.0 110240 1148 pts/1 R+ 17:11 0:00 ps -aux postgres 5511 0.0 0.0 103252 836 pts/1 S+ 17:11 0:00 grep postgres 在備庫的服務(wù)器上輸入命令,會看到多出一個 wal receiver process 的進程: #ps -aux | grep postgres [postgres@postgresql2 data]$ ps -aux | grep postgres Warning: bad syntax, perhaps a bogus -? See /usr/share/doc/procps-3.2.8/FAQ root 10971 0.0 0.1 163748 2012 pts/0 S 10:22 0:00 su - postgres postgres 10972 0.0 0.1 108472 1972 pts/0 S 10:22 0:00 -bash root 11148 0.0 0.1 163748 2008 pts/1 S 10:59 0:00 su - postgres postgres 11149 0.0 0.0 108340 1824 pts/1 S+ 10:59 0:00 -bash postgres 11242 0.0 0.9 152440 18452 pts/0 S 11:12 0:00 /pgadmin/postgres10/bin/postgres postgres 11243 0.0 0.0 117072 884 ? Ss 11:12 0:00 postgres: logger process postgres 11244 0.0 0.0 152560 1692 ? Ss 11:12 0:00 postgres: startup process waiting for 000000010000000000000003 postgres 11245 0.0 0.0 152440 1108 ? Ss 11:12 0:00 postgres: checkpointer process postgres 11246 0.2 0.0 152440 1092 ? Ss 11:12 0:00 postgres: writer process postgres 11247 0.0 0.0 119168 836 ? Ss 11:12 0:00 postgres: stats collector process postgres 11279 10.0 0.0 110236 1148 pts/0 R+ 11:14 0:00 ps -aux postgres 11280 0.0 0.0 103252 836 pts/0 S+ 11:14 0:00 grep postgres [postgres@postgresql2 data]$ --無wal receiver process 進程,經(jīng)核查recovery.conf用戶名寫錯,修改recovery.conf后,重啟數(shù)據(jù)庫 [postgres@postgresql2 data]$ cat recovery.conf standby_mode = on recovery_target_timeline = latest primary_conninfo = host=192.168.20.101 port=5432 user=cyl password=cyl [postgres@postgresql2 data] [postgres@postgresql2 data]$ pg_ctl restart waiting for server to shut down.... done server stopped waiting for server to start....2020-09-04 03:17:00.052 GMT [11319] LOG: listening on IPv4 address "0.0.0.0", port 5432 2020-09-04 03:17:00.052 GMT [11319] LOG: listening on IPv6 address "::", port 5432 2020-09-04 03:17:00.055 GMT [11319] LOG: listening on Unix socket "/pgadmin/pg_data/10.0/data/.s.PGSQL.5432" 2020-09-04 03:17:00.070 GMT [11319] LOG: redirecting log output to logging collector process 2020-09-04 03:17:00.070 GMT [11319] HINT: Future log output will appear in directory "pg_log". done server started [postgres@postgresql2 data]$ [postgres@postgresql2 data]$ [postgres@postgresql2 data]$ ps -aux | grep postgres Warning: bad syntax, perhaps a bogus -? See /usr/share/doc/procps-3.2.8/FAQ root 10971 0.0 0.1 163748 2012 pts/0 S 10:22 0:00 su - postgres postgres 10972 0.0 0.1 108472 1972 pts/0 S 10:22 0:00 -bash root 11148 0.0 0.1 163748 2008 pts/1 S 10:59 0:00 su - postgres postgres 11149 0.0 0.0 108340 1824 pts/1 S+ 10:59 0:00 -bash postgres 11319 0.0 0.9 152440 18456 pts/0 S 11:16 0:00 /pgadmin/postgres10/bin/postgres postgres 11320 0.0 0.0 117072 888 ? Ss 11:16 0:00 postgres: logger process postgres 11321 0.0 0.0 152560 1648 ? Ss 11:16 0:00 postgres: startup process recovering 000000010000000000000003 postgres 11322 0.0 0.0 152440 1116 ? Ss 11:16 0:00 postgres: checkpointer process postgres 11323 0.2 0.0 152440 1100 ? Ss 11:16 0:00 postgres: writer process postgres 11324 0.0 0.0 119168 844 ? Ss 11:16 0:00 postgres: stats collector process postgres 11325 0.1 0.1 156820 1948 ? Ss 11:16 0:00 postgres: wal receiver process streaming 0/3000140 postgres 11326 0.0 0.0 110236 1148 pts/0 R+ 11:17 0:00 ps -aux postgres 11327 0.0 0.0 103252 836 pts/0 S+ 11:17 0:00 grep postgres [postgres@postgresql2 data]$ |
備庫核查:
核查發(fā)現(xiàn)備庫已經(jīng)crash,重啟報錯,根據(jù)報錯日志查看是因為備庫主機上沒有/pgadmin/pg_data/10.0/data/tbs_pgtest目錄導致,備庫手動創(chuàng)建目錄,重新拉起數(shù)據(jù)庫
拉起數(shù)據(jù)庫后可以看到,mytestdb1已經(jīng)同步到備庫
[postgres@postgresql2 pg_log]$ more postgresql-2020-09-04_032720.csv 2020-09-04 03:27:20.478 GMT,,,11358,,5f51b418.2c5e,1,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"ending log output to stderr",,"Future log output will go to log destination ""csvlog"".",,,,,,,"" 2020-09-04 03:27:20.554 GMT,,,11360,,5f51b418.2c60,1,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"database system was interrupted while in recovery at log time 2020-09-04 03:08:46 GMT",,"If this has occurred more t han once some data might be corrupted and you might need to choose an earlier recovery target.",,,,,,,"" 2020-09-04 03:27:20.579 GMT,,,11360,,5f51b418.2c60,2,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"entering standby mode",,,,,,,,,"" 2020-09-04 03:27:20.581 GMT,,,11360,,5f51b418.2c60,3,,2020-09-04 03:27:20 GMT,1/0,0,LOG,00000,"redo starts at 0/3000060",,,,,,,,,"" 2020-09-04 03:27:20.581 GMT,,,11360,,5f51b418.2c60,4,,2020-09-04 03:27:20 GMT,1/0,0,LOG,00000,"consistent recovery state reached at 0/3000108",,,,,,,,,"" 2020-09-04 03:27:20.581 GMT,,,11360,,5f51b418.2c60,5,,2020-09-04 03:27:20 GMT,1/0,0,FATAL,58P01,"directory ""/pgadmin/pg_data/10.0/data/tbs_pgtest"" does not exist",,"Create this directory for the tablespace before restarting the server.",,,"WAL redo at 0/30012D8 for Tablespace/CREATE: 32784 ""/pgadmin/pg_data/10.0/data/tbs_pgtest""",,,,"" 2020-09-04 03:27:20.585 GMT,,,11358,,5f51b418.2c5e,2,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"database system is ready to accept read only connections",,,,,,,,,"" 2020-09-04 03:27:20.587 GMT,,,11358,,5f51b418.2c5e,3,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"startup process (PID 11360) exited with exit code 1",,,,,,,,,"" 2020-09-04 03:27:20.587 GMT,,,11358,,5f51b418.2c5e,4,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"terminating any other active server processes",,,,,,,,,"" 2020-09-04 03:27:20.589 GMT,,,11358,,5f51b418.2c5e,5,,2020-09-04 03:27:20 GMT,,0,LOG,00000,"database system is shut down",,,,,,,,,"" [postgres@postgresql2 pg_log]$ mkdir -p /pgadmin/pg_data/10.0/data/tbs_pgtest [postgres@postgresql2 pg_log]$ |
主庫操作:
create table test_1(id int4,name text,create_time timestamp without time zone default clock_timestamp()); alter table test_1 add primary key (id); insert into test_1(id,name) select n,n ||_francs from generate_series(1,5000) n; select * from test_1 limit 10; |
備庫查看:
可以看到備庫無法進行寫操作
PostgreSQL在9.0之后引入了主備流復制機制,通過流復制,備庫不斷的從主庫同步相應(yīng)的數(shù)據(jù),并在備庫apply每個WALrecord,這里的流復制每次傳輸單位是WAL日志的record。而PostgreSQL9.0之前提供的方法是主庫寫完一個WAL日志文件后,才把WAL日志文件傳送到備庫,這樣的方式導致主備延遲特別大。同時PostgreSQL9.0之后提供了HotStandby,備庫在應(yīng)用WALrecord的同時也能夠提供只讀服務(wù)。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/130122.html
postgresql10主備流復制測試 img{ display:block; margin:0 auto !important; width:100%; } body{ width:75%; ...
摘要:作者譚峰張文升出版日期年月頁數(shù)頁定價元本書特色中國開源軟件推進聯(lián)盟分會特聘專家撰寫,國內(nèi)多位開源數(shù)據(jù)庫專家鼎力推薦。張文升中國開源軟件推進聯(lián)盟分會核心成員之一。 很高興《PostgreSQL實戰(zhàn)》一書終于出版,本書大體上系統(tǒng)總結(jié)了筆者 PostgreSQL DBA 職業(yè)生涯的經(jīng)驗總結(jié),本書的另一位作者張文升擁有豐富的PostgreSQL運維經(jīng)驗,目前就職于探探科技任首席PostgreS...
摘要:上操作備注執(zhí)行拋出以上錯誤,錯誤內(nèi)容很明顯。再次上操作備注成功。啟動原主庫,上操作數(shù)據(jù)驗證上操作備注成功,原主庫現(xiàn)在是以備庫角色啟動,而且數(shù)據(jù)表也同步過來了。三原理四參考的主備切換使用搭建流復制環(huán)境 了解 PG 的朋友應(yīng)該知道 PG 的主備切換并不容易,步驟較嚴謹,在激活備節(jié)點前需主動關(guān)閉主節(jié)點,否則再想以備節(jié)點角色拉起主節(jié)點會比較困難,之前博客介紹過主備切換,PostgreSQL H...
閱讀 1356·2023-01-11 13:20
閱讀 1707·2023-01-11 13:20
閱讀 1215·2023-01-11 13:20
閱讀 1906·2023-01-11 13:20
閱讀 4165·2023-01-11 13:20
閱讀 2757·2023-01-11 13:20
閱讀 1402·2023-01-11 13:20
閱讀 3671·2023-01-11 13:20