在RedHat9上安装oracle 9i

费了好大功夫才装好了oracle,在这里记录一下,以备以后参考。:)

写这个东东的大部分的参考文章和参考数字及各种数据均来自互联网,我谨代表我个人对免费提供这些材料的作者表示由衷的感谢。


先来总结一下经验:

1,机子配置要高点,内存至少为256M,我用的是VMware 虚拟的Linux系统,内存分配256M,速度一般。
2,linux系统安装成英文版,用中文版会出现安装乱码的问题。
3,安装前的更项配置参数比较重要,很容易出错,应当格外小心。


安装过程:
一 检查系统中所需要的软件包,具体在网上搜索,我安装的linux系统是安装了所有的包,所以没有这个问题。

二 配置操作
1.设置内核参数,调节信号灯及共享内存:
Oracle9i使用Linux的共享内存、交换区等资源进行工作,如果系统的的内核参数设置不能满足Oracle的需求,那么在安装或使用过程就会出现各种问题,因此建议配置或修改这些系统内核的参数。

打开/etc/sysctl.conf 文件,将下列数据写入到sysctl.conf的末尾并保存:

kernel.shmmax = 536870912
kernel.shmmni = 4096
kernel.shmall = 2097152
kernel.sem = 250 32000 100 128
fs.file-max = 65536
net.ipv4.ip_local_port_range = 1024 65000

其中,kernel.shmmax是共享内存段最大尺寸,kernel.shmmni是共享内存段最小尺寸。进入目录/proc/sys/kernel,可分别用命令:
#cat shmmax
#cat shmmni
#cat shmall

查看 kernel.shmmax 、kernel.shmmni、kernel.shmall的数值。

kernel.shmmax的计算方法为:
kernel.shmmax = 1024*1024*RAM(M)/2 (至少)。

用命令:
#cat sem

可以查看kernel.sem的数值。其中, 250 是参数SEMMSL的值,32000是参数SEMMNS的值, 100是参数SEMOPM的值,而128则是参数SEMMNI的值。


接下来,打开/etc/security/limits.conf文件,将下列数据添加到 limits.conf的末尾并保存:
oracle soft nofile 65536
oracle hard nofile 65536
oracle soft nproc 16384
oracle hard nproc 16384

这是设置Oracle对文件的要求。

当对/etc/sysctl.conf 文件和/etc/security/limits.conf文件修改并保存完毕后,请重新启动(reboot)redhat Linux9系统,这样设置的这些参数才能生效。

如果此时进入到/proc/sys/kernel路径,用上述的命令再次查看,就会看到设置的参数已经生效。

2.创建Oracle用户帐号和安装目录
如有以前安装过Oracle 8i for Linux的经验,应该知道在安装Oracle之前须先在Linux操作系统下新增一个名为oracle的用户,以及一个oracle DBA所专用的群组。Oracle在安装和使用中需要用特定用户(非root用户),按照Oracle的标准说明是需要添加三个专门用户和用户组。为了简单方便安装,我们建立两个组,一个负责安装,另一个负责管理,并把Oracle的安装和使用归到一个特定用户来完成。

以root用户登录,进行如下操作,建立两个组(dba组与oinstall组)和一个Oracle用户,操作命令如下:
#groupadd dba
#groupadd oinstall
#useradd –g oinstall –G dba oracle
#passwd oracle
设置oracle的密码。

Oracle安装的位置应遵守OFA( Optimal Flexible Architecture )规范。Oracle9i的典型安装需要至少两个安装点:一个安装基本的运行程序,一个为存放数据库,并要确保oracle用户对这两个目录具有可写的权限。

运行下面的命令,创建Oracle的安装点(mount point):

#mkdir /opt/oracle9i
#mkdir /opt/oracle9i/product
#mkdir /opt/oracle9i/product/9.2.0
#chown –R oracle.oinstall /opt/oracle9i
#mkdir /var/opt/oracle9i
#chown oracle.dba /var/opt/oracle9i
#chmod 755 /var/opt/oracle9i

3.设置环境变量
以oracle用户身份登录,打开编辑/home/oracle/.bash_profile文件,在文件末尾添加如下数据行并保存:
export LD_ASSUME_KERNEL=2.4.1
export ORACLE_BASE=/opt/oracle9i
export ORACLE_HOME=/opt/oracle9i/product/9.2.0
export ORACLE_SID= ORCL
export ORACLE_TERM=xterm
export TNS_ADMIN=$ORACLE_HOME/network/admin
export LANG=en_US
export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib
export LD_LIBRARY_PATH
export PATH=$PATH:$ORACLE_HOME/bin

CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
CLASSPATH=$CLASSPATH:$ORACLE_HOME/network/jlib
export CLASSPATH
#export DISPLAY=hostIP:0.0

这样oracle用户每次登录时都带有这些环境变量。

编辑并保存/home/oracle/.bash_profile文件后,建议先注销退出oracle用户,然后再以oracle用户身份重新登录,这样可以测试一下配置的环境变量是否出错。

三 安装过程:
1.对安装文件进行解压
$gunzip -dc lnx_920_disk1.cpio.gz | cpio -div
$gunzip -dc lnx_920_disk2.cpio.gz | cpio -div
$gunzip -dc lnx_920_disk3.cpio.gz | cpio -div

等三个文件包全部解压完毕后,生成3个安装文件夹,名称分别为Disk1、Disk2、Disk3。

2.安装过程

以oracle用户登录,进行安装。进入到/setup/Disk1目录,执行如下命令:

#cd /Disk1
#./runInstaller

运行等一会后,就会出现Oracle Universal Installer(OUI)的图形界面,按照提示一步步点击“Next”安装即可。

此时Oracle Universal Installer会生成一个建立Oracle Inventory所用的orainstRoot.sh文件,弹出一个提示框,需要用root身份来执行这个/orainstRoot.sh文件,此时可以再开启一个新的终端窗口(Terminal),按照提示窗口所写的目录路径来以root用户来执行orainstRoot.sh。等执行完毕后再回到提示窗口,按下“Continue”按钮继续安装。

当遇到要输入“全局数据库名(Global Database Name)和数据库SID”的窗口时,会发现数据库的SID已经按照环境变量中的设置的ORACLE_SID=YOUR_SID显示出来了。只需要把全局数据库名输入即可。

接下来的安装均按照默认设置来进行。

当遇到设置数据库的字符集的窗体时,不要选择默认的数据库字符类型。字符集(Character Set)是建立Oracle数据库时最重要的一项设定,如果设定的不正确,很可能造成在使用中无法正常存取中文数据。在这里我们最好选择第三个选项的下拉框,选择Simplifiled Chinese ZHS16GBK,按Next进入下一步。

在Oracle Universal Installer开始复制安装文件之前,会显示要安装的Oracle9i产品摘要,在确认无误后按下“Install”按钮就会开始安装了,这将是一个较长时间的过程,当然了,这和你机器的配置、运算速度和内存空间大小等都有关系。

在接下来的安装过程中会出现2个错误,我所看到的网上的文章中也都说到了,我在这里也描述一下:

第一个错误是Linking阶段的,当安装进度到69%的时候出现的,Oracle Universal Installer提示关于这个文件“/soft/oracle/network/lib/ins_oemagent.mk”有问题,这时我们可以暂时不要去管它,选择“ignore”,将其忽略,等整个安装过程完成以后,再来解决这个问题。(我看了很多资料上都是这么干的,于是乎,我也这么干。唉,真搞不明白 :( 在RH7下安装Oracle8i的时候也是会出现很多个错误提示的。)

第二错误也是Linking阶段,当安装进度到84%的时候出现的,Oracle Universal Installer提示“Error in invoking target install of makefile $ORACLE_HOME/ctx/lib/ins_ctx.mk”出现错误。
这个时候就不要选择忽略了,可以修复这个错误,打开$ORACLE_HOME/ctx/lib/env_ctx.mk文件进行如下编辑,将光标定位到第1365行,也就是“INSO_LINK =”这一行,然后把“$(LDLIBFLAG)dl”这句加入到“INSO_LINK=-L$(CTXLIB)$ (LDLIBFLAG)m”的后面,修改后成为这个样子:

 INSO_LINK = -L$(CTXLIB) $(LDLIBFLAG)m $(LDLIBFLAG)dl
$(LDLIBFLAG)sc_ca $(LDLIBFLAG)sc_fa $(LDLIBFLAG)sc_ex
$(LDLIBFLAG)sc_da $(LDLIBFLAG)sc_ut $(LDLIBFLAG)sc_ch
$(LDLIBFLAG)sc_fi $(LLIBCTXHX) $(LDLIBFLAG)c
-Wl,-rpath,$(CTXHOME)lib $(CORELIBS) $(COMPEOBJS)

然后保存$ORACLE_HOME/ctx/lib/env_ctx.mk文件,回到错误提示窗口,按“retry”按钮即可继续安装。

当数据库建立完毕,等安装程序将所有文件复制到系统之后,Oracle Universal Installer还会弹出一个提示信息窗口要求以root身分执行运行root.sh程序 ,root.sh位于 ORACLE_HOME 所指向的目录下。这个时候要再开启一个新的终端窗口(Terminal),以oracle用户的身份登录进去,运行以下的命令操作命令如下:

#su root
#cd /opt/oracle9i/product/9.2.0
#./root.sh

运行后系统会提示如下信息:
Running Oracle9 root.sh script...
/nThe following environment variables are set as:
ORACLE_OWNER= oracle
ORACLE_HOME= /opt/Oracle9i/product/9.2.0

Enter the full pathname of the local bin directory: [/usr/local/bin]

这里填写默认的目录即:/opt/oracle9i/product/9.2.0/bin即可。


等这里执行完毕后,如果一切正常,OUI会出现“The Installation Of Oracle9i Database Was successful.”的提示信息,此时说明Oracle920数据库在redhat Linux9上安装成功了!可真不容易啊! *_^

如果此时还需要进行其它内容的安装,按下“Next Install”按钮可进行安装,否则,请按下“Exit”按钮退出OUI安装。

最后一步是修复一下刚才的那个错误,即Linking阶段安装到69%的时候出现的“/soft/oracle/network/lib/ins_oemagent.mk”这个错误。

以Oracle用户执行如下命令:
 
#cd $ORACLE_HOME/network/lib
#make -f ins_net_client.mk install
 
然后编辑$ORACLE_HOME/ctx/lib/ins_ctx.mk 文件的第13-14行,由:

ctxhx: $(CTXHXOBJ)
$(LINK) $(CTXHXOBJ) $(INSO_LINK)
改为:
  ctxhx: $(CTXHXOBJ)
  $(LINK) -ldl $(CTXHXOBJ) $(INSO_LINK)
 
保存$ORACLE_HOME/ctx/lib/ins_ctx.mk文件。

然后执行如下命令:

#make -f $ORACLE_HOME/ctx/lib/ins_ctx.mk install

将错误修复完成。

到此为止,Oracle920数据库在redhat Linux9上已经完全安装成功了。


四、Oracel9i的使用

安装完Oracle数据库后会自动启动,下面可以进行一下实际的操作。
以oracle用户身份登陆数据库,可一个终端窗口(Terminal),进行如下的操作:

[oracle@Linux oracle]$ sqlplus /“as sysdba”

出现如下字符提示:
――――――――――――――――――――――――――――――
SQL*Plus: Release 9.2.0.1.0 - Production on Thu Feb 26 15:53:31 2004
Copyright(c) 1982,2002, Oracle Corporation. All rights reserved.

Connected to:
Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production
With the Partitioning OLAP and Oracle Data Mining options
JServer Release 9.2.0.1.0 – Production

SQL>
――――――――――――――――――――――――――――――

运行shudown命令关闭数据库,操作如下:
――――――――――――――――――――――――――――――
SQL> shutdown
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL>
――――――――――――――――――――――――――――――

启动Oracle 9i 数据库,操作如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$ sqlplus "/ as sysdba"

SQL*Plus: Release 9.2.0.1.0 - Production on Thu Feb 26 16:00:59 2004
Copyright (c) 1982,2002, Oracle Corporation. All rights reserved.
Connected to an idle instance.

SQL> startup

Oracle instance started.

Total System Global Area 235999352 bytes
Fixed Size 450680 bytes
Variable Size 201326592 bytes
Database Buffers 33554432 bytes
Redo Buffers 667648 bytes
Database mounted.
Database opened.
SQL>
――――――――――――――――――――――――――――――

启动Oracle 9i监听程序,操作如下:
说明:Oracle的监听程序主要是为客户端的连接提供接口的。
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$ lsnrctl

LSNRCTL for Linux: Version 9.2.0.1.0 - Production on 26-FEB-2004 16:10:17
Copyright (c) 1991, 2002, Oracle Corporation. All rights reserved.
Welcome to LSNRCTL, type "help" for information.

LSNRCTL> start
Starting /opt/oracle9i/product/9.2.0/bin/tnslsnr: please wait...

TNSLSNR for Linux: Version 9.2.0.1.0 - Production
System parameter file is /opt/oracle9i/product/9.2.0/network/admin/listener.ora
Log messages written to /opt/oracle9i/product/9.2.0/network/log/listener.log
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC)))
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=Linux)(PORT=1521)))

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC)))
STATUS of the LISTENER
------------------------
Alias LISTENER
Version TNSLSNR for Linux: Version 9.2.0.1.0 - Production
Start Date 26-FEB-2004 15:28:23
Uptime 0 days 0 hr. 0 min. 0 sec
Trace Level off
Security OFF
SNMP OFF
Listener Parameter File /opt/oracle9i/product/9.2.0/network/admin/listener.ora

Listener Log File /opt/oracle9i/product/9.2.0/network/log/listener.log

Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC)))
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=Linux)(PORT=1521)))
Services Summary...
Service "ORCL.SOFT" has 1 instance(s).
Instance "ORCL", status UNKNOWN, has 1 handler(s) for this service...
Service "PLSExtProc" has 1 instance(s).
Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
The command completed successfully
LSNRCTL>
――――――――――――――――――――――――――――――


关闭Oracle 9i监听程序,操作如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$ lsnrctl

LSNRCTL for Linux: Version 9.2.0.1.0 - Production on 26-FEB-2004 16:15:28
Copyright (c) 1991, 2002, Oracle Corporation. All rights reserved.
Welcome to LSNRCTL, type "help" for information.

LSNRCTL> stop
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC)))
The command completed successfully
LSNRCTL>
――――――――――――――――――――――――――――――


启动Oracle Web Server,操作如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$cd $Oracle_HOME/Apache/Apache/bin
[oracle@Linux oracle]$./startJServ.sh
/opt/oracle9i/product/9.2.0/Apache/Apache/bin/apachectl start: httpd started
――――――――――――――――――――――――――――――


启动Oracle Web Server后默认的端口号是7777,在客户端的浏览器地址栏中输入

http://xxx.xx.xxx.xxx:7777/

其中,xxx.xx.xxx.xxx代表IP地址,或用网络机器名也可。如果浏览器出现 ORACLE HTTP Server的页面,则说明Oracle Web Server运行正常。


关闭Oracle Web Server, 操作如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$cd $Oracle_HOME/Apache/Apache/bin
[oracle@Linux oracle]$./stopJServ.sh
/opt/oracle9i/product/9.2.0/Apache/Apache/bin/apachectl stop: httpd stopped
――――――――――――――――――――――――――――――

启动Database Configuration Assistant,操作命令如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$dbca&
――――――――――――――――――――――――――――――

启动Oracle Net Configuration Assistant,操作命令如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$netca&
――――――――――――――――――――――――――――――

启动Enterprise Manager Configuration Assistant,操作命令如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$emca&
――――――――――――――――――――――――――――――



oemapp相关命令,如下:
――――――――――――――――――――――――――――――
[oracle@Linux oracle]$oemapp dbastudio
[oracle@Linux oracle]$oemapp console
[oracle@Linux oracle]$oemapp txtmgr
[oracle@Linux oracle]$oemapp ocmcli
[oracle@Linux oracle]$oemapp lmviewer
[oracle@Linux oracle]$oemapp ocm
[oracle@Linux oracle]$oemapp esmsrv
[oracle@Linux oracle]$oemapp opm
[oracle@Linux oracle]$oemapp cpta
[oracle@Linux oracle]$oemapp esm
[oracle@Linux oracle]$oemapp jdbctest
[oracle@Linux oracle]$oemapp oemutil
[oracle@Linux oracle]$oemapp topsess
[oracle@Linux oracle]$oemapp dataguard
[oracle@Linux oracle]$oemapp worksheet
[oracle@Linux oracle]$oemapp cp
[oracle@Linux oracle]$oemapp sdoadvisor
[oracle@Linux oracle]$oemapp pm
――――――――――――――――――――――――――――――
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值