这几天因为公司的复杂查询出现性能的问题(说实话本来就没设计好,数据行数都在1000W左右),所以需要进行调优,其实问题很简单,在系统中都使用了exists来进行表关联,
当然是不行的,我利用了表内联来解决问题
恩,结果还算不错,从跑不出来到了第一次硬解析在10分钟以内,但是公司管理层还是希望请“大牛”来查看下(该说的我都说了,摆明了不相信我吗)
“大牛”来的第一天:
一、调整过程:
1.) 通过with语句进行调整语句
2.) 调整分区表结构
调整结果:
1.) 返回数据太大,tempspace不够
2.) 调整分区表结构
二、最终结果:
不了了之
“大牛”来的第二天:(因为有事,我不在,以下是听同事说的)
一、调整过程:
1.) 增加redo group
2.) resetlogs
3.) 增大SGA(ASSM)、PGA
调整结果:
1.) 数据库死机
二、最终结果:
无法open
当然了,事件是出了,事情还要做得,所以接下来由我来进行解决
配置说明:
OS: RH Linux AS 4
HD: 1 CPU、2GB MEM
DB: Oracle 10gR1
[oracle@crm73 ~]$ sqlplus /nolog
SQL*Plus: Release 10.1.0.3.0 - Production on Fri Jan 16 13:27:53 2009
Copyright (c) 1982, 2004, Oracle. All rights reserved.
SQL> startup mount;
....
SQL> alter database open;
数据库就死在那里不动了....
查看alert_je01.log文件,看到以下问题:
Recovery of Online Redo Log: Thread 1 Group 3 Seq 11894 Reading mem 0
Mem# 0 errs 0: /opt/oracle/oradata/je01/redo03.log
Thu Jan 15 13:52:06 2009
Warning: scanned uninitialized pool DEFAULT, setid=3, blksz=8192, 0
然后通过linux gdb进行进程dump,得到如下等待事件:
PX Deq: Test for msg
PX Deq: Par Recov Execute
free buffer waits
在LINUX下可以使用gdb,下面是一个例子:
[oracle@xty ~]$ ps -ef | grep LOCAL
......
[oracle@xty ~]$ gdb $ORACLE_HOME/bin/oracle 3765
......
(gdb) print ksudss(10)
[Switching to Thread -1219938624 (LWP 3765)]
$1 = 213658428
(gdb) detach
Detaching from program: /u01/app/oracle/product/10.1.0/db_1/bin/oracle, process 3765
(gdb) quit
根据“大牛”调整的步骤、trace、经验判断,很有可能问题出在redo和SGA上,根据推测做如下工作:
一、调整/etc/sysctl.conf
原本:kernel.shmmax = 4073741824
调整:
kernel.shmmax = 1073741824
kernel.shmall = 1048576
kernel.shmmni = 2048
kernel.sem = 250 32000 100 128
一、调整SGA:
原本:sga_max_size=520M
现在:sga_max_size=800M
调整:alter system set sga_max_size=520M scope=spfile;
二、调整PGA:
原本:pga_aggregate_target=170M
现在:pga_aggregate_target=400M
调整:alter system set pga_aggregate_target=170M;
三、删除redo group 3:
查看V$log,发现是当前日志
SQL> select group#,sequence#,archived,status from v$log;
GROUP# SEQUENCE# ARCHIVED STATUS
---------- ---------- -------- ----------------
1 1 YES INACTIVE
2 2 YES INACTIVE
3 3 NO CURRENT
发现clear不成功
SQL> alter database clear unarchived logfile group 3;
alter database clear unarchived logfile group 3
*
ERROR at line 1:
ORA-01624: log 3 needed for crash recovery of thread 1
ORA-00312: online log 3 thread 1: /op/oracle/oradata/je01/REDO03.LOG
把数据库down掉
SQL>shutdown immediate
recover database until cancel
先选择auto,尽量恢复可以利用的归档日志,然后重新
recover database until cancel
这次输入cancel,完成不完全恢复,也就是说恢复两次
如:
SQL> recover database until cancel;
Auto
……
SQL> recover database until cancel;
Cancel;
在init.ora.4292008151251中加入如下参数
_allow_resetlogs_corruption=TRUE
以resetlogs方式打开数据库
SQL>alter database open resetlogs;
问题解决!
将pfile转换成spfile
先注释_allow_resetlogs_corruption=TRUE
Create spfile from pfile=’ /opt/oracle/admin/je01/pfile/init.ora.4292008151251’
SQL> show parameter spfile;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
spfile string /opt/oracle/product/10g/dbs/spfileje01.ora
问题总结:
1、在没有充分了解OS的环境配置,就调整了SGA和PGA,导致scanned uninitialized pool DEFAULT
2、在处理过程使用了shutdown abort,导致buffer cache和redo不统一
分享到:
相关推荐
本文将深入探讨如何在C#中利用Oracle自带的驱动来实现批处理,以一次执行多条SQL语句。 首先,我们需要了解Oracle的数据驱动,即ODP.NET(Oracle Data Provider for .NET)。这是Oracle公司为.NET开发者提供的一个...
本文将深入探讨“System.Data.OracleClient”组件以及它与Oracle客户端软件的关系,同时提供一个详细的解决方案来处理“需要Oracle客户端软件8.1.7或更高版本”的错误。 System.Data.OracleClient是.NET Framework...
在本案例中,我们遇到了一个Oracle数据库在服务器主板故障后无法正常启动的问题。数据库在重启后尝试打开时,出现了ORA-01589错误,提示必须使用RESETLOGS或NORESETLOGS选项进行数据库打开。这通常意味着数据库在...
它以其“一次编写,到处运行”的特性著称,允许开发者编写跨平台的应用程序。在大会上,可能探讨了Java的新版本特性、性能优化、安全性更新以及Java在企业级应用中的最佳实践。 Java的最新发展可能包括JDK(Java ...
在实际应用中,可能还需要考虑性能优化,比如使用流式处理大文件,避免一次性加载整个BLOB到内存。此外,考虑到安全性,应该对敏感数据进行加密,同时确保对数据库操作的权限控制。 总的来说,Oracle数据库为存储和...
-- 如果不是第一次合并,则添加逗号分隔 ELSE MergeStr := cur_row.BaseValue; -- 第一次合并直接赋值 END IF; END LOOP; RETURN MergeStr; -- 返回合并后的字符串 END; ``` ### 函数解析 1. **变量声明**:...
它会将从上一次备份到指定恢复时间点的所有更改应用于数据文件。 - **打开数据库并重置日志**:`alter database open resetlogs` 命令用于打开数据库并重置日志文件序列号。这是恢复过程中的最后一步,也是至关重要...
1. 提高性能:由于存储过程在服务器端预编译,执行时只需解析一次,减少了网络传输和解析时间。 2. 代码复用:存储过程可以被多个应用调用,减少了代码重复,提高了开发效率。 3. 安全性:可以对存储过程设置权限,...
2. **增量备份**:基于上一次完整备份或上一次增量备份,仅备份自上次备份以来发生变化的数据。 3. **差异备份**(在某些工具中被称为增量备份):与Oracle的增量备份类似,但仅备份自上次完整备份以来变化的数据。 ...
- 分批处理大数据量操作,避免一次性加载所有数据。 6. **安全考虑**: - 避免在代码中硬编码数据库凭据,最好使用环境变量或配置文件。 - 使用参数化查询来防止SQL注入攻击。 7. **Qt Designer集成**: 如果...
Oracle的游标是数据库开发中的一个重要概念,尤其在PL/SQL编程中,游标用于处理SQL查询结果集,使得我们能够逐行处理数据,而不仅仅局限于一次性获取所有数据。在这个主题中,我们将深入探讨游标的定义、类型、使用...
Oracle Dataguard 实施步骤详解 ...开始第一次日志归档: ALTER SYSTEM ARCHIVE LOG CURRENT; 至此,Oracle Dataguard 的实施步骤已经完成。备库现在已经同步了主库的数据,并且可以实现实时灾难恢复。
- **启动时间** (`startup_time`):显示Oracle实例最后一次启动的时间。 - **状态** (`status`):应为“OPEN”,表明Oracle实例正在运行并且可以接受连接请求。 - **数据库状态** (`database_status`):应为...
如果Excel文件非常大,一次性读取所有数据可能会消耗大量内存。这时可以考虑分批处理,或者使用Oracle的BULK COLLECT功能以提高效率。 4. **错误处理**: 在实际操作中,务必添加适当的错误处理代码,如捕获和...
这个问题可能是由于某一次的 C 盘文件批量整理的过程中连带这些重要的文件一同“整理”掉了。 故障分析 由于所有的联机日志文件都被删除了,所以既包含当前联机日志,也包含非当前联机日志。为了恢复这些日志文件...
在Oracle数据库中,分页查询是一项常见的操作,特别是在大数据量的场景下,为了提高用户体验,我们需要快速有效地获取数据的一部分,而不是一次性加载所有记录。这里我们将深入探讨如何利用Oracle的存储过程来实现...
Oracle 性能问题是数据库管理员和开发者经常遇到的一个棘手问题,本文总结了 Oracle 性能问题的解决方案,涵盖了物理模型优化、索引相关、SQL 相关、表设计和其他几个方面。 在物理模型优化方面,需要合理分配 SGA...
在 Oracle 非归档模式下,丢失全部联机日志文件后,数据库无法启动,需要进行处理以恢复数据库。以下是处理方法的详细步骤和注意事项: 第一步:备份数据文件和参数文件 在进行任何处理前,首先需要备份数据文件和...
- `DB_FILE_MULTIBLOCK_READ_COUNT`:决定了一次I/O操作可以读取的数据块数量,优化了多块读性能。 - `LOG_BUFFER`:定义了redo log缓冲区的大小,影响redo日志写入的速度。 - `DB_BLOCK_SIZE`:数据库的默认块...