Welcome 微信登录
编程资源 图片资源库 蚂蚁家优选

首页 / 数据库 / MySQL / Oracle 11g Debian设置手记

在Linux下安装Oracle果然是好麻烦,先是要下载一坨库。因为用的是Testing的Debian,而安装用到的包大多都是old stable的,一般是在port里找不到的,都要在Debian的网站上手工搜索,有些包还有依赖的包,于是顺藤摸瓜都要下下来。主要参考的手册是网上流传比较多的一个pdf文档。唯一与文档安装不同的是,我在安装的时候选择了直接配置一个数据库实例,界面有所不同。pdf也提供了所有依赖的包,虽然不是oracle声明的版本(那些也太老了,gcc3.3啊libstdc++5啊什么的都出来了叫= =),不过确实可用,但是我不知道我哪里一个库出了问题,在安装过程中还是跳了一个错误,不过好像目前还没发现有问题。然后就是数据库的设置问题了。像Windows下都傻瓜式设置好了,这里还要自己再重新设置一下。1、在.profile里要填好$ORACLE_HOME  $ORACLE_BASE  $ORACLE_SID,这些一定要与安装的时候的参数一致喔。2、然而就在我第一次用sqlplus,scott用户登录的时候,就报错了
ORA-01034: ORACLE not available
ORA-27101: shared memory realm does not exist
Linux Error: 2: No such file or directory
Process ID: 0
Session ID: 0 Serial number: 0
网上查了一下,应该是数据库实例没有启动,于是我就dbstart $ORACLE_HOME,但是
ORACLE_HOME_LISTNER is not SET, unable to auto-start Oracle Net Listener
我只好先sqlplus / as sysdba,然后在startup。3、listener.ora的设置。这里也颇费周章,不知道为什么一开始没有设置好,反正原先只有
LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
    )
  )
这明显是不可能起得来的。所以在前面添加了几行
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = /var/oracle/product/11.2.0/db_1)
      (PROGRAM = extproc)
    )
    (SID_DESC =
      (GLOBAL_DBNAME = orcl.styx)
      (ORACLE_HOME = /var/oracle/product/11.2.0/db_1)
      (SID_NAME = orcl.styx)
    )
  )
于是这番,然后把之前的那个TCP连接的HOST改成数据库主机的IP,就可以远程访问数据库了。4、我在客户端上用sqldeveloper连接数据库主机的sys用户,总是提示用户名密码不正确,我检查了好几遍依然不见好转,忽然在网上看到,密码文件要跟数据库实例的名字一致,于是找到$ORACLE_HOME/dbs/,看了下文件名,密码文件应该就是orapworcl没错了,orapw就是密码文件的前缀,orcl应该是个实例名……可是我的实例叫orcl.styx啊,估计就是这里的问题了!
$ cp orapworcl orapworcl.styx
然后在sqlplus / as sysdba里面
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.Total System Global Area  849530880 bytes
Fixed Size                  1339824 bytes
Variable Size             499125840 bytes
Database Buffers          343932928 bytes
Redo Buffers                5132288 bytes
Database mounted.
Database opened.
SQL> 然后就可以正常使用远程访问了,如果不修改,可以用除了sysdba之外的帐号访问,比如scott之类,但是sysdba会被提示密码错误。 好像遇到的就这些问题吧,还有就是不能自己启动,要自己手动startup,然后dbstart也不能用,不知道怎么回事。Oracle 10g导入DMPLinux与Windows下QT中使用MySQL中文乱码解决方法相关资讯      Oracle教程 
  • Oracle中纯数字的varchar2类型和  (07/29/2015 07:20:43)
  • Oracle教程:Oracle中查看DBLink密  (07/29/2015 07:16:55)
  • [Oracle] SQL*Loader 详细使用教程  (08/11/2013 21:30:36)
  • Oracle教程:Oracle中kill死锁进程  (07/29/2015 07:18:28)
  • Oracle教程:ORA-25153 临时表空间  (07/29/2015 07:13:37)
  • Oracle教程之管理安全和资源  (04/08/2013 11:39:32)
本文评论 查看全部评论 (0)
表情: 姓名: 字数