linux下oracle数据库服务和监听的启动停止

时间:2021-09-25 23:15:20

oracle数据库是重量级的,其管理非常复杂,将其在linux平台上的启动和关闭步骤整理一下。

安装完毕oracle以后,需要创建oracle系统用户,并在/home/oracle下面的.bash_profile添加几个环境变量:ORACLE_SID,ORACLE_BASE,ORACLE_HOME。比如:

export ORACLE_SID=test  export ORACLE_BASE=oracle_install_dir export ORACLE_HOME=xxx

启动步骤:注意$代表shell命令提示符,这里的oracle9.0以上版本。

  1. $ su - oracle
  2. $ sqlplus / nolog
  3. sql> conn / as sysdba
  4. sql> startup (一般不需要加参数,只要设置好环境变量)
  5. sql> quit (退出sql模式)
  6. $ lsnrctl start (启动监听器)关闭oracle
    1. $ lsnrctl stop(关闭监听器,在这之前,应该先关闭应用程序)
    2. $ sqlplus  /nolog
    3. sql>shutdown 其参数shutdown有四个参数,四个参数的含义如下:
      Normal 
      需要等待所有的用户断开连接
      Immediate 
      等待用户完成当前的语句
      Transactional 
      等待用户完成当前的事务
      Abort 
      不做任何等待,直接关闭数据库
      normal
      需要在所有连接用户断开后才执行关闭数据库任务,所以有的时候看起来好象命令没有运行一样!在执行这个命令后不允许新的连接
      immediate
      在用户执行完正在执行的语句后就断开用户连接,并不允许新用户连接。
      transactional 
      在拥护执行完当前事物后断开连接,并不允许新的用户连接数据库。
      abort 
      执行强行断开连接并直接关闭数据库。
      前三种方式不回丢失用户数据。第四种在不的已的情况下,不建议采用!

经常遇到的问题:

1)权限问题,解决方法,切换到oracle用户;

2)没有关闭监听器,解决方法:关闭监听器

3)有oracle实例没有关闭,解决办法:关闭oracle实例

 

4)环境变量设置不全,解决办法:修改环境变量

1、启动数据库:
oracle@suse92:~> sqlplus /nolog

SQL*Plus: Release 9.2.0.4.0 - Production on Fri Jan 20 02:29:37 2006

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

SQL> connect /as sysdba
Connected to an idle instance.
SQL> startup
ORACLE instance started.

Total System Global Area 135352820 bytes
Fixed Size 455156 bytes
Variable Size 109051904 bytes
Database Buffers 25165824 bytes
Redo Buffers 679936 bytes
Database mounted.
2
、关闭数据库:
oracle@suse92:~> sqlplus /nolog

SQL*Plus: Release 9.2.0.4.0 - Production on Fri Jan 20 02:29:37 2006

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

SQL> connect /as sysdba
Connected to an idle instance.
SQL> shutdwon abort;
3
、启动监听器
oracle@suse92:~> lsnrctl start
4
、停止监听器
oracle@suse92:~> lsnrctl stop
5
、查看监听器状态
oracle@suse92:~> lsnrctl

oracle数据库是重量级的,其管理非常复杂,将其在linux平台上的启动和关闭步骤整理一下。

安装完毕oracle以后,需要创建oracle系统用户,并在/home/oracle下面的.bash_profile添加几个环境变量:ORACLE_SID,ORACLE_BASE,ORACLE_HOME。比如:

export ORACLE_SID=test  export ORACLE_BASE=oracle_install_dir export ORACLE_HOME=xxx

启动步骤:注意$代表shell命令提示符,这里的oracle9.0以上版本。

  1. $ su - oracle
  2. $ sqlplus / nolog
  3. sql> conn / as sysdba
  4. sql> startup (一般不需要加参数,只要设置好环境变量)
  5. sql> quit (退出sql模式)
  6. $ lsnrctl start (启动监听器)关闭oracle
    1. $ lsnrctl stop(关闭监听器,在这之前,应该先关闭应用程序)
    2. $ sqlplus  /nolog
    3. sql>shutdown 其参数shutdown有四个参数,四个参数的含义如下:
      Normal 
      需要等待所有的用户断开连接
      Immediate 
      等待用户完成当前的语句
      Transactional 
      等待用户完成当前的事务
      Abort 
      不做任何等待,直接关闭数据库
      normal
      需要在所有连接用户断开后才执行关闭数据库任务,所以有的时候看起来好象命令没有运行一样!在执行这个命令后不允许新的连接
      immediate
      在用户执行完正在执行的语句后就断开用户连接,并不允许新用户连接。
      transactional 
      在拥护执行完当前事物后断开连接,并不允许新的用户连接数据库。
      abort 
      执行强行断开连接并直接关闭数据库。
      前三种方式不回丢失用户数据。第四种在不的已的情况下,不建议采用!

经常遇到的问题:

1)权限问题,解决方法,切换到oracle用户;

2)没有关闭监听器,解决方法:关闭监听器

3)有oracle实例没有关闭,解决办法:关闭oracle实例

4)环境变量设置不全,解决办法:修改环境变量

linuxoracle数据库服务和监听的启动停止

2007/10/23 19:33

1、启动数据库:
oracle@suse92:~> sqlplus /nolog

SQL*Plus: Release 9.2.0.4.0 - Production on Fri Jan 20 02:29:37 2006

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

SQL> connect /as sysdba
Connected to an idle instance.
SQL> startup
ORACLE instance started.

Total System Global Area 135352820 bytes
Fixed Size 455156 bytes
Variable Size 109051904 bytes
Database Buffers 25165824 bytes
Redo Buffers 679936 bytes
Database mounted.
2
、关闭数据库:
oracle@suse92:~> sqlplus /nolog

SQL*Plus: Release 9.2.0.4.0 - Production on Fri Jan 20 02:29:37 2006

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

SQL> connect /as sysdba
Connected to an idle instance.
SQL> shutdwon abort;
3
、启动监听器
oracle@suse92:~> lsnrctl start
4
、停止监听器
oracle@suse92:~> lsnrctl stop
5
、查看监听器状态
oracle@suse92:~> lsnrctl