欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql利用init-connect增加訪問(wèn)審計(jì)功能的實(shí)現(xiàn)

 更新時(shí)間:2017年03月31日 13:36:33   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇mysql利用init-connect增加訪問(wèn)審計(jì)功能的實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

mysql的連接首先都是要通過(guò)init-connect初始化,然后連接到實(shí)例。

我們利用這一點(diǎn),通過(guò)在init-connect的時(shí)候記錄下用戶的thread_id,用戶名和用戶地址實(shí)現(xiàn)db的訪問(wèn)審計(jì)功能。

實(shí)現(xiàn)步驟

1、創(chuàng)建審計(jì)用的庫(kù)表。

為了不與業(yè)務(wù)的庫(kù)沖突,單獨(dú)創(chuàng)建自己的庫(kù):

#建庫(kù)表代碼
create database db_monitor ;
use db_monitor ;
CREATE TABLE accesslog
( thread_id int(11) DEFAULT NULL,  #進(jìn)程id
 log_time datetime default null,  #登錄時(shí)間
 localname varchar(50) DEFAULT NULL, #登錄名稱,帶詳細(xì)ip
 matchname varchar(50) DEFAULT NULL, #登錄用戶
 key idx_log_time(log_time)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

2、配置init-connect參數(shù)

這個(gè)參數(shù)是可以動(dòng)態(tài)調(diào)整的,也注意要加到配置文件my.cnf中,否則下次重啟后就失效了;

mysql> show variables like 'init_connect%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| init_connect |    |
+---------------+-------+
1 row in set (0.00 sec

mysql> set global init_connect='insert into db_monitor.accesslog(thread_id,log_time,localname,matchname) values(connection_id(),now(),user(),current_user());'; 

3、授予普通用戶對(duì)accesslog表的insert權(quán)限

該點(diǎn)很重要

該參數(shù)只對(duì)普通用戶生效,有super權(quán)限的都不會(huì)有作用。

如果是普通用戶,增加了該功能后,一定需要授權(quán):

grant insert on db_monitor.accesslog to user@'xx.xx.xx.%';

不授權(quán)的后果是,連接數(shù)據(jù)庫(kù)會(huì)失?。?/p>

accesslog表沒(méi)有insert權(quán)限的用戶:

mysql> show databases;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:  7
Current database: *** NONE ***

ERROR 1184 (08S01): Aborted connection 7 to db: 'unconnected' user: 'user2' host: 'localhost' (init_connect command failed) 

4、驗(yàn)證審計(jì)功能

某個(gè)用戶對(duì)test庫(kù)刪除了一張表,看我們配合binlog日志是否能追蹤到時(shí)哪個(gè)用戶:


查看binlog:


可以看出來(lái)是哪個(gè)用戶進(jìn)行了操作,從而完成審計(jì)。

以上這篇mysql利用init-connect增加訪問(wèn)審計(jì)功能的實(shí)現(xiàn)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 圖文詳解MySQL中兩表關(guān)聯(lián)的連接表如何創(chuàng)建索引

    圖文詳解MySQL中兩表關(guān)聯(lián)的連接表如何創(chuàng)建索引

    這篇文章通過(guò)圖文給大家介紹了關(guān)于MySQL中兩表關(guān)聯(lián)的連接表如何創(chuàng)建索引的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • mysql數(shù)據(jù)庫(kù)row_number函數(shù)舉例介紹

    mysql數(shù)據(jù)庫(kù)row_number函數(shù)舉例介紹

    在MySQL中ROW_NUMBER()是一種用來(lái)生成行號(hào)的功能函數(shù),通常情況下它用于對(duì)查詢結(jié)果進(jìn)行編號(hào),以便方便地查看每行的位置,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫(kù)row_number函數(shù)舉例介紹的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • 從云數(shù)據(jù)遷移服務(wù)看MySQL大表抽取模式的原理解析

    從云數(shù)據(jù)遷移服務(wù)看MySQL大表抽取模式的原理解析

    這篇文章主要介紹了從云數(shù)據(jù)遷移服務(wù)看MySQL大表抽取模式的原理解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • Mysql中zerofill自動(dòng)填充的實(shí)現(xiàn)

    Mysql中zerofill自動(dòng)填充的實(shí)現(xiàn)

    MySQL中的zero fill可以設(shè)置自動(dòng)填充零,以便固定位數(shù)的數(shù)字能夠保持一致的格式,本文就介紹了Mysql中zerofill自動(dòng)填充,感興趣的可以了解一下
    2023-09-09
  • Mysql之如何修改字段名和字段類型

    Mysql之如何修改字段名和字段類型

    這篇文章主要介紹了Mysql之如何修改字段名和字段類型問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Mysql大數(shù)據(jù)量查詢優(yōu)化思路詳析

    Mysql大數(shù)據(jù)量查詢優(yōu)化思路詳析

    這篇文章主要介紹了Mysql大數(shù)據(jù)量查詢優(yōu)化思路,Mysql大表查詢優(yōu)化,理論上千萬(wàn)級(jí)別以下的數(shù)據(jù)量Mysql單表查詢性能處理都是可以的。下文我們就來(lái)看看具體得思路解析
    2022-01-01
  • win2003 安裝2個(gè)mysql實(shí)例做主從同步服務(wù)配置

    win2003 安裝2個(gè)mysql實(shí)例做主從同步服務(wù)配置

    注意的就是路徑的正確書(shū)寫(xiě)。然后在my.ini的配置中,server_id必須保持唯一性。port避免使用3306,服務(wù)名稱和mysql5.1不一樣即可。
    2011-05-05
  • MySQL插入中文不亂碼的5種方法

    MySQL插入中文不亂碼的5種方法

    這篇文章主要介紹了MySQL 插入中文不亂碼的5種方法,需要的朋友可以參考下
    2016-06-06
  • mysql 行轉(zhuǎn)列和列轉(zhuǎn)行實(shí)例詳解

    mysql 行轉(zhuǎn)列和列轉(zhuǎn)行實(shí)例詳解

    這篇文章主要介紹了mysql 行轉(zhuǎn)列和列轉(zhuǎn)行實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • MySQL使用UUID_SHORT()的問(wèn)題解決

    MySQL使用UUID_SHORT()的問(wèn)題解決

    MySQL的UUID_SHORT()函數(shù)是一個(gè)用于生成短UUID的函數(shù),該函數(shù)返回一個(gè)64位的整數(shù),可以用于唯一標(biāo)識(shí)一條數(shù)據(jù)記錄,本文介紹了MySQL使用UUID_SHORT()的問(wèn)題解決,感興趣的可以了解一下
    2023-08-08

最新評(píng)論