如果丢失所有初始化参数文件,但是有参数文件的备份可以用的情况下如何处理:
1.模拟问题发生
备份spfile
去dbs下面把所有初始化参数文件都删掉
2.如果实例并没有关闭,那么所有参数都还存储在内存中,就可以用
create pfile from spfile;
来创建pfile,之后再用
create spfile='/home/oracle/spfileorcl.ora' from pfile;
来创建spfile
3.如果实例是关闭掉的,或者是迁移到新的环境上的,可以先手工创建一个简单的pfile:
然后启动到nomount
然后进入rman,用spfile的备份文件恢复出一个spfile来:
检查是否生成:
然后关闭数据库重新启动
4.总结
数据库的初始化参数大多数都设置了默认值,作为数据库的标准配置,所以即使pfile只定义了一个db_name,其他数据库运行必要的参数,在实例启动的时候都是会给配上的。
在一个用spfile启动的数据库中,我们可能会发现v$parameter里面的值会跟v$spparameter的值不一样,v$spparameter很多内容是空的。
这是因为v$spparameter中的变量是来自磁盘上存储的spfile<SID>.ora的,而v$parameter的参数是来自当前运行的实例(内存)的。
改动静态参数,只会写到spfile里面,不会写入内存,SMON从spfile里面读到了这个参数,才会写入内存。
5.补充
后来发现RMAN可以在没有可用参数文件的情况启动到nomount,使得DBA可以操作备份恢复。道理跟上面是一样的,只不过连手工创建一个简单的pfile都不需要了。
删掉所有初始化参数文件,然后尝试启动数据库:
登入rman,启动到nomount
检查当前数据库状态
然后一样道理,操作spfile的restore