国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關注微信公眾號

實戰:巧用磁盤管理工具給oracle提速
2007-11-07   IT168

今天,數據庫的使用已經深入到了各個行業的方方面面,隨著大型數據庫應用的增加,動輒涉及到TB級數據量的存儲與讀取,數據庫的讀寫效率日益成為整體系統的瓶頸所在。越來越多的系統管理員已經意識到:提高數據庫的讀寫速度,走出海量數據和訪問量壓力的瓶頸,是提高整體系統的運行效率的關鍵。

在這里,筆者將向大家介紹使用磁盤管理工具給Oracle提速的一些方法。當我們希望給Oracle提速的時候,我們首先必須了解在oracle運行過程中,瓶頸來自于哪些方面,我們通過哪些方面去給Oracle提速。

瓶頸來自于哪里

一、 操作系統的單寫鎖

首先我們知道,Unix系統是一個多用戶的操作系統,為了保持文件的一致性,操作系統一般會在某個用戶對數據庫進行讀寫操作的時候,為該文件加一個單寫鎖(single write lock),這樣可以避免其它人繼續操作這個文件,可以保證數據文件的可靠性。

但是加鎖和解鎖的過程如此復雜,在獲得文件一致性和安全性的同時,犧牲掉了大量的系統性能,有什么辦法可以既保證數據庫系統的文件一致性,又不致于浪費掉大量的系統性能呢?

二、寫緩存和磁盤讀寫

我們知道,在數據庫的數據在讀寫的時候,首先都需要經過緩存,緩存命中率對于數據庫的讀寫效率起著至關重要的作用。那么我們如何提高緩存的命中率呢?

一般數據庫在讀寫的時候都會保存一份cache,然而文件系統在讀寫系統文件的時候也會生成一份cache,這樣緩存中就會留有冗余的數據,影響緩存使用的利用率。我們怎樣消除緩存中這部分冗余的數據呢?

三、提高磁盤讀寫效率

在Oracle 9i版本以后,Oracle本身都自帶有磁盤管理組件(Oracle disk manager)來管理數據文件,提高I/O吞吐量,不過本文將為大家介紹另外一種磁盤管理工具,能夠進一步優化磁盤數據結構,提高數據吞吐量。大家有興趣,可對兩種系統優化工具進行一下對比測試。

1

優化磁盤文件系統和數據分布

由于數據庫的讀寫與磁盤文件系統、數據分布等等規則密切相關,我們可以使用一些磁盤管理工具來優化磁盤的文件系統和數據分布規則。

對于Unix系統的單寫鎖問題造成數據庫讀寫效率低下的情況,我們知道,為了提高讀寫速度,Unix操作系統在提供單寫鎖功能的同時,還提供了異步讀寫(asynchronous I/O)和直接讀寫(direct I/O)的API,允許應用程序不加鎖的寫入文件。因此,一些磁盤管理工具軟件可以利用這個特點, 讓數據庫文件跳過這些單寫鎖,按照裸設備的讀寫方式寫這些文件,從而提高數據庫的讀寫性能。

同時,大多數磁盤管理工具都能夠自動監控數據讀寫存取的頻度,選擇將一些讀寫頻繁的數據文件直接加載到內存中,這樣,磁盤管理工具軟件能保證讀出和寫入這些文件,整個過程對于Oracle是完全透明的。

筆者在這里將以2個2000行的相同的數據庫更新來進行測試,以Vetitas storage foundation為例,來測試Veritas Storage Foundation對Oracle數據庫的提速效果。

1

Quick I/O系統優化實例介紹

Veritas Storage Foundation本身是一個管理軟件的套件,其中的Quick I/O與cache I/O功能組件能夠分別解決單寫鎖和緩存命中率問題。利用Quick I/O這個特性來讀寫文件,需要將VxFS文件系統的文件轉換成Quick IO文件,然后storage foundation才能減少這些文件的讀寫的鎖控制和cache的控制。

下面我們來看一下Quick IO的用法:

1. 確定目前數據庫的數據文件的位置;

""

2. 確定是否該目錄屬于VxFS文件系統,Qick IO是建立在VxFS文件系統上的,如果不屬于VxFS文件系統將無法使用Qick IO。

""

3. 同時,我們還需要確定是否Quick IO正在使用,可以通過如下命令行:
# dbed_checkconfig -S $ORACLE_SID -H $ORACLE_HOME
來確定,輸入命令行之后,從屏幕輸出中我們可以看到有關Quick IO的信息:
Examining Quick I/O settings.
10 files are not configured to use Quick I/O.
同時必須要注意,使用該命令的時候,$ORACLE_SID所屬的實例必須是啟動的狀態。

4. 獲得QIO所能夠轉換的數據庫文件的列表,生成mkqio.dat文件。
在這里,我們輸入:#qio_getdbfiles_ora,屏幕輸出如下:

""

這里需要注意的是:該命令會自動跳過temporary tablespace的文件,這是因為oracle的臨時文件支持把數據寫到未分配的存儲區域,但是quick IO不支持,所以如果將這種文件轉換成Quick IO文件,可能會引起oracle的寫失敗。

5. 這時必須停止oracle數據庫,否則在數據庫文件轉換成Quick IO文件時會失敗。

6. 停止oracle數據庫后,我們可以將VxFS類型的數據庫文件轉換為Quick文件,命令行如下:#qio_convertdbfiles_ora

""

這時候,我們重啟oracle數據庫,這時會發現數據庫的讀寫速度就會加快。一般來說,數據庫讀寫加快的比例和具體用戶的需求有關,以筆者所做的兩個2000行的數據更新進行測試的結果,速度提高了10%。Veritas官方的說法認為,這個提高的比例大概在5%-20%左右,不過具體應用過程中,能做到10%的速度提高還是很不錯的,有興趣的朋友可以自己試一試。

1

利用Cache QIO提高oracle讀寫

使用cache QIO的關鍵在于統計出來哪些數據庫文件被頻繁使用,因為內存的總數是有限的,將有限的資源利用到最需要的地方,正是我們這些數據庫管理員所追求的。下面我們說明一下cache QIO的用法:

1. 第一步必須清空QIO的統計信息,命令行如下:
#qiostat -r /oracle/oradata/glob_ora/*.dbf
#qiostat /oracle/oradata/glob_ora/*.dbf
這時,輸出結果如下,我們可以看見QIO的信息已經完全清空。

""

2. 下面,我們可以進入數據庫做幾個常見的讀寫操作,來判斷哪些文件被讀寫過了,并且判斷讀寫的頻次。

""

我們通過以下命令行來查詢哪些文件被讀寫過了:
#qiostat /oracle/oradata/glob_ora/*.dbf
這時,在輸出結果中,我們留意這一行:

""

說明該文件被讀寫的次數比較多。

3. 將該文件系統轉為Cache QIO文件系統
#vxtunefs -o qio_cache_enable=1 /oracle
注:關閉就是將該值設置為0

4. 重復上面的1-3步驟來測試哪些數據被讀寫過了。這時,我們可以發現,第二步的數據庫讀寫操作對文件的讀寫幾乎為0,那就是因為磁盤管理工具已經將你的讀寫記錄到了內存中一個專屬的地方,由磁盤管理工具來負責對文件的讀寫。

需要注意的是,這一步驟對普通用戶是屏蔽的,提高了數據庫用戶的數據文件讀寫速的,這個時候數據庫的讀寫可靠性將由磁盤管理工具軟件storage foundation來維護。

1

優化數據結構提高讀寫速度

在Oracle 9i之后,oracle使用oracle磁盤管理組件(Oracle Disk Manager)來管理數據文件,提高oracle數據庫的輸入輸出數據吞吐量。Oracle磁盤管理的原理是通過直接將用戶數據拷貝到裸設備上,從而減少內核對數據文件加鎖和減少多余cache,所以它基本應用在裸設備上,由oracle來管理和控制對于裸設備的讀寫。

我們仍然以Veritas的磁盤管理工具軟件Storage Foundation為例來說明磁盤管理工具軟件對數據文件的優化。Veritas Storage Foundation的組件ODM和Oracle自帶的系統優化是同樣的原理,唯一不同的是,它可以將數據寫在Veritas VxFS文件系統的基礎上,至于該軟件與Oracle自帶的優化功能孰優孰劣,讀者可以自己測試一下,根據筆者的經驗,由于Veritas Storage Foundation本身是專業的磁盤管理工具軟件,在針對Oracle數據庫的系統優化上,還是有非常明顯的效果。

但是,Veritas Storage Foundation的ODM組件與Quick IO還是有所不同。他們的區別在于使用Quick IO需要轉換數據庫文件,然而ODM的使用對于用戶來說是透明的。另外oracle 9i之前的用戶只能使用Quick IO功能,并不支持ODM功能,同時Quick IO和ODM不能同時使用。

下面我們來說明一下ODM的用法:

1. 確認ODM的序列號已經安裝;
# /opt/VRTS/bin/vxlictest -n "VERITAS Storage Foundation
for Oracle" -f "ODM"

2. 確定ODM軟件包已經安裝(以solaris為例):
# pkginfo |grep VRTSodm

3. 確認odm的庫文件存在:
# ls –l /opt/VRTSodm/lib/sparcv9/libodm.so (64位操作系統)
# ls –l /opt/VRTSodm/lib/libodm.so (32位操作系統)

4. 確認Quick IO沒有被使用
$ dbed_checkconfig -S $ORACLE_SID -H $ORACLE_HOME

5. 停止oracle 數據庫。如果Quick IO 不存在,可以忽律步驟6-7;

6. 將quick IO數據文件轉換為ODM文件格式:
# /opt/VRTS/bin/qio_getdbfiles -T ora –a
得出Quick IO的數據庫文件
# /opt/VRTS/bin/qio_convertdbfiles -T ora –u
將剛才得出的數據庫文件轉換為非Quick IO的文件

7. 查看ODM是否在當前數據庫已經被使用:
$ grep ODM /oracle/admin/ORCL/bdump/alert_ORCL.log
如果該命令得出“Oracle instance running with ODM: Veritas #.# ODM Library, Version #.#”,則說明ODM已經是啟動的了;否則就是沒有啟動。

8. 將原來的odm庫文件用Veritas的替換:
# mv /oracle/lib/libodm9.so /oracle/lib/libodm9.so.old
將原有的庫文件備份;
# ln -s /opt/VRTSodm/lib/sparcv9/libodm.so /oracle/lib/libodm9.so
用Veritas的庫文件替換

9. 因為ODM功能無法與QIO功能一起使用,所以使用ODM之前,必須關閉cache quick IO功能;
# vxtunefs -o qio_cache_enable=0 $ORACLE_BASE/oradata
重新啟動oracle數據庫

10. 驗證ODM已經啟動
$ grep ODM /oracle/admin/ORCL/bdump/alert_ORCL.log
可以得出Veritas ODM的版本信息
$ dbed_checkconfig -S $ORACLE_SID -H $ORACLE_HOME
可以在輸出中看到“NOTICE: It appears that your system is ODM enabled.”

這樣,oracle的ODM功能就成功啟動了,至于數據庫讀寫速度加快了多少,大家有興趣可自行測試下,并與前面的Quick IO相對比下。

1

熱詞搜索:

上一篇:分清業務類型 選擇合適的優化方法
下一篇:Sql Server數據庫的備份和恢復措施

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
国产精品久久久久一区二区| 另类人畜视频在线| 欧美日韩一区在线播放| 国产精品久久久久久亚洲调教| 国产女人18毛片水18精品| 好看的亚洲午夜视频在线| 亚洲精品一区二区三区99| 亚洲午夜精品一区二区三区他趣 | 一本久道久久综合中文字幕| 亚洲影视中文字幕| 欧美成人精品高清在线播放| 国产精品免费电影| 亚洲精品四区| 久久精品综合| 国产精品久久婷婷六月丁香| 亚洲精品乱码久久久久久黑人 | 欧美日韩亚洲一区二区三区在线 | 91久久在线观看| 午夜精品一区二区在线观看| 美女主播视频一区| 国产麻豆午夜三级精品| 亚洲狼人综合| 老司机午夜精品视频| 国产精品手机在线| 亚洲一区二区动漫| 欧美日韩成人激情| 亚洲人午夜精品免费| 久久国产高清| 国产午夜亚洲精品不卡| 亚洲综合日本| 国产精品乱子久久久久| 亚洲午夜精品久久久久久浪潮 | 影音先锋亚洲电影| 亚洲一区二区三区在线| 欧美日韩大陆在线| 尤物yw午夜国产精品视频| 午夜精品视频网站| 国产精品亚洲精品| 亚洲欧美另类综合偷拍| 国产精品爽黄69| 亚洲在线视频网站| 国产精品影视天天线| 亚洲免费中文| 国产日韩在线一区| 久久久九九九九| 精品成人在线视频| 欧美不卡高清| 亚洲人精品午夜| 欧美日韩在线视频一区| 日韩午夜中文字幕| 国产精品高清网站| 久久久久久成人| 亚洲黄色一区| 欧美午夜精品久久久久久孕妇| 亚洲香蕉网站| 狠狠久久亚洲欧美专区| 久久精品一区四区| 91久久综合亚洲鲁鲁五月天| 欧美日韩成人综合天天影院| 亚洲综合色视频| 激情av一区二区| 欧美乱妇高清无乱码| 亚洲专区在线| 激情综合久久| 欧美日韩综合在线| 欧美亚洲日本国产| 亚洲成色精品| 国产精品久久9| 久久精选视频| 一区二区三区国产精品| 国产精品一区视频| 麻豆亚洲精品| 国产精品99久久久久久久久| 国产一区二区精品丝袜| 欧美精品在线一区二区三区| 欧美亚洲三区| 亚洲夜间福利| 亚洲黄色影片| 国产亚洲一本大道中文在线| 欧美伦理影院| 久久在线免费观看| 久久er精品视频| 国产精品99久久久久久www| 亚洲大黄网站| 国产中文一区二区| 国产精品久久久久久久久免费桃花 | 国产精品永久免费视频| 欧美99在线视频观看| 午夜视频久久久| 一片黄亚洲嫩模| 亚洲精品1区2区| 激情婷婷久久| 国产女优一区| 欧美日韩免费一区二区三区视频| 久久精品国产999大香线蕉| aa日韩免费精品视频一| 亚洲成人原创| 国产精品拍天天在线| 欧美区二区三区| 美女视频黄 久久| 欧美在线日韩| 性久久久久久久久| 亚洲自啪免费| 亚洲欧美卡通另类91av| 亚洲深夜福利网站| 一道本一区二区| 亚洲毛片在线观看.| 在线观看国产欧美| 一区二区三区在线免费视频| 国产一区二区三区在线观看精品 | 狠狠做深爱婷婷久久综合一区| 国产精品综合网站| 国产精品色网| 国产欧美日韩精品丝袜高跟鞋| 欧美日本中文字幕| 欧美日韩精品中文字幕| 欧美激情精品久久久久久大尺度| 另类天堂av| 欧美激情一区在线| 欧美劲爆第一页| 欧美三级免费| 国产欧美在线| 樱桃国产成人精品视频| 亚洲国产专区| 亚洲自拍偷拍麻豆| 欧美一区在线看| 美女91精品| 欧美日韩一区二区视频在线观看 | 99视频精品在线| 一区二区三区免费观看| 亚洲欧美国产一区二区三区| 欧美一区在线直播| 欧美阿v一级看视频| 欧美视频在线播放| 国产精品腿扒开做爽爽爽挤奶网站| 国产精品久久久久免费a∨大胸| 欧美午夜精品一区| 国产一区二区精品| 亚洲福利视频二区| 这里只有精品丝袜| 久久久综合网站| 欧美日韩国产综合网 | 亚洲视频专区在线| 久久精品亚洲精品国产欧美kt∨| 欧美成年人视频网站欧美| 欧美色视频日本高清在线观看| 国产精品日韩精品| 亚洲欧洲精品一区二区| 午夜一区二区三区不卡视频| 蜜桃久久精品一区二区| 国产精品视频第一区| 亚洲精品裸体| 久久免费精品日本久久中文字幕| 欧美日韩国产精品专区| 国产一区二区三区在线观看网站 | 激情久久综合| 亚洲伊人网站| 欧美成人免费小视频| 国产欧美一区二区在线观看| 一本色道久久综合精品竹菊| 另类天堂视频在线观看| 国产日韩精品在线| 亚洲午夜精品福利| 欧美国产亚洲另类动漫| 精品av久久707| 欧美亚洲免费电影| 欧美午夜视频一区二区| 一区二区三区久久网| 欧美电影免费观看高清完整版| 国产精品久久久久久亚洲毛片| 亚洲精品系列| 欧美成人网在线| 亚洲大片精品永久免费| 久久久精品一品道一区| 国产午夜亚洲精品羞羞网站| 午夜一区二区三区不卡视频| 国产精品捆绑调教| 中文在线不卡视频| 欧美日本在线看| 亚洲日本中文字幕区| 美女日韩欧美| 1000部国产精品成人观看| 老司机精品视频一区二区三区| 影音先锋在线一区| 玖玖综合伊人| 亚洲电影免费观看高清完整版在线| 久久久久91| 影音先锋久久精品| 久久人人爽人人| 亚洲高清免费视频| 欧美国产精品中文字幕| 亚洲精品网址在线观看| 欧美激情国产精品| 亚洲色无码播放| 国产毛片一区| 久久精品一区二区国产| 一区在线观看| 欧美激情一区二区三区在线视频 | 欧美性事在线| 亚洲欧美激情四射在线日 |