Rumah >pangkalan data >Oracle >Penjelasan terperinci mengenai fail kawalan Oracle dan isu pengurusan fail log
Artikel ini membawakan anda pengetahuan yang berkaitan tentang Oracle Ia terutamanya memperkenalkan pengurusan fail kawalan Oracle dan fail log Fail kawalan adalah salah satu daripada fail fizikal Oracle sekurang-kurangnya satu fail kawalan, yang merekodkan nama pangkalan data, lokasi fail data dan maklumat lain Mari kita lihat bersama-sama.
Tutorial yang disyorkan: "Tutorial Video Oracle"
Fail kawalan ialah salah satu fail fizikal Oracle Setiap pangkalan data Oracle mesti mempunyai sekurang-kurangnya satu fail kawalan, yang merekodkan nama pangkalan data, lokasi fail data dan maklumat lain. Apabila memulakan contoh data, Oracle akan mencari fail kawalan berdasarkan parameter permulaan, dan kemudian Oracle akan mewujudkan perkaitan antara tika dan pangkalan data berdasarkan fail kawalan. Kepentingan fail kawalan ialah apabila fail kawalan rosak, pangkalan data tidak akan dapat dimulakan.
Fail kawalan dibuat secara automatik apabila pangkalan data dibuat, dan akan dikemas kini secara serentak apabila pangkalan data berubah secara fizikal. Pastikan fail kawalan tersedia sepanjang masa. Hanya proses Oracle boleh mengemas kini kandungan fail kawalan dengan selamat, jadi jangan cuba mengedit fail kawalan secara manual pada bila-bila masa.
Apabila pangkalan data dicipta, sistem akan mencipta fail kawalan berdasarkan tetapan control_files dalam fail parameter permulaan. Semasa penggunaan pangkalan data kemudian, jika fail kawalan hilang atau rosak, fail kawalan baharu boleh dibuat secara manual.
Sintaks asas untuk mencipta fail kawalan secara manual adalah seperti berikut.
create controlfile reuse database db_name logfile group 1 redofiles_list1 ... datafile ... maxlogfiles max_value1 maxlogmembers max_value2 maxinstances max_value3 maxdatafiles max_value4 noresetlogsiresetlogs archiveloginoarchivelog;
Penerangan parameter adalah seperti berikut.
db_name: nama pangkalan data.
fail log: Menunjukkan fail kumpulan log yang ditakrifkan di bawah.
redofiles_list1: Nama dan laluan senarai fail log buat semula 1 dalam kumpulan log buat semula.
fail data: Menunjukkan fail data yang ditakrifkan di bawah.
max_value1: Bilangan maksimum fail log buat semula.
max_value2: Bilangan maksimum ahli kumpulan log semula.
max_value3: Bilangan maksimum kejadian.
max_value4: Bilangan maksimum fail data.
Langkah asas untuk mencipta fail kawalan baharu adalah seperti berikut.
1 Lihat nama dan laluan semua fail data dan buat semula fail log dalam pangkalan data.
2.
3. Sandarkan semua fail data dan buat semula fail log.
4. Mulakan contoh pangkalan data.
5. Cipta fail kawalan baharu.
6. Edit parameter permulaan.
7. Buka semula pangkalan data.
1. Lihat nama dan laluan semua fail data dan buat semula fail log dalam pangkalan data.
Jika pangkalan data boleh dibuka, anda boleh menggunakan kamus data untuk mendapatkan maklumat asas tentang fail data dan fail log, seperti yang ditunjukkan di bawah.
Gunakan kamus data v$logfile untuk mendapatkan maklumat fail log.
select member from v$logfile;
Gunakan kamus data v$datafile untuk mendapatkan maklumat fail data.
select name from v$datafile;
Gunakan kamus data v$controlfile untuk mendapatkan maklumat fail kawalan.
select name from v$controlfile;
2. Tutup pangkalan data
Jika pangkalan data sedang berjalan, sebelum mencipta fail kawalan, log masuk dahulu sebagai pengguna sys dan tutup pangkalan data.
conn sys/change_on_install as sysdbashutdown normal
3. Sandarkan semua fail data dan buat semula fail log.
4. Mulakan contoh pangkalan data.
Selepas sandaran selesai, mulakan pangkalan data, tetapi jangan memuatkan pangkalan data terlebih dahulu Ini terutamanya kerana jika anda memuatkan pangkalan data, fail kawalan akan dibuka pada masa yang sama, dan tujuan mencipta kawalan baharu. fail tidak dapat dicapai.
startup nomount
Semasa penyelenggaraan pangkalan data harian, untuk mengelakkan ranap sistem pangkalan data akibat kehilangan atau kerosakan fail kawalan, kerap Buat sandaran fail kawalan. Terutama apabila struktur pangkalan data diubah suai, seperti menambah atau memadam fail data, fail kawalan perlu disandarkan semula dalam masa.
Menyandarkan fail kawalan boleh dicapai menggunakan pernyataan berikut.
alter database backup controlfile
Secara amnya terdapat dua jenis sandaran menggunakan pernyataan ini, satu adalah untuk membuat sandaran dalam bentuk fail binari, dan satu lagi adalah untuk membuat sandaran dalam bentuk fail teks. Mari kita lihat cara melaksanakan sandaran fail kawalan.
alter database backup controlfile to 'c:\bak.bkp';
Kod di atas melaksanakan sandaran fail kawalan ke direktori akar pemacu C, dan nama fail ialah bak.bkp , fail itu wujud dalam bentuk binari.
alter database backup controlfile to trace;
当数据库由于各种情况发生损坏时,这时可以使用所备份的文件来恢复数据库。在日常维护中,经常会遇到两种情况,一种是控制文件损坏,另一种情况是磁盘发生故障。
当控制文件损坏时,这种情况较为简单,只需要用备份文件替换损坏的文件即可,不过复制之前要先关闭数据库,然后再复制,复制完成后需要重新启动。
为了提高数据库的可靠性,可以建立多个镜像的控制文件,并且分别保存在不同的磁盘中进行多路复用,这样就可以避免由于单个设备故障而使得数据库无法启动的情况发生,这种管理策略被称为多路复用控制文件。当某个磁盘发生物理损坏导致控制文件损坏,数据库将被关闭,此时就可以利用另一个磁盘中保存的控制文件来恢复被损坏的控制文件,然后再重新启动数据库,达到保护控制文件的目的。
重做日志文件也称为日志文件,是记录系统的日常操作、异常等行为的文件,是包含系统信息的文件,包括内核、服务、在系统上运行的应用程序等。重做日志文件是数据库安全和恢复的基本保障,当数据库出现故障的时候,管理员可以根据日志文件和数据库备份文件,将崩溃的数据库恢复到最近一次记录日志时的状态。
在oracle数据库中,重做日志文件用于记录用户对数据库所做的各种变更操作所引起的数据变化,此时,所产生的操作会先写入重做日志缓冲区,当用户提交一个事务的时候,LGWR进程将与该事务相关的所有重做记录写入重做日志文件,同时生成一个“系统变更数”,scn会和重做记录一起保存到重做日志文件组,以标识与该事务提交成功。如果某个事务提交出现错误,可以通过重做记录找到数据库修改之前的内容,进行数据恢复。
在oracl数据库日常运行过程中,数据库管理员可以查看重做日志文件信息,用于了解数据库的运行情况。这可以通过查询数据字典视图v l o g 、 v log、v log、vlogfile和v l o g h i s t o r y 来 实 现 , 通 过 它 们 可 以 查 询 的 信 息 如 下 。 v log_history来实现,通过它们可以查询的信息如下。 v loghistory来实现,通过它们可以查询的信息如下。vlog:包含重做日志文件组的信息。
v l o g f i l e : 包 含 重 做 日 志 文 件 成 员 信 息 。 v logfile:包含重做日志文件成员信息。 v logfile:包含重做日志文件成员信息。vlog_history:包含日志历史信息。
在数据库的日常维护过程中,数据库管理员可以通过手工方式向数据库中添加新的重做日志组或日志文件,也可以改变重做日志文件的名称与位置,或者删除重做日志组或其成员。
1、创建重做日志文件组
语法如下:
alter database add logfile [group] [编号](日志文件) size
上面语句中group可选,当不选择的时候,系统会自动产生组号,为当前重做日志文件组的个数加1。
当重做日志文件组,其成员不合适或者所在存储位置出现错误时,此时可以将重做日志文件组或者其成员删除。
1、删除重做日志成员文件
删除重做日志文件成员使用如下语法。
alter database drop logfile member 文件名
删除group5添加的新成员文件
alter database drop logfile member 'd:\app\redo05_3.log';
在数据库正常使用中,如果想要改变重做日志文件的名称或位置,可以按照如下步骤进行重做日志文件的修改。
1、关闭数据库。
2、复制或者修改日志文件的位置。
3、启动数据库实例,但不打开数据库,只加载数据库。
4、重新设置重做日志文件的名称或位置。
5、打开数据库。
在oracle数据库中,重做日志文件用于记录用户对数据库所做的各种变更操作所引起的数据变化。在把这些变化写入重做的日志文件的时候,一般情况下有多个重做日志文件组,每个文件组有多个文件,oracle向这些重做文件写入的时候,一般情况下有多个重做日志文件组,每个文件组有多个文件,oracle向这些重做文件写入的时候,是使用循环的方式向这些重做日志文件组中的文件进行写入的,当最后一个重做日志文件组中的文件内容写满后,会重新写入第一个重做日志文件组中的文件。在这种情况下,原先重做日志文件的内容如何处理,是直接覆盖还是把原先的记录保存,就是我们要介绍的归档日志。
所谓归档日志文件就是指当重做日志文件写满的时候,把其中内容保存到新的文件中,这些新的文件集合就是归档日志文件。但是重做日志文件并不一定主动被保存到新的文件中,根据数据库设置不同,oracle有两种日志模式:归档日志模式和非归档日志模式。在非归档日志模式下,原日志文件的内容会被新的日志内容所覆盖;在归档日志模式下,oracle会首先对原日志文件进行归档存储,且在归档未完成之前不允许覆盖原有日志。
数据库管理人员可以修改归档日志文件和非归档日志文件,但首先需要了解归档日志信息。在oracle中,可以通过查询数据字典了解归档日志的一些基本信息,常用的数据字典有v a r c h i v e d l o g 、 v archived_log、v archivedlog、varchive_dest、v$database等
默认情况下,oracle数据库处于非归档日志模式,即当重做日志文件写满的时候,直接覆盖里面的内容,原先的日志记录不会被写入到归档日志文件中。根据oracle数据库对应的应用系统不同,数据库管理员可以把数据库的日志模式在归档模式和非归档模式之间进行切换。可以通过alter database archivelog或noarchivelog语句实现数据库在归档模式与非归档模式之间进行切换。
切换步骤如下:
1、关闭数据库
shutdown immediate;
2、将数据库启动到加载状态。
startup mount;
3、修改数据库的归档模式或非归档模式
归档模式修改为非归档模式
alter database noarchivelog;
非归档模式修改为归档模式
alter database archivelog;
4、重新打开数据库
alter database open;
推荐教程:《Oracle视频教程》
Atas ialah kandungan terperinci Penjelasan terperinci mengenai fail kawalan Oracle dan isu pengurusan fail log. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!