oracle参数和日志文件
linux:
oracle数据库口令文件(orapw + 实例名)损坏时恢复或者重置口令:
orapwd file=$ORACLE_HOME/dbs/orapworcl password=123456
参数:
select * from v$parameter;
静态参数:内存值不可修改,只能修改文件(修改后需要重启实例生效)
动态参数:内存值可以修改
修改参数:
alter system set open_cursors=400 scope=memory;
重置参数:
alter system reset open_cursors scope=spfile sid='*';
scope默认值是both,即memory和spfile都生效
spfile是二进制文件,不可以直接编辑
二进制文件可以使用 strings 文件名 查看内容
sql模式下:create pfile from spfile;--会生成一个initorcl.ora的文件
spfile级别高于pfile,要使pfile生效,必须删除spfile文件
使用pfile启动的实例,修改参数时没有scope选项,只可以修改内存参数
pfile可以使用vi命令或者文本编辑器直接修改文件
使用非默认路径下的pfile启动实例:startup pfile='/home/oracle/testpfile.ora';
使用内存中的参数创建spfile: create spfile='/home/oracle/testspfile.ora' from memory;
停止实例:shut immediate
使用非默认路径下的spfile启动实例需要借助pfile,在pfile中指定spfile的路径:spfile='/home/oracle/testspfile.ora'
show parameter spfile有值说明是以spfile启动的,否则是以pfile启动的
审计日志目录(用户连接、停止、启动):show parameter audit_file_dest
审计相关:show parameter audit
诊断(用户进程监听日志、异常)相关:show parameter diag
查询用户的SID:select sid,serial#,username,machine from v$session where username='SYSTEM';
打印某个用户的sql到诊断监听文件:EXEC DBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION(sid,serial#,TRUE);
监听文件命名格式:实例名_ora_进程id
查找服务器进程id: select spid from v$process where addr=(select paddr from v$session where sid=sid);
格式化诊断文件:tkprof 文件名 新文件名