婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PostgreSQL用戶登錄失敗自動鎖定的處理方案

PostgreSQL用戶登錄失敗自動鎖定的處理方案

熱門標簽:電話機器人錄音師薪資 高德地圖標注電話怎么沒了 無錫梁溪公司怎樣申請400電話 智能電銷機器人教育 奧維地圖標注字體大小修改 中國地圖標注省份用什么符號 江西穩定外呼系統供應商 孝感銷售電銷機器人廠家 北京智能外呼系統供應商家

墨墨導讀:PostgreSQL使用session_exec插件實現用戶密碼驗證失敗幾次后自動鎖定,本文介紹一種處理方案。

一、插件session_exec安裝配置篇

下載插件并編譯安裝。
https://github.com/okbob/session_exec

$ unzip session_exec-master.zip 
$ cd session_exec-master/
$ make pg_config=/opt/pgsql/bin/pg_config
$ make pg_config=/opt/pgsql/bin/pg_config install

配置postgresql.conf。

session_preload_libraries='session_exec'
session_exec.login_name='login'

注意:上面第一個變量是設置session_preload_libraries而不是通常設置的shared_preload_libraries。
第二個變量是需要自定義實現的登錄函數。

重啟數據庫服務。

$ sudo systemctl restart postgresql-12

二、自定義登錄函數篇

創建t_login表用于存儲提取自數據庫日志中登錄失敗的信息。

create table t_login
(
login_time timestamp(3) with time zone --插入時間,
user_name text --數據庫登錄用戶,
flag int4 --標志位,0代表過期數據,1代表正常狀態數據
);

使用file_fdw外部表記錄數據庫日志信息。
file_fdw如果未配置過,參見下面步驟。

$ cd /opt/postgresql-12.5/contrib/file_fdw
$ make  make install

create extension file_fdw;
CREATE SERVER pglog FOREIGN DATA WRAPPER file_fdw;

建立外部表postgres_log,關聯數據庫日志中登錄失敗的信息。

CREATE FOREIGN TABLE postgres_log( 
 log_time timestamp(3) with time zone, 
 user_name text, 
 database_name text, 
 process_id integer,
 connection_from text,
 session_id text, 
 session_line_num bigint, 
 command_tag text, 
 session_start_time timestamp with time zone, 
 virtual_transaction_id text, 
 transaction_id bigint, 
 error_severity text, 
 sql_state_code text, 
 message text, 
 detail text, 
 hint text, 
 internal_query text, 
 internal_query_pos integer, 
 context text, 
 query text, 
 query_pos integer, 
 location text, 
 application_name text
) SERVER pglog 
OPTIONS ( program 'find /opt/pg_log_5432 -type f -name "*.csv" -mtime -1 -exec cat {} \;', format 'csv' );

注意:
1./opt/pg_log_5432需要修改為實際環境日志目錄。
2. 不同PG版本csv日志格式可能有所差異,參考PG官網文檔runtime-config-logging章節(http://postgres.cn/docs/12/runtime-config-logging.html)。

此時連接數據庫因未創建登錄函數會出現下面的警告信息。

$ psql -Upostgres
WARNING: function "login()" does not exist
psql (12.5)
Type "help" for help.

創建登錄函數login。

create or replace function login() returns void as $$
declare
res text;
c1 timestamp(3) with time zone;
begin

--獲取當前日志中最新時間
select login_time 
from public.t_login 
where flag = 0 
order by login_time 
desc limit 1 
into c1; 

 --將最新的數據插入t_login表
insert into public.t_login 
select log_time,user_name 
from public.postgres_log 
where command_tag='authentication' 
and error_severity= 'FATAL' 
and log_time > c1;

update public.t_login set flag = 1 where login_time > c1; 

--檢查登錄失敗次數是否大于3,若大于3則鎖定用戶
for res in select user_name from public.t_login where flag = 1 group by user_name having count(*) >=3 
loop
--鎖定用戶
EXECUTE format('alter user %I nologin',res); 
--斷開當前被鎖定用戶會話
EXECUTE 'select pg_catalog.pg_terminate_backend(pid) from pg_catalog.pg_stat_activity where usename=$1' using res; 
raise notice 'Account % is locked!',res;
end loop;
end;
$$ language plpgsql strict security definer set search_path to 'public';

測試使用篇

創建測試用戶。

create user test1 encrypted password 'XXX';

模擬test1用戶登錄失敗,輸入錯誤密碼。

$ psql -h192.168.137.11 -Utest1 postgres
Password for user test1: 
psql: error: FATAL: password authentication failed for user "test1"

通過外部表查看登錄失敗的日志。

select * from postgres_log where command_tag='authentication' and error_severity= 'FATAL';

可以看到1條數據,手工插入一條登錄失敗的信息到t_login表。

insert into t_login select log_time,user_name,0
 from postgres_log 
 where command_tag='authentication' 
 and error_severity= 'FATAL';

參考上面登錄失敗測試,接著再測試2次。

然后使用postgres用戶登錄數據庫,觀察t_login表數據。

postgres=# select * from t_login;
  login_time  | user_name | flag 
-------------------------+-----------+------
 2021-02-08 06:24:47.101 | test1  | 0
 2021-02-08 06:25:16.581 | test1  | 1
 2021-02-08 06:25:18.429 | test1  | 1
(3 rows)

再測試兩次失敗登錄,然后使用postgres用戶登錄數據庫,看到提示該用戶被鎖定。

[postgres@node11 ~]$ psql
NOTICE: Account test1 is locked!
psql (12.5)
Type "help" for help.

postgres=# select * from t_login;
  login_time  | user_name | flag 
-------------------------+-----------+------
 2021-02-08 06:45:38.017 | test1  | 0
 2021-02-08 06:45:58.809 | test1  | 1
 2021-02-08 06:45:58.809 | test1  | 1
 2021-02-08 06:46:08.116 | test1  | 1
 2021-02-08 06:46:11.986 | test1  | 1
(5 rows)

解鎖用戶。

update t_login set flag = 0 where user_name='test1' and flag=1;

總結

  • session_exec通過用戶登錄成功后調用login函數去實現鎖定登錄失敗次數過多的用戶。
  • 此種方式有點繁瑣且會造成數據庫連接變慢。
  • 不支持自動解鎖,需要管理用戶手工處理。

參考鏈接:

https://www.jb51.net/article/208018.htm

到此這篇關于PostgreSQL用戶登錄失敗自動鎖定的解決辦法的文章就介紹到這了,更多相關PostgreSQL登錄失敗自動鎖定內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PostGreSql 判斷字符串中是否有中文的案例
  • PostgreSQL的中文拼音排序案例
  • 自定義函數實現單詞排序并運用于PostgreSQL(實現代碼)
  • PostgreSQL將數據加載到buffer cache中操作方法
  • 在PostgreSQL中使用ltree處理層次結構數據的方法
  • postgresql 中的時間處理小技巧(推薦)
  • Postgresql限制用戶登錄錯誤次數的實例代碼
  • postgresql影子用戶實踐場景分析
  • 如何使用PostgreSQL進行中文全文檢索

標簽:泰州 臨滄 阜陽 通化 荊州 那曲 齊齊哈爾 海北

巨人網絡通訊聲明:本文標題《PostgreSQL用戶登錄失敗自動鎖定的處理方案》,本文關鍵詞  PostgreSQL,用戶,登錄,失敗,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL用戶登錄失敗自動鎖定的處理方案》相關的同類信息!
  • 本頁收集關于PostgreSQL用戶登錄失敗自動鎖定的處理方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品一区二区三区免费视频| 国产在线精品一区二区不卡了| 久久精品99久久久| 精品视频免费看| 成人国产视频在线观看| 欧美精品一区二区三区高清aⅴ| 色狠狠av一区二区三区| 中文字幕制服丝袜成人av| 免费在线一区观看| 樱花草国产18久久久久| 欧洲av在线精品| 亚洲国产另类av| 中文字幕一区二区三区色视频| 欧美日本韩国一区| 奇米色一区二区三区四区| 日韩一级免费观看| 欧美中文字幕一二三区视频| 亚洲成av人在线观看| 69堂国产成人免费视频| 欧美日韩中字一区| 理论片日本一区| 亚洲欧洲无码一区二区三区| 亚洲午夜电影网| 亚洲制服丝袜av| 日韩女优制服丝袜电影| 高清久久久久久| 成人免费福利片| 亚洲综合色视频| 日韩免费一区二区| 日韩免费看的电影| 99久久精品国产导航| 日韩免费福利电影在线观看| 国产成人精品免费一区二区| 亚洲精品视频在线观看免费| 国产福利一区二区| 亚洲免费观看高清| 一本久久a久久精品亚洲| 婷婷一区二区三区| 亚洲精品综合在线| 欧美精品一区二区久久久| 99re热视频这里只精品| 久久成人18免费观看| 久久精品人人做| 在线观看亚洲精品视频| 亚洲欧美电影一区二区| 精品福利一二区| 91成人在线观看喷潮| 成人一级片在线观看| 久久99九九99精品| 亚洲成人三级小说| 亚洲人成在线播放网站岛国| 欧美三级日韩在线| 成人av动漫网站| 国产精品一二三区在线| 日本午夜精品一区二区三区电影 | 日韩亚洲欧美一区| 国产成人无遮挡在线视频| 亚洲视频在线一区二区| 欧美v亚洲v综合ⅴ国产v| 欧美日韩一区二区三区四区五区 | 99免费精品视频| 久久成人久久爱| 亚洲电影一区二区| 亚洲品质自拍视频| 中文字幕av一区二区三区免费看| 国产成人午夜精品5599| 韩国在线一区二区| 日韩精品成人一区二区在线| 亚洲影院理伦片| 一区二区三区日本| 自拍偷自拍亚洲精品播放| 久久久久久久久一| 色一情一乱一乱一91av| 99久久久精品| proumb性欧美在线观看| www.性欧美| 一本色道**综合亚洲精品蜜桃冫| 国产盗摄女厕一区二区三区| 免费高清在线视频一区·| 日韩欧美卡一卡二| 一区二区免费在线播放| 91久久国产最好的精华液| 国产成人免费高清| 国产女人aaa级久久久级| 日韩黄色免费电影| 国产69精品久久久久毛片| 国产精品久久久久aaaa樱花| 亚洲国产成人91porn| 亚洲五月六月丁香激情| 日韩午夜av一区| 日韩精品一区二区三区视频 | 777精品伊人久久久久大香线蕉| 欧美视频精品在线观看| 欧美亚洲免费在线一区| 91精品国产综合久久久久久久| 精品一区二区三区免费毛片爱| 国产成人鲁色资源国产91色综 | 免费在线看成人av| 日韩av一二三| 国产宾馆实践打屁股91| 粉嫩av一区二区三区粉嫩| 国产精品麻豆99久久久久久| 国内精品免费**视频| 成人手机电影网| 日韩国产欧美三级| 加勒比av一区二区| 高清国产午夜精品久久久久久| 在线观看日韩电影| 日韩女优毛片在线| av一二三不卡影片| 欧美最新大片在线看| 91精品免费在线| 亚洲综合在线视频| 亚洲伦理在线精品| 日韩午夜精品视频| 日韩免费高清电影| 亚洲欧美电影一区二区| 亚洲欧美综合色| 亚洲女同ⅹxx女同tv| 日韩欧美国产1| 91精品国产91热久久久做人人| 欧美变态tickling挠脚心| 7777精品伊人久久久大香线蕉经典版下载| 欧美精品高清视频| 紧缚奴在线一区二区三区| 日韩国产在线观看一区| 成人h精品动漫一区二区三区| 日韩亚洲欧美中文三级| 亚洲素人一区二区| 国产真实乱对白精彩久久| 捆绑变态av一区二区三区| 国产三级久久久| 中文字幕在线免费不卡| 一区二区三区四区高清精品免费观看 | 欧美精品一卡二卡| 91久久精品国产91性色tv| 7777精品久久久大香线蕉| 日本高清不卡在线观看| 国产午夜亚洲精品午夜鲁丝片| 亚洲国产va精品久久久不卡综合| 99国产精品国产精品毛片| 欧美a一区二区| 91福利国产精品| 18欧美亚洲精品| 国产美女精品一区二区三区| 色婷婷综合五月| 亚洲男人的天堂在线aⅴ视频| 国产精品1024久久| 久久久午夜精品理论片中文字幕| 精品欧美乱码久久久久久1区2区| 欧美日韩不卡在线| 亚洲国产成人porn| 日韩av网站在线观看| 欧美精品在线一区二区| 日本免费新一区视频 | 日韩高清在线不卡| 99精品视频一区二区| 亚洲色图视频网站| 91高清视频在线| 视频一区在线视频| 欧美电影在哪看比较好| 日韩高清欧美激情| 在线综合+亚洲+欧美中文字幕| 免费成人小视频| 精品福利二区三区| 成人免费黄色大片| 亚洲国产精品久久艾草纯爱| 911精品国产一区二区在线| 日韩视频在线永久播放| 国产精品久久国产精麻豆99网站| 久久精品一区蜜桃臀影院| 国产成人精品免费在线| 26uuu亚洲综合色欧美| 国产a久久麻豆| 亚洲精品国产无天堂网2021| 国产福利一区在线| 一区二区国产盗摄色噜噜| 日韩欧美国产电影| 久久综合久久综合亚洲| 不卡一区二区中文字幕| 亚洲毛片av在线| 国产麻豆欧美日韩一区| 国产激情一区二区三区四区| 亚洲欧美另类图片小说| 成人黄色a**站在线观看| 亚洲一区二区三区在线| 日韩欧美中文字幕公布| 亚洲美女区一区| 国产精品综合视频| 一区二区在线看| 精品福利在线导航| 欧美日韩激情在线| 欧美三级韩国三级日本一级| 日韩av在线发布| 欧美一区二区视频在线观看2022| 欧美人成免费网站| 一区二区三区在线视频免费观看| 九一九一国产精品| 亚洲一区二区精品3399| 国产精品免费丝袜|