欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > 数据库 >内容正文

数据库

oracle连续状态相同,数据库共有三种状态:quiesce、resrict、suspend

发布时间:2025/3/8 数据库 47 豆豆
生活随笔 收集整理的这篇文章主要介绍了 oracle连续状态相同,数据库共有三种状态:quiesce、resrict、suspend 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

数据库共有三种状态:quiesce、resrict、suspend

一、quiesce模式

首先来说说数据库的静默状态

静默状态是指数据库中只存在sys和system用户建立的活动会话。只有dba能继续操作数据库。

此状态下可以进行一些在非静默状态下执行可能存在不安全因素的特殊操作。

对于必须持续运行的系统,在不关闭数据库就能执行某些特殊操作的功能十分重要。

静默状态下数据库资源管理器(database resource manager)将阻止sys、system用户以外的用户提交操作。

进入静默状态的方法为:

alter system quiesce restricted;(sys或system用户执行)

进入静默模式的过程为:数据库资源管理器控制所有实例,阻止非活动会话恢复为活动状态。普通用户无法执

行新的事务、查询、数据提取和pl/sql过程。如果一个查询是由多个连续的 OCI 数据提取操作执行的,Oracle

不会等待所有的数据提取全部结束。Oracle 只会等待当前的数据提取结束并阻塞之后的数据提取。Oracle 还

会等待所有拥有共享资源的会话(SYS 及 SYSTEM 用户的资源除外)释放资源。上面提到的所有等待都结束之

后,Oracle 可以将数据库置为静默状态,并结束 QUIESCE RESTRICTED 语句。

如果数据库的某个实例是在共享服务模式(shared server mode)下运行的,Oracle 通过数据库资源管理器(

Database Resource Manager)阻止用户(SYS 及 SYSTEM 用户除外)登录到此实例。如果实例运行在专用服务

模式(dedicated server mode)下,Oracle 不会对此实例的用户登录进行限制。

静默状态恢复到正常状态方法为:

alter system unquiesce

可以通过v$instance等视图得到数据库状态。

具体实例为:

Microsoft Windows XP [版本 5.1.2600]

(C) 版权所有 1985-2001 Microsoft Corp.

D:\Documents and Settings\tian>set oracle_sid=test_database

D:\Documents and Settings\tian>sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - Production on 星期五 10月 19 09:19:50 2012

Copyright (c) 1982, 2002, Oracle Corporation.  All rights reserved.

SQL> conn /as sysdba

已连接。

SQL> alter system quiesce restricted

2  ;

alter system quiesce restricted

*

ERROR 位于第 1 行:

ORA-25507: 没有使资源管理器一直处于打开状态

//如果是9i,那么必须设置resource_limit参数为true,并设置resource_manager_plan参数指向一个资源计划

SQL> alter system set resource_manager_plan='SYSTEM_PLAN' scope=spfile sid='JLRP

S';

//由于数据库没有开启资源管理器,无法执行这个操作。需要开启后重启才生效。

系统已更改。

SQL> shutdown immediate;

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup

ORACLE 例程已经启动。

Total System Global Area  126950220 bytes

Fixed Size                   453452 bytes

Variable Size             109051904 bytes

Database Buffers           16777216 bytes

Redo Buffers                 667648 bytes

数据库装载完毕。

数据库已经打开。

SQL> alter system quiesce restricted;

系统已更改。

SQL> conn

^C

//此处证明静默模式下其他用户不能登录数据库

D:\Documents and Settings\tian>sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - Production on 星期五 10月 19 09:32:07 2012

Copyright (c) 1982, 2002, Oracle Corporation.  All rights reserved.

SQL> conn /as sysdba

已连接。

SQL> select * from v$instance;

INSTANCE_NUMBER INSTANCE_NAME

--------------- ----------------

HOST_NAME

----------------------------------------------------------------

VERSION           STARTUP_TI STATUS       PAR    THREAD# ARCHIVE LOG_SWITCH_

----------------- ---------- ------------ --- ---------- ------- -----------

LOGINS     SHU DATABASE_STATUS   INSTANCE_ROLE      ACTIVE_ST

---------- --- ----------------- ------------------ ---------

1 test_database

TIANLEI

9.2.0.1.0         19-10月-12 OPEN         NO           1 STARTED

ALLOWED    NO  ACTIVE            PRIMARY_INSTANCE   QUIESCED//处于静默状态

SQL> alter system unquiesce;

系统已更改。

SQL> conn scott/tiger

已连接。

SQL> select * from v$instance;

INSTANCE_NUMBER INSTANCE_NAME

--------------- ----------------

HOST_NAME

----------------------------------------------------------------

VERSION           STARTUP_TI STATUS       PAR    THREAD# ARCHIVE LOG_SWITCH_

----------------- ---------- ------------ --- ---------- ------- -----------

LOGINS     SHU DATABASE_STATUS   INSTANCE_ROLE      ACTIVE_ST

---------- --- ----------------- ------------------ ---------

1 test_database

TIANLEI

9.2.0.1.0         19-10月-12 OPEN         NO           1 STARTED

ALLOWED    NO  ACTIVE            PRIMARY_INSTANCE   NORMAL//恢复正常状态了

在设置静默状态时,正在登陆的普通用户被挂起,无法进行操作了。

而当状态改为正常后,普通用户的会话继续执行。

以上的实验是在oracle9i环境下操作的,在10g中,必须开启数据库资源管理器的限制已经被取消了。因此,向

上面实验中的操作其实是没意义的,因为静默状态和restricted状态的区别就在于其不用停掉数据库而执行操

作。

在RAC环境下某个节点设置了静默状态后,其他节点也是能够监测到的。

二、restrict模式:

直接实验

1.会话1中进行操作:

SQL> startup restrict

ORACLE 例程已经启动。

Total System Global Area  126950220 bytes

Fixed Size                   453452 bytes

Variable Size             109051904 bytes

Database Buffers           16777216 bytes

Redo Buffers                 667648 bytes

数据库装载完毕。

数据库已经打开。

SQL> select * from v$instance;

INSTANCE_NUMBER INSTANCE_NAME

--------------- ----------------

HOST_NAME

----------------------------------------------------------------

VERSION           STARTUP_TI STATUS       PAR    THREAD# ARCHIVE LOG_SWITCH_

----------------- ---------- ------------ --- ---------- ------- -----------

LOGINS     SHU DATABASE_STATUS   INSTANCE_ROLE      ACTIVE_ST

---------- --- ----------------- ------------------ ---------

1 jlrps

TIANLEI

9.2.0.1.0         19-10月-12 OPEN         NO           1 STARTED

RESTRICTED NO  ACTIVE            PRIMARY_INSTANCE   NORMAL

SQL> create user tes1 identified by tes1;

用户已创建

SQL> grant create session to tes1;

授权成功。

2.会话2中进行操作:

SQL> conn tes1/tes1

ERROR:

ORA-01035: ORACLE only available to users with RESTRICTED SESSION privilege

SQL> conn scott/tiger

已连接。

SQL> select * from emp;

EMPNO ENAME      JOB              MGR HIREDATE          SAL       COMM

---------- ---------- --------- ---------- ---------- ---------- ----------

DEPTNO

----------

7369 SMITH      CLERK           7902 17-12月-80        800

20

7499 ALLEN      SALESMAN        7698 20-2月 -81       1600        300

30

7521 WARD       SALESMAN        7698 22-2月 -81       1250        500

30

……//结果省略,scott用户拥有dba角色(RESTRICTED SESSION privilege)

3.会话1中操作:

SQL> shutdown immediate;

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup

ORACLE 例程已经启动。

Total System Global Area  126950220 bytes

Fixed Size                   453452 bytes

Variable Size             109051904 bytes

Database Buffers           16777216 bytes

Redo Buffers                 667648 bytes

数据库装载完毕。

数据库已经打开。

SQL>

4.会话2中操作:

SQL> conn tes1/tes1

已连接。

可以看到,restrict模式需要重启数据库,且拥有RESTRICTED SESSION privilege的用户在此模式可以登录系

统进行操作。

而quiese模式就死板多了,除了sys、system都不行,不过也更安全。

三、suspend模式:

面向所有用户,限制I/O操作。当我们需要进行物理读操作时,会话会暂停。

SQL> shutdown immediate

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup

ORACLE 例程已经启动。

Total System Global Area  126950220 bytes

Fixed Size                   453452 bytes

Variable Size             109051904 bytes

Database Buffers           16777216 bytes

Redo Buffers                 667648 bytes

数据库装载完毕。

数据库已经打开。

SQL> alter system suspend;

系统已更改。

SQL> select * from scott.emp;

//一直没有查询结果。

这个问题还真不会解决了。将数据库重启再操作还是无效的

说到了数据库启停,再复习一下:

启动类型:

startup nomount  --启动实例

startup mount    --启动实例、装载

startup (normal) --启动实例、装载、打开数据库

startup pfile='xx/xx/xx.ora'  --参数文件启动

startup restrict --限制模式,无restricted session权限的用户无法登录

startup force    --强制启动,正常启动不了才用

startup open recover --启动实例,装载数据库和启动完全介质恢复

停止类型:

shutdown (normal) --正常模式

shutdownimmediate --立即模式

shutdown abort    --中断模式,再次启动时可能需要恢复

alter system quiese restricted; --停顿数据库,只有sys、system用户可操作

挂起数据库

--暂停对数据文件和控制文件的所有IO,可以在无IO干扰情况先进行备份

--挂起命令可以挂起数据库而并不指定一个实例

ALTER SYSTEM SUSPEND;

--恢复到非挂起状态

ALTER SYSTEM RESUME;

--查看挂起状态

SELECT DATABASE_STATUS FROM V$INSTANCE;

总结

以上是生活随笔为你收集整理的oracle连续状态相同,数据库共有三种状态:quiesce、resrict、suspend的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。