Linux分區(qū)只讀導致數據庫停止寫入數據怎么辦
通常我們利用數據庫存儲數據和需要時候讀取。但是有網友在Linux服務器中,出現Linux分區(qū)只讀的現象,導致數據庫無法輸入數據,遇到這種情況要如何處理呢?下面小編就給大家介紹下Linux分區(qū)只讀導致數據庫停止寫入數據的解決方法。
Linux分區(qū)只讀導致數據庫停止寫入數據怎么辦?
升級操作系統(tǒng)至SUSE Linux 11SP2版本。
服務器掛載的遠端分區(qū)(從存儲上劃分的卷),一開始是直接就掃描不到PV/VG/LV等信息,必須要手工執(zhí)行PVSCAN/VGSCAN/LVSCAN命令才可以看到信息,后來不能隨系統(tǒng)自動掛載,無論怎么修改fstab文件都沒反應。
xxx-db:~ # more /etc/fstab
/dev/disk/by-id/cciss-3600508b1001c2b630be086f93f71f626-part1 swap swap defaults 0 0
/dev/disk/by-id/cciss-3600508b1001c230b6be086f39f71f626-part2 / ext3 acl,user_xattr 1 1
proc /proc proc defaults 0 0
sysfs /sys sysfs noauto 0 0
debugfs /sys/kernel/debug debugfs noauto 0 0
usbfs /proc/bus/usb usbfs noauto 0 0
devpts /dev/pts devpts mode=0620,gid=5 0 0
#/dev/oraclevg/oraclelv /oradata ext3 acl,user_xattr 1 2
/dev/oraclevg/oraclelv /oradata ext3 defaults 0 0
#/dev/mapper/36001438009b03d620000500000f90000 /oradata ext3 defaults 0 0
1、懷疑是文件分區(qū)表最后的校驗參數過于嚴格,于是由原來的“1 2”直接修改為“0 0”,結果依然未能解決問題。
2、添加如下腳本
xxx-db:/etc/init.d # more /etc/init.d/after.local
pvscan
vgscan
lvscan
mount /dev/mapper/oraclevg-oraclelv /oradata
解決了文件系統(tǒng)自動掛載問題,這個應該是SUSE系統(tǒng)升級過程中的BUG。
3、之后,沒有再次出現分區(qū)只讀問題,說明系統(tǒng)升級已經解決分區(qū)只讀問題,后續(xù)如果還有問題,我打算再找硬件工程師更新光纖卡驅動和服務器固件。
補充:MySQL 數據庫常用命令
create database name; 創(chuàng)建數據庫
use databasename; 進入數據庫
drop database name 直接刪除數據庫,不提醒
show tables; 顯示表
describe tablename; 查看表的結構
select 中加上distinct去除重復字段
mysqladmin drop databasename 刪除數據庫前,有提示。
顯示當前mysql版本和當前日期
select version(),current_date;
數據庫維護方法
在MySQL使用的過程中,在系統(tǒng)運行一段時間后,可能會產生碎片,造成空間的浪費,所以有必要定期的對MySQL進行碎片整理。
當刪除id=2的記錄時候,發(fā)生的現象
這個時候發(fā)現磁盤的空間并沒有減少。這種現象就叫做碎片化(有一部分的磁盤空間在數據刪除以后(空),還是無法被操作系統(tǒng)所使用。)
常見的優(yōu)化:
# alter table xxx engine myisam;
# optimize table t1;
注意: 在實際開發(fā)的過程中,上面兩個語句盡量少使用,因為在使用的過程中,MySQL的表的結構會整體全部重新整理,需要消耗很多的資源,建議在凌晨兩三點鐘的時候執(zhí)行。(在linux下有定時器腳本可以執(zhí)行,crontab)