日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql-bin.000001文件的来源及处理方法

發布時間:2024/6/18 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql-bin.000001文件的来源及处理方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

用ports安裝了mysql以后,過一段時間發現/var空間不足了,查一下,會發現是mysql-bin.000001、mysql- bin.000002等文件占用了空間,那么這些文件是干嗎的?這是數據庫的操作日志,例如UPDATE一個表,或者DELETE一些數據,即使該語句沒 有匹配的數據,這個命令也會存儲到日志文件中,還包括每個語句執行的時間,也會記錄進去的。

這樣做主要有以下兩個目的:
1:數據恢復
如果你的數據庫出問題了,而你之前有過備份,那么可以看日志文件,找出是哪個命令導致你的數據庫出問題了,想辦法挽回損失。
2:主從服務器之間同步數據
主服務器上所有的操作都在記錄日志中,從服務器可以根據該日志來進行,以確保兩個同步。

處理方法分兩種情況:
1:只有一個mysql服務器,那么可以簡單的注釋掉這個選項就行了。
vi /etc/my.cnf把里面的log-bin這一行注釋掉,重啟mysql服務即可。
2:如果你的環境是主從服務器,那么就需要做以下操作了。
A:在每個從屬服務器上,使用SHOW SLAVE STATUS來檢查它正在讀取哪個日志。
B:使用SHOW MASTER LOGS獲得主服務器上的一系列日志。
C:在所有的從屬服務器中判定最早的日志,這個是目標日志,如果所有的從屬服務器是更新的,就是清單上的最后一個日志。
D:清理所有的日志,但是不包括目標日志,因為從服務器還要跟它同步。
清理日志方法為:
PURGE MASTER LOGS TO 'mysql-bin.010';
PURGE MASTER LOGS BEFORE '2008-12-19 21:00:00';
如果你確定從服務器已經同步過了,跟主服務器一樣了,那么可以直接RESET MASTER將這些文件刪除。

?

如何刪除mysql-bin.0000X 日志文件呢?

紅色表示輸入的命令.

[root@jiucool var]# /usr/local/mysql/bin/mysql -u root -p
Enter password:? (輸入密碼)
Welcome to the MySQL monitor.? Commands end with ; or /g.
Your MySQL connection id is 264001
Server version: 5.1.35-log Source distribution

Type ‘help;’ or ‘/h’ for help. Type ‘/c’ to clear the current input statement.

mysql> reset master; (清除日志文件)
Query OK, 0 rows affected (8.51 sec)

mysql>

好了,我們再來查看下mysql文件夾占用多少空間?

[root@jiucool var]# du -h –max-depth=1 /usr/local/mysql/
37M???? /usr/local/mysql/var
70M???? /usr/local/mysql/mysql-test
15M???? /usr/local/mysql/lib
448K??? /usr/local/mysql/include
2.9M??? /usr/local/mysql/share
7.6M??? /usr/local/mysql/libexec
17M???? /usr/local/mysql/bin
11M???? /usr/local/mysql/docs
2.9M??? /usr/local/mysql/sql-bench
163M??? /usr/local/mysql/

好了,看一下,整個mysql 目錄才占用163M大小!OK,沒問題,既然mysql-bin.0000X日志文件占用這么大空間,存在的意義又不是特別大,那么我們就不讓它生成吧.

[root@jiucool var]# find / -name my.cnf

找到了my.cnf 即mysql配置文件,我們將log-bin=mysql-bin 這條注釋掉即可.

# Replication Master Server (default)
# binary logging is required for replication
#log-bin=mysql-bin

重啟下mysql吧.

OK,至此,操作完成. 以后再不會因為就幾十M的數據庫大小生成N個G的日志文件啦.

這些個日志文件太恐怖了,我搬到這新VPS來才二十天左右,還不到一個月日志文件居然就近3個G大小,如果一兩個月我不清除日志文件這還得了!

?

轉載于:https://www.cnblogs.com/mr-amazing/p/4468395.html

總結

以上是生活随笔為你收集整理的mysql-bin.000001文件的来源及处理方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。