本文目錄一覽:
如何查看mysql數據庫操作記錄日誌?
有時候我們會不小心對一個大表進行了 update,比如說寫錯了 where 條件……
此時,如果 kill 掉 update 線程,那回滾 undo log 需要不少時間。如果放置不管,也不知道 update 會持續多久。
那我們能知道 update 的進度么?
實驗
我們先創建一個測試數據庫:
快速創建一些數據:
連續執行同樣的 SQL 數次,就可以快速構造千萬級別的數據:
查看一下總的行數:
我們來釋放一個大的 update:
然後另起一個 session,觀察 performance_schema 中的信息:
可以看到,performance_schema 會列出當前 SQL 從引擎獲取的行數。
等 SQL 結束後,我們看一下 update 從引擎總共獲取了多少行:
可以看到該 update 從引擎總共獲取的行數是表大小的兩倍,那我們可以估算:update 的進度 = (rows_examined) / (2 * 錶行數)
?小貼士
information_schema.tables 中,提供了對錶行數的估算,比起使用 select count(1) 的成本低很多,幾乎可以忽略不計。
那麼是不是所有的 update,從引擎中獲取的行數都會是表大小的兩倍呢?這個還是要分情況討論的,上面的 SQL 更新了主鍵,如果只更新內容而不更新主鍵呢?我們來試驗一下:
等待 update 結束,查看 row_examined,發現其剛好是表大小:
那我們怎麼準確的這個倍數呢?
一種方法是靠經驗:update 語句的 where 中會掃描多少行,是否修改主鍵,是否修改唯一鍵,以這些條件來估算係數。
另一種方法就是在同樣結構的較小的表上試驗一下,獲取倍數。
這樣,我們就能準確估算一個大型 update 的進度了。
如何查看mysql數據庫操作記錄日誌
1、首先確認你日誌是否啟用了mysqlshow variables like ‘log_bin’。
2、如果啟用了,即ON,那日誌文件就在mysql的安裝目錄的data目錄下。
3、怎樣知道當前的日誌mysql show master status。
4、看二進制日誌文件用mysqlbinlog,shellmysqlbinlog mail-bin.000001或者shellmysqlbinlog mail-bin.000001 | tail,Windows 下用類似的。
MySQL的日誌操作:
1、首先,登陸mysql後,執行sql語句:show variables like ‘log_bin’。
2、#錯誤日誌log-errol開啟方式:在my.ini的[mysqld]選項下:添加代碼:log-error=E:\log-error.txt。
記錄內容:主要是記錄啟動、運行或停止mysqld時出現的致命性問題,都是系統級的錯誤記錄。
3、#查詢日誌:log,開啟方式:在my.ini的[mysqld]選項下:添加代碼:log=E:/mysql_log.txt。
4、#二進制日誌:log-bin,開啟方式:在my.ini的[mysqld]選項下:添加代碼:log-bin=E:/mysql_log_bin,記錄內容:主要是記錄所有的更改數據的語句,可使用mysqlbinlog命令恢複數據。
關於Mysql數據庫日誌的問題
1.
錯誤日誌記錄啟動、運行或停止mysqld時出現的問題。
My.ini配置信息:
#Enter a name for the error log file.Otherwise a default name will be used.
#log-error=d:/mysql_log_err.txt
2.
查詢日誌記錄建立的客戶端連接和執行的語句。
My.ini配置信息:
#Enter a name for the query log file. Otherwise a default name will be used.
#log=d:/mysql_log.txt
3.
更新日誌記錄更改數據的語句。不贊成使用該日誌。
My.ini配置信息:
#Enter a name for the update log file. Otherwise a default name will be used.
#log-update=d:/mysql_log_update.txt
4.
二進制日誌記錄所有更改數據的語句。還用於複製。
My.ini配置信息:
#Enter a name for the binary log. Otherwise a default name will be used.
#log-bin=d:/mysql_log_bin
5.
慢日誌記錄所有執行時間超過long_query_time秒的所有查詢或不使用索引的查詢。
My.ini配置信息:
#Enter a name for the slow query log file. Otherwise a default name will be used.
#long_query_time =1
#log-slow-queries= d:/mysql_log_slow.txt
Mysql日誌的關閉與開啟:使用以下命令查看是否啟用了日誌
mysql show variables like ‘log_%’
凡Value值為OFF的表示未開啟服務,若要開啟只需要將上的my.ini配置信息寫入(my.ini為mysql安裝目錄下),然後去掉前面的“#”號,再重啟mysql服務.相反地,若要停止mysql日誌服務,只需要將my.ini中對應的配置信息去掉即
怎麼查看mysql日誌
mysql有好幾種日誌,通常日誌,查詢緩慢日誌,錯誤日誌,默認只有錯誤日誌是開啟的,通常日誌如果開啟會消耗大量系統資源,而且查看也是非常不容易。如果想看哪裡出錯的話,查詢錯誤日誌就可以。通常會在data文件夾下面,服務器名稱.err就是日誌
數據庫的安全涉及到各方面,數據的丟失或者篡改將會帶來無法估量的損失,所以數據庫的安全尤為重要,我們可以通過數據庫的日誌來分析數據庫的安全性,然會針對分析結果採取相應的措施。
mysql日誌類型有哪些
一、錯誤日誌
二、二進制日誌
三、查詢日誌
四、慢查詢日誌
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/278353.html