Pangkalan data Oracle ialah salah satu pangkalan data hubungan yang paling popular di dunia. Sebagai pangkalan data berskala, Oracle boleh mengendalikan sejumlah besar data kompleks dalam aplikasi perusahaan besar. Dalam proses pemprosesan data ini, pengurusan memori adalah perkara yang sangat kritikal, kerana penggunaan memori yang munasabah boleh meningkatkan prestasi dan kelajuan tindak balas pangkalan data Oracle dengan banyak. Dalam artikel ini, kami akan menerangkan cara mengubah suai konfigurasi memori pangkalan data Oracle.
1. Fahami konfigurasi memori pangkalan data Oracle
Pangkalan data Oracle akan menduduki memori pelayan apabila ia sedang dijalankan. SGA terdiri daripada berbilang komponen, termasuk kumpulan kongsi, cache penimbal pangkalan data, penampan semula log, dsb. Komponen ini digunakan untuk menyimpan data dan indeks yang dibaca daripada cakera keras, serta hasil perantaraan yang diperlukan untuk memproses operasi pengisihan dan pengagregatan.
Sebaliknya, saiz SGA dikawal melalui parameter SGA_TARGET dan SGA_MAX_SIZE. SGA_TARGET merujuk kepada jumlah memori yang cuba diperuntukkan kepada kumpulan kongsi, cache pangkalan data dan log buat semula, manakala SGA_MAX_SIZE merujuk kepada saiz maksimum yang SGA_TARGET boleh berkembang. Kedua-dua parameter boleh diubah suai melalui arahan ALTER SYSTEM, tetapi hanya SGA_TARGET boleh diubah suai dalam talian dan SGA_MAX_SIZE mesti dimulakan semula untuk berkuat kuasa selepas pangkalan data dimulakan semula.
2. Ubah suai saiz memori pangkalan data Oracle
Sebelum mengubah suai saiz memori pangkalan data Oracle, kita perlu terlebih dahulu memahami peranan dan saiz setiap komponen, dan mengubah suai SGA_CONFIG, SGA_TARGET dan SGA_MAX_SIZE pangkalan data semasa. Arahan pertanyaan adalah seperti berikut:
show parameter sga
Selepas melaksanakan arahan ini, tetapan parameter yang berkaitan dengan SGA dalam pangkalan data semasa akan dikeluarkan. Dalam keadaan biasa, SGA_TARGET dan SGA_MAX_SIZE harus sama. Jika tidak, anda boleh menukarnya kepada nilai yang sama melalui perintah berikut:
alter system set sga_max_size=<size> scope=spfile; alter system set sga_target=<size> scope=spfile;
di mana,
Selepas pengubahsuaian selesai, anda perlu memulakan semula pangkalan data untuk konfigurasi memori baharu berkuat kuasa. Untuk memastikan pengubahsuaian berjaya, anda boleh melaksanakan perintah sga parameter tunjukkan sekali lagi untuk menyemak sama ada nilai parameter yang diubah suai telah berkuat kuasa.
3. Tetapkan saiz kolam kongsi
Kolam kongsi ialah salah satu komponen terpenting dalam SGA. Ia digunakan untuk menyimpan memori untuk pernyataan dan objek SQL dan PL/SQL yang dikongsi. Dalam Pangkalan Data Oracle, apabila aplikasi menanyakan pangkalan data, ia biasanya melaksanakan pernyataan SQL yang sama atau serupa, yang dicache dalam kumpulan kongsi untuk membolehkan pelaksanaan pantas pertanyaan yang sama atau serupa. Oleh itu, saiz kumpulan kongsi adalah penting kepada prestasi dan responsif pangkalan data Oracle.
Untuk mengubah suai saiz kumpulan kongsi, anda boleh menggunakan perintah berikut:
alter system set shared_pool_size=<size> scope=spfile;
Di mana,
Begitu juga, anda juga perlu memulakan semula pangkalan data untuk menjadikan konfigurasi memori baharu berkuat kuasa, dan sahkan sama ada nilai parameter yang diubah suai telah berkuat kuasa melalui arahan berikut:
show parameter shared_pool_size
4. Tetapan Saiz Cache Pangkalan Data
Cache pangkalan data ialah satu lagi komponen utama yang disimpan dalam SGA. Ia menyimpan blok data dan mengindeks dalam pangkalan data untuk mengurangkan bilangan akses cakera dan masa tindak balas. Tidak seperti kumpulan kongsi, saiz cache pangkalan data biasanya perlu ditetapkan berdasarkan keperluan aplikasi, jadi sukar untuk memberikan cadangan umum.
Untuk aplikasi OLTP yang besar, disyorkan untuk menetapkan cache pangkalan data kepada 50% ~ 70% daripada sumber SGA. Untuk aplikasi OLAP yang besar, disyorkan untuk menetapkan cache pangkalan data kepada 80% ~ 90% daripada sumber SGA.
Untuk mengubah suai saiz cache pangkalan data, anda boleh menggunakan arahan berikut:
alter system set db_cache_size=<size> scope=spfile;
Di mana,
Selepas pengubahsuaian selesai, anda perlu memulakan semula pangkalan data untuk menjadikan konfigurasi memori baharu berkuat kuasa, dan sahkan sama ada nilai parameter yang diubah suai telah berkuat kuasa melalui arahan berikut:
show parameter db_cache_size
5. Tetapan Saiz cache log buat semula
Cache log buat semula ialah komponen dalam SGA yang menyimpan log buat semula transaksi yang sedang berjalan. Cache log buat semula biasanya menggunakan saiz memori yang lebih kecil kerana Pangkalan Data Oracle boleh memutarkan log buat semula ke dalam berbilang fail pada cakera untuk memastikan penggunaan penuh ruang cakera. Walau bagaimanapun, dalam persekitaran transaksi yang tinggi, saiz cache log buat semula perlu ditingkatkan dengan sewajarnya.
Untuk mengubah suai saiz cache log buat semula, anda boleh menggunakan arahan berikut:
alter system set log_buffer=<size> scope=spfile;
Di mana,
Selepas pengubahsuaian selesai, anda perlu memulakan semula pangkalan data untuk menjadikan konfigurasi memori baharu berkuat kuasa, dan sahkan sama ada nilai parameter yang diubah suai telah berkuat kuasa melalui arahan berikut:
show parameter log_buffer
6. Ringkasan
Dalam artikel ini, kami membincangkan cara mengubah suai konfigurasi memori pangkalan data Oracle, termasuk saiz SGA_TARGET, SGA_MAX_SIZE, kumpulan kongsi, cache pangkalan data dan buat semula cache log, dsb. Pengubahsuaian kepada parameter ini mesti dipertimbangkan dengan teliti untuk memastikan pangkalan data mengimbangi memori dan penggunaan cakera, memaksimumkan prestasi dan responsif.
Atas ialah kandungan terperinci Bagaimana untuk mengubah suai konfigurasi memori pangkalan data Oracle. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!