亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解PostgreSQL 實(shí)現(xiàn)定時(shí)任務(wù)的 4 種方法

 更新時(shí)間:2021年02月06日 08:56:46   作者:不剪發(fā)的Tony老師  
這篇文章主要介紹了PostgreSQL 實(shí)現(xiàn)定時(shí)任務(wù)的 4 種方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

定時(shí) 任務(wù)

數(shù)據(jù)庫(kù)定時(shí)任務(wù)可以用于實(shí)現(xiàn)定期的備份、統(tǒng)計(jì)信息采集、數(shù)據(jù)匯總、數(shù)據(jù)清理與優(yōu)化等。PostgreSQL 沒(méi)有提供類似 Oracle、MySQL 以及 Microsoft SQL Sever 的內(nèi)置任務(wù)調(diào)度功能,因此本文給大家介紹一下 PostgreSQL 數(shù)據(jù)庫(kù)中實(shí)現(xiàn)定時(shí)任務(wù)的 4 種方法。

操作系統(tǒng)定時(shí)任務(wù)

Linux 定時(shí)任務(wù)(crontab)或者 Windows 任務(wù)計(jì)劃程序(Task Scheduler)為我們提供了一個(gè)實(shí)現(xiàn)定時(shí)任務(wù)傳統(tǒng)的方法。以 crontab 為例,我們可以使用以下命令編輯任務(wù)列表:

crontab -e

然后在打開的文件中使用以下格式增加一行數(shù)據(jù):

#分鐘 小時(shí) 月份中的某一天 月份 星期  命令
#(0-59) (0-23) (1-31)  (1-12) (0-7 [7 or 0 == Sunday])
<minute> <hour> <day of month> <month> <day of week> <command>

其中的前五個(gè)字段表示執(zhí)行命令的時(shí)間,可以使用星號(hào)(*)匹配所有的時(shí)間。例如,將 <month> 設(shè)置為星號(hào)表示每個(gè)月都執(zhí)行命令。

舉例來(lái)說(shuō),輸入以下內(nèi)容表示每天零點(diǎn)執(zhí)行數(shù)據(jù)庫(kù)邏輯備份操作。

0 0 * * * pg_dump --no-password -U user db_name > backup.sql

為了安全起見不要直接輸入密碼,而是應(yīng)該將密碼加入 .pgpass 文件,并且將該文件的權(quán)限設(shè)置為僅當(dāng)前用戶可見:

chmod 600 .pgpass

pgAgent

pgAgent 是一個(gè)用于 PostgreSQL 數(shù)據(jù)庫(kù)的任務(wù)調(diào)度代理,能夠基于復(fù)雜的調(diào)度計(jì)劃運(yùn)行多步驟的批處理、shell 腳本以及 SQL 命令。對(duì)于 Unix/Linux 系統(tǒng),pgAgent 以后臺(tái)進(jìn)程的方式運(yùn)行;對(duì)于 Windows 系統(tǒng),pgAgent 以服務(wù)的形式運(yùn)行。

安裝 pgAgent

PgAdmin 4 管理工具集成了 pgAgent 的功能,但是這兩者需要單獨(dú)安裝。我們可以通過(guò)官方網(wǎng)站下載 PgAdmin 4 以及 pgAgent。具體的安裝步驟和注意事項(xiàng)可以參考官網(wǎng)文檔。安裝完成之后,我們可以在 PgAdmin 4 左側(cè)導(dǎo)航樹中看到“pgAgent Jobs”節(jié)點(diǎn)。

pgagent

創(chuàng)建定時(shí)任務(wù)

右鍵點(diǎn)擊“pgAgent Jobs”節(jié)點(diǎn),選擇“Create” > “pgAgent Job”創(chuàng)建一個(gè)新的定時(shí)任務(wù)。

job

其中,“General”頁(yè)面可以輸入一些基本信息,包括任務(wù)的名稱?!癝teps”頁(yè)面可以設(shè)置多個(gè)操作步驟,包括執(zhí)行的腳本或者 SQL 語(yǔ)句等?!癝chedules”頁(yè)面用于定義任務(wù)執(zhí)行的時(shí)間計(jì)劃?!癝QL”頁(yè)面可以顯示創(chuàng)建或者修改任務(wù)的語(yǔ)句。

sql

點(diǎn)擊“Save”按鈕保存設(shè)置并創(chuàng)建任務(wù),然后我們就可以在“pgAgent Job”節(jié)點(diǎn)下看到創(chuàng)建的任務(wù)。

pg_cron

pg_cron 是由 citusdata 公司開發(fā)的一個(gè) PostgreSQL 定時(shí)任務(wù)插件(類似于 Oracle 中的 DBMS_SCHEDULER)。pg_cron 作為一個(gè)后臺(tái)工作進(jìn)程運(yùn)行,使用類似 cron 的編輯語(yǔ)法,允許直接在數(shù)據(jù)庫(kù)中執(zhí)行定時(shí)任務(wù)。例如:

-- 每周六 3:30am (GMT) 刪除歷史記錄
SELECT cron.schedule('30 3 * * 6', $$DELETE FROM events WHERE event_time < now() - interval '1 week'$$);
 schedule
----------
 42

-- 每天 10:00am (GMT) 執(zhí)行清理作業(yè)
SELECT cron.schedule('nightly-vacuum', '0 10 * * *', 'VACUUM');
 schedule
----------
 43

-- 將清理作業(yè)修改為 3:00am (GMT)
SELECT cron.schedule('nightly-vacuum', '0 3 * * *', 'VACUUM');
 schedule
----------
 43

-- 停止計(jì)劃中的任務(wù)
SELECT cron.unschedule('nightly-vacuum' );
 unschedule 
------------
 t
(1 row)

SELECT cron.unschedule(42);
 unschedule
------------
  t

安裝 pg_cron

pg_cron 目前只支持 Linux 操作系統(tǒng)。對(duì)于 Red Hat、CentOS 以及 Fedora 等操作系統(tǒng)可以使用以下命令進(jìn)行安裝(PostgreSQL 12):

sudo yum install -y pg_cron_12

對(duì)于 Debian 以及 Ubuntu 可以使用以下命令進(jìn)行安裝(PostgreSQL 12):

sudo apt-get -y install postgresql-12-cron

另外,我們也可以使用源碼進(jìn)行編譯安裝:

git clone https://github.com/citusdata/pg_cron.git
cd pg_cron
# Ensure pg_config is in your path, e.g.
export PATH=/usr/pgsql-12/bin:$PATH
make && sudo PATH=$PATH make install

配置 pg_cron

為了在啟動(dòng) PostgreSQL 時(shí)運(yùn)行 pg_cron 后臺(tái)工作進(jìn)程,我們需要將 pg_cron 添加到 postgresql.conf 文件中的 shared_preload_libraries配置項(xiàng)。 默認(rèn)情況下,pg_cron 后臺(tái)進(jìn)程使用 postgres 數(shù)據(jù)庫(kù)獲取所需的元數(shù)據(jù)。但是我們也可以使用 cron.database_name 配置參數(shù)進(jìn)行設(shè)置。

shared_preload_libraries = 'pg_cron'
cron.database_name = 'postgres'

重啟 PostgreSQL:

sudo service postgresql-12 restart

然后我們可以使用以下命令創(chuàng)建 pg_cron 函數(shù)以及元數(shù)據(jù)相關(guān)的表:

-- 使用 superuser 運(yùn)行以下命令
CREATE EXTENSION pg_cron;

-- 可選操作,為其他用戶授予訪問(wèn)權(quán)限
GRANT USAGE ON SCHEMA cron TO username;

pg_timetable

pg_timetable 是由 CYBERTEC 公司開發(fā)的 PostgreSQL 作業(yè)調(diào)度程序,提供了靈活的配置方式和許多高級(jí)功能。包括由多個(gè)任務(wù)組成的任務(wù)鏈、支持 SQL 命令和可執(zhí)行程序、內(nèi)置任務(wù)(例如發(fā)送郵件)、完全基于數(shù)據(jù)庫(kù)的配置和日志功能、cron 風(fēng)格的計(jì)劃調(diào)度、并發(fā)執(zhí)行的保護(hù)等。

pg_timetable

安裝 pg_timetable

首先,我們可以使用官方發(fā)布的二進(jìn)制安裝程序安裝 pg_timetable,目前支持 Windows、Linux 以及 macOS 操作系統(tǒng)。

另外,官方的 docker 鏡像可以點(diǎn)此下載。

master 分支的 latest 標(biāo)簽是最新版本,使用命令行的運(yùn)行方式如下:

docker run --rm \
 cybertecpostgresql/pg_timetable:latest \
 -h 10.0.0.3 -p 54321 -c worker001

指定環(huán)境變量的方式如下:

docker run --rm \
 -e PGTT_PGHOST=10.0.0.3 \
 -e PGTT_PGPORT=54321 \
 cybertecpostgresql/pg_timetable:latest \
 -c worker001

除此之外,我們也可以使用源碼進(jìn)行編譯安裝。首先下載并安裝 Go 語(yǔ)言環(huán)境,然后使用 go get 命令拷貝 pg_timetable 源碼:

$ env GIT_TERMINAL_PROMPT=1 go get github.com/cybertec-postgresql/pg_timetable/
Username for 'https://github.com': <Github Username>
Password for 'https://cyberboy@github.com': <Github Password>

運(yùn)行 pg_timetable:

$ cd ~/go/src/github.com/cybertec-postgresql/pg_timetable/
$ go run main.go --dbname=dbname --clientname=worker001 --user=scheduler --password=strongpwd

或者,也可以編譯成二進(jìn)制程序并運(yùn)行:

$ go build
$ ./pg_timetable --dbname=dbname --clientname=worker001 --user=scheduler --password=strongpwd

如果想要運(yùn)行項(xiàng)目中的所有測(cè)試,可以執(zhí)行以下命令:

$ cd ~/go/src/github.com/cybertec-postgresql/pg_timetable/
$ go get github.com/stretchr/testify/
$ go test ./...

也可以使用 postgres docker 鏡像運(yùn)行測(cè)試:

$ RUN_DOCKER=true go test ./...

使用 pg_timetable

pg_timetable 獨(dú)立于 PostgreSQL 服務(wù)器運(yùn)行,相當(dāng)于一個(gè)客戶端進(jìn)程。安裝完成之后,執(zhí)行以下命令運(yùn)行 pg_timetable 程序:

# ./pg_timetable

Application Options:
 -c, --clientname=  Unique name for application instance
 -v, --verbose   Show verbose debug information [$PGTT_VERBOSE]
 -h, --host=   PG config DB host (default: localhost) [$PGTT_PGHOST]
 -p, --port=   PG config DB port (default: 5432) [$PGTT_PGPORT]
 -d, --dbname=   PG config DB dbname (default: timetable) [$PGTT_PGDATABASE]
 -u, --user=   PG config DB user (default: scheduler) [$PGTT_PGUSER]
 -f, --file=   SQL script file to execute during startup
 --password=   PG config DB password (default: somestrong) [$PGTT_PGPASSWORD]
 --sslmode=[disable|require] What SSL priority use for connection (default: disable)
 --pgurl=   PG config DB url [$PGTT_URL]
 --init   Initialize database schema and exit. Can be used with --upgrade
 --upgrade   Upgrade database to the latest version
 --no-program-tasks  Disable executing of PROGRAM tasks [$PGTT_NOPROGRAMTASKS]

源代碼的 sample 目錄中提供了大量的示例可以參考。以下命令可以創(chuàng)建一個(gè) 8 月份 00:05 運(yùn)行“MyJob”的定時(shí)任務(wù):

SELECT timetable.job_add('MyJob', 'SELECT public.my_func()' , NULL, 'SQL', '5 0 * 8 *', live := TRUE);

以下命令表示從 0 點(diǎn)到 20 點(diǎn),每?jī)蓚€(gè)小時(shí)的 23 分時(shí)運(yùn)行“MyJob”任務(wù):

SELECT timetable.job_add('MyJob', 'SELECT public.my_func()' , NULL, 'SQL', '23 0-20/2 * * *', live := TRUE);

pg_timetable 計(jì)劃任務(wù)的完整配置由 3 個(gè)階段組成:

  • 第一個(gè)階段用于配置 base_task,定義需要執(zhí)行的操作。包括 SQL 語(yǔ)句、外部程序以及內(nèi)置的操作。
  • 第二個(gè)階段用于配置 task_chain,定義一組順序執(zhí)行的基本任務(wù)。
  • 第三階段用于配置 chain_execution_config,定義任務(wù)鏈的執(zhí)行計(jì)劃。

chain

此外,為了給基本任務(wù)傳遞控制參數(shù),任務(wù)鏈中的任務(wù)都可以附帶一個(gè)執(zhí)行參數(shù)。詳細(xì)的配置方法和案例可以參考官方網(wǎng)站。

總結(jié)

本文介紹了在 PostgreSQL 數(shù)據(jù)庫(kù)中實(shí)現(xiàn)定時(shí)任務(wù)的 4 種方法,包括操作系統(tǒng)定時(shí)任務(wù)、pgAgent 代理、pg_cron 插件以及 pg_timetable 工具。

到此這篇關(guān)于PostgreSQL 實(shí)現(xiàn)定時(shí)任務(wù)的 4 種方法的文章就介紹到這了,更多相關(guān)PostgreSQL 定時(shí)任務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 修改postgresql存儲(chǔ)目錄的操作方式

    修改postgresql存儲(chǔ)目錄的操作方式

    這篇文章主要介紹了修改postgresql存儲(chǔ)目錄的操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL處理數(shù)據(jù)并發(fā)更新沖突的解決方法

    PostgreSQL處理數(shù)據(jù)并發(fā)更新沖突的解決方法

    在數(shù)據(jù)庫(kù)并發(fā)操作環(huán)境中,多個(gè)事務(wù)同時(shí)嘗試更新相同的數(shù)據(jù)可能導(dǎo)致沖突,PostgreSQL?提供了一系列機(jī)制來(lái)處理這些并發(fā)更新沖突,以確保數(shù)據(jù)的一致性和完整性,所以本文給大家介紹了PostgreSQL處理數(shù)據(jù)并發(fā)更新沖突的解決方法,需要的朋友可以參考下
    2024-07-07
  • CentOS中運(yùn)行PostgreSQL需要修改的內(nèi)核參數(shù)及配置腳本分享

    CentOS中運(yùn)行PostgreSQL需要修改的內(nèi)核參數(shù)及配置腳本分享

    這篇文章主要介紹了CentOS中運(yùn)行PostgreSQL需要修改的內(nèi)核參數(shù)及配置腳本分享,本文從系統(tǒng)資源限制類和內(nèi)存參數(shù)優(yōu)化類來(lái)進(jìn)行說(shuō)明,需要的朋友可以參考下
    2014-07-07
  • PostgreSQL教程(十四):數(shù)據(jù)庫(kù)維護(hù)

    PostgreSQL教程(十四):數(shù)據(jù)庫(kù)維護(hù)

    這篇文章主要介紹了PostgreSQL教程(十四):數(shù)據(jù)庫(kù)維護(hù),本文講解了恢復(fù)磁盤空間、更新規(guī)劃器統(tǒng)計(jì)、VACUUM和ANALYZE的示例、定期重建索引等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 基于PostgreSql 別名區(qū)分大小寫的問(wèn)題

    基于PostgreSql 別名區(qū)分大小寫的問(wèn)題

    這篇文章主要介紹了基于PostgreSql 別名區(qū)分大小寫的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL模糊匹配走索引的操作

    PostgreSQL模糊匹配走索引的操作

    這篇文章主要介紹了PostgreSQL模糊匹配走索引的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL的日期時(shí)間差DATEDIFF實(shí)例詳解

    PostgreSQL的日期時(shí)間差DATEDIFF實(shí)例詳解

    PostgreSQL是一款簡(jiǎn)介而又性能強(qiáng)大的數(shù)據(jù)庫(kù)應(yīng)用程序,其在日期時(shí)間數(shù)據(jù)方面所支持的功能也都非常給力,下面這篇文章主要給大家介紹了關(guān)于PostgreSQL的日期時(shí)間差DATEDIFF的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例

    postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例

    這篇文章主要介紹了postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL新手入門教程

    PostgreSQL新手入門教程

    本文介紹PostgreSQL的安裝和基本用法,供初次使用者上手。以下內(nèi)容基于Debian操作系統(tǒng),其他操作系統(tǒng)實(shí)在沒(méi)有精力兼顧,但是大部分內(nèi)容應(yīng)該普遍適用
    2014-06-06
  • PostgreSQL運(yùn)維案例之遞歸查詢死循環(huán)解決方案

    PostgreSQL運(yùn)維案例之遞歸查詢死循環(huán)解決方案

    PostgreSQL提供的遞歸語(yǔ)法是很棒的,例如可用來(lái)解決樹形查詢的問(wèn)題,解決Oracle用戶connect by的語(yǔ)法兼容性,下面這篇文章主要給大家介紹了關(guān)于PostgreSQL運(yùn)維案例之遞歸查詢死循環(huán)解決方案的相關(guān)資料,需要的朋友可以參考下
    2024-02-02

最新評(píng)論