學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 網(wǎng)絡(luò)知識(shí) > 網(wǎng)絡(luò)技術(shù) >

Linux分區(qū)只讀導(dǎo)致數(shù)據(jù)庫停止寫入數(shù)據(jù)怎么辦

時(shí)間: 加城1195 分享

  通常我們利用數(shù)據(jù)庫存儲(chǔ)數(shù)據(jù)和需要時(shí)候讀取。但是有網(wǎng)友在Linux服務(wù)器中,出現(xiàn)Linux分區(qū)只讀的現(xiàn)象,導(dǎo)致數(shù)據(jù)庫無法輸入數(shù)據(jù),遇到這種情況要如何處理呢?下面小編就給大家介紹下Linux分區(qū)只讀導(dǎo)致數(shù)據(jù)庫停止寫入數(shù)據(jù)的解決方法。

  Linux分區(qū)只讀導(dǎo)致數(shù)據(jù)庫停止寫入數(shù)據(jù)怎么辦?

  升級(jí)操作系統(tǒng)至SUSE Linux 11SP2版本。

  服務(wù)器掛載的遠(yuǎn)端分區(qū)(從存儲(chǔ)上劃分的卷),一開始是直接就掃描不到PV/VG/LV等信息,必須要手工執(zhí)行PVSCAN/VGSCAN/LVSCAN命令才可以看到信息,后來不能隨系統(tǒng)自動(dòng)掛載,無論怎么修改fstab文件都沒反應(yīng)。

  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ū)表最后的校驗(yàn)參數(shù)過于嚴(yán)格,于是由原來的“1 2”直接修改為“0 0”,結(jié)果依然未能解決問題。

  2、添加如下腳本

  xxx-db:/etc/init.d # more /etc/init.d/after.local

  pvscan

  vgscan

  lvscan

  mount /dev/mapper/oraclevg-oraclelv /oradata

  解決了文件系統(tǒng)自動(dòng)掛載問題,這個(gè)應(yīng)該是SUSE系統(tǒng)升級(jí)過程中的BUG。

  3、之后,沒有再次出現(xiàn)分區(qū)只讀問題,說明系統(tǒng)升級(jí)已經(jīng)解決分區(qū)只讀問題,后續(xù)如果還有問題,我打算再找硬件工程師更新光纖卡驅(qū)動(dòng)和服務(wù)器固件。

  補(bǔ)充:MySQL 數(shù)據(jù)庫常用命令

  create database name; 創(chuàng)建數(shù)據(jù)庫

  use databasename; 進(jìn)入數(shù)據(jù)庫

  drop database name 直接刪除數(shù)據(jù)庫,不提醒

  show tables; 顯示表

  describe tablename; 查看表的結(jié)構(gòu)

  select 中加上distinct去除重復(fù)字段

  mysqladmin drop databasename 刪除數(shù)據(jù)庫前,有提示。

  顯示當(dāng)前mysql版本和當(dāng)前日期

  select version(),current_date;

  數(shù)據(jù)庫維護(hù)方法

  在MySQL使用的過程中,在系統(tǒng)運(yùn)行一段時(shí)間后,可能會(huì)產(chǎn)生碎片,造成空間的浪費(fèi),所以有必要定期的對(duì)MySQL進(jìn)行碎片整理。

  當(dāng)刪除id=2的記錄時(shí)候,發(fā)生的現(xiàn)象

  這個(gè)時(shí)候發(fā)現(xiàn)磁盤的空間并沒有減少。這種現(xiàn)象就叫做碎片化(有一部分的磁盤空間在數(shù)據(jù)刪除以后(空),還是無法被操作系統(tǒng)所使用。)

  常見的優(yōu)化:

  # alter table xxx engine myisam;

  # optimize table t1;

  注意: 在實(shí)際開發(fā)的過程中,上面兩個(gè)語句盡量少使用,因?yàn)樵谑褂玫倪^程中,MySQL的表的結(jié)構(gòu)會(huì)整體全部重新整理,需要消耗很多的資源,建議在凌晨?jī)扇c(diǎn)鐘的時(shí)候執(zhí)行。(在linux下有定時(shí)器腳本可以執(zhí)行,crontab)


4015139