oracle启动阶段

oracle 启动阶段

成都创新互联专注于鄠邑网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供鄠邑营销型网站建设,鄠邑网站制作、鄠邑网页设计、鄠邑网站官网定制、微信小程序定制开发服务,打造鄠邑网络公司原创品牌,更为您提供鄠邑网站排名全网营销落地服务。

启动时分成三个步骤:

1.nomount阶段,该阶段是实例启动,根据参数文件进行系统分配内存,启动后台进程。

2.mount阶段,根据控制文件来进行数据文件和日志文件的名称和位置检查,把实例和数据库连接起来。

3.open阶段,就是数据库打开阶段,打开是就需要检查文件是否正常,有没有发生文件丢失或者不一致的情况,丢失则报错,不一致则进行实例恢复。

停止数据库:

sysdba & sysoper 才可以启停数据库!

查看数据库的当前状态:

select status from v$instance;

停止数据库:

shutdown normal = shutdown

1.新的连接不允许建立

2.等待查询结束

3.等待事务结束

4.产生检查点(将buffer cache里面的脏数据写盘)

5.关闭数据文件

6.关闭控制文件

7.关闭实例(停止所有的后台进程,释放共享内存段)

shutdown transactional

1.新的连接不允许建立

*2.不等待查询结束

3.等待事务结束

4.产生检查点(将buffer cache里面的脏数据写盘)

5.关闭数据文件

6.关闭控制文件

7.关闭实例(停止所有的后台进程,释放共享内存段)

shutdown immediate (最常用的选项)

1.新的连接不允许建立

1.新的连接不允许建立

*2.不等待查询结束

*3.事务被回退

4.产生检查点(将buffer cache里面的脏数据写盘)

5.关闭数据文件

6.关闭控制文件

7.关闭实例(停止所有的后台进程,释放共享内存段)

前三种停库参数,数据库是干净的,重新启动时不需要实例恢复!

shutdown abort (相当于拔电源)

重新启动时需要实例恢复! --> smon

ps -ef | grep pmon

ipcs -sm

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

启动数据库:

分三个阶段

1.分配实例 nomount:

需要参数文件

需要保存trace文件的目录(实例管理的目录)

ps -ef | grep pmon

ipcs -sm

2.加载控制文件 mount

只需要控制文件

3.加载联机日志和数据文件 open

需要联机日志和数据文件

startup = startup open

三个台阶连续启动

分阶段启动数据库:

启动数据库到第一阶段:nomount

startup nomount -->只启动实例(共享内存段和后台进程)

SQL> select status from v$instance;

STATUS

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

STARTED

启动数据库到第二阶段:mount

数据如果是shutdown状态:

startup mount

数据如果是STARTED状态:不能使用startup命令,只能使用修改数据库的命令

alter database mount;

SQL> select status from v$instance;

STATUS

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

MOUNTED

启动数据库到第三阶段:open

数据如果是shutdown状态:

startup

数据如果是STARTED状态:

alter database mount;

alter database open;

alter database open read only;

数据如果是MOUNTED状态:

alter database open;

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

startup 命令:

startup nomount

startup mount

startup open = startup

startup pfile='/home/oracle/initdemo.ora'

startup restrict

*startup force = shut abort + startup --> 强制重启(慎用)

conn / as sysdba

alter system enable restricted session;

alter system disable restricted session;

alter database mount;

alter database open;

alter database open read only; -->只能查询不能dml,可以写本地管理的temp表空间

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


分享名称:oracle启动阶段
文章源于:http://pwwzsj.com/article/pssjje.html