看到很多文章都说Redhat7.0带的glibc有问题,装不上Oracle。后来又听说换个glibc的版本就可以,于是就想安装上用一用。有人说想安装Oracle,至少需要256M内存,还要修改共享内存大小,重新编译内核,创建4个mount点等,我都没有做,也安装上了(也可能只能用来学习,干不了什么大事)。下面的步骤忠实记录了整个安装过程。 |
1.机器配置 |
CPU: Intel Pentium III 668203 khz |
内存: 128M |
操作系统: Redhat7.0(完全安装) |
SWAP区: 256M |
安装shell: bash |
2.安装所需软件 |
Oracle8161_tar.gz(275M,文件较大,下载前做好心理准备,我第一次花了一整天弄下来却是个坏的,展不开,差点气死!只好又下载了一次,还不如去买张盗版光盘呢)。下载网址: |
ftp://166.111.136.3/pub/DataBase/Oracle/oracle8161.tar.gz(清华酒井) |
http://technet.oracle.com/software/products/oracle8i/software/index.htm |
glibc2.1版本(GNU C Library,18M)下载地址: |
ftp://ftp.kernel.org/pub/software/libs/glibc/hjl/sdk/2.1/i386-glibc-2.1-linux.tar.gz |
下载后都放到了/backup目录 |
3.安装glibc 2.1包 |
RedHat7.0安装的是glibc2.2。Oracle 8I不能使用glibc 2.2进行编译,而需要glibc2.1的SDK。 |
以root帐号登录 |
[root@only_you /root] cd / |
[root@only_you /] tar zxvf /backup/i386-glibc-2.1-linux.tar.gz |
隐藏/usr/bin 目录下的gcc,cc,ld,避免被Oracle installer使用 |
[root@only_you /] cd /usr/bin |
[root@only_you bin] mkdir saved |
[root@only_you bin] mv gcc cc ld saved |
[root@only_you bin] ln -s /usr/i386-glibc-2.1-linux/bin/i386-glibc21-linux-gcc gcc |
[root@only_you bin] ln -s gcc cc |
[root@only_you bin] ln -s /usr/i386-glibc-2.1-linux/bin/i386-glibc21-linux-ld ld |
隐藏/usr/lib目录下的libc.so,libdl.so,libm.so和libpthread.so文件,避免被Oracle installer使用 |
[root@only_you bin] cd ../lib |
[root@only_you lib] mkdir saved |
[root@only_you lib] mv libc.so libdl.so libm.so libpthread.so saved |
[root@only_you lib] mv libc.a libdl.a libm.a libpthread.a saved |
4.创建oracle帐号 |
以root帐号登录,开启一个terminal窗口,创建oracle帐号 |
[root@only_you /root]useradd oracle |
[root@only_you /root]passwd oracle (设置oralce帐号的密码) |
系统自动创建了/home/oracle目录,属主为oracle。我的Oracle就准备装在此目录下。安装文档上说要创建dba组,我看就免了。 |
5.解压缩oracle8161_tar.gz |
以root帐号登录,执行: |
[root@only_you /root] cd /backup |
[root@only_you /backup] tar zxvf oracle8161_tar.gz |
在/backup/目录下生成Oralce8iR2目录,内含解包后的文件 |
6.设置oracle用户环境 |
使用oracle帐号登录,开启terminal窗口, 使用文本编辑器打开/home/oracle/.bash_profile最后加入如下环境变量的设置行: |
ORACLE_HOME=/home/oracle; export ORACLE_HOME |
LD_LIBRARY_PATH=/home/oracle/lib; export LD_LIBRARY_PATH |
ORACLE_BASE=/home/oracle; export ORACLE_BASE |
ORACLE_SID=ORCL; export ORACLE_SID |
ORA_NLS33=/home/oracle/ocommon/nls/admin/data; export ORA_NLS33 |
NLS_LANG=american_america.zhs16cgb231280;export NLS_LANG |
#其中,zhs16cgb231280是简体中文的代码。也是数据库的字符集。 american_america是区域代码,关系不大。 |
Log out,重新以oracle帐号登录,键入env指令查看刚才设置的环境变量。 |
[oracle@only_you oracle]env |
7.创建oracle数据文件目录 |
我想把数据文件放在/home/oracle/data目录下,于是 |
[oracle@only_you oracle] mkdir data |
8.安装Oracle 8i 数据库软件 |
(1)用oracle帐号登录,进入Xwindows,开启terminal窗口 |
(2)[oracle@only_you oracle] cd /backup/Oracle8iR2 |
(3)[oracle@only_you Oralcle8iR2]./runInstaller |
(4)出错,显示信息为 |
Xlib: connection to “:0.0” refused by server |
Xlib: Client is not authorized to connect to server |
说明xhost没有配置 |
(5)设置xhost |
开启一个新的terminal窗口 |
[oracle@only_you oracle]su - (输入root密码) |
[root@only_you /root] xhost + |
保留此窗口 |
(6)在oracle用户窗口下继续安装 |
[oracle@only_you Oralcle8iR2] ./runInstaller |
在出现的基于JAVA的Oracle installer界面上,点击Next。 |
(7) 在File Locations界面上,检查Destination Path为/home/oracle,点击Next |
(8)在Unix Group Name窗口中,键入"oracle",点击Next; |
(9)一个窗口会弹出,要求以root身份运行/home/oracle/orainstRoot.sh |
(10)切换到刚才保留的root用户窗口 |
[root@only_you /root] cd /home/oracle |
[root@only_you oracle]./orainstRoot.sh |
(11)返回刚才弹出的窗口,点击Retry。 |
(12)在出现的"Available products"窗口上选择"Oracle8I enterprise edition8.1.6.1.0",点击Next。 |
(13)下一个画面上选择Typical ,点击Next |
(14)在Privileged Operating System Groups界面上,点击Next |
(15)提示输入global database name,自己喜欢什么就写什么,我写了个wap ,验证ORACLE_SID为ORCL,点击Next |
(16)提示输入db files localtion,输入/home/oracle/data,点击Next |
(17)在最后的Summary窗口上,点击Install |
(18)现在正式开始安装了 |
我看的文章上说这是个漫长的过程,至少需要 1~2个小时。为了保持清醒,我冲了杯咖啡,开始上网。没想到不到20分钟就完成了。 |
(19)在文件被拷贝和联接后,弹出一个要求运行root.sh的窗口 |
切换到root用户窗口, |
[root@only_you oracle]./root.sh |
在询问local bin directory时按下Enter键 |
(20)返回要求运行root.sh的窗口上,点击OK |
(21)Oracle Net8 Configuration和Oracle Database Configuration Assistants启动, 安装Net8和创建数据库。 这一步又花了20分钟左右的时间。 |
(22)Oracle Database Configuration Assistants结束后,在弹出的完成数据库创建窗 口上点击OK |
(23)在End of Installation画面上,点击Exit ,在弹出的Do you reallywant to exit?窗口上点击yes |
现在所有的Oralce 8i Enterprise就安装好了! 之后可以使用Oracle数据库管理工具svrmgrl、sql*plus来对安装好的数据库进行测试! |
9.测试 |
[oracle@only_you oracle] svrmgrl |
Oracle Server Manager Release 3.1.6.0.0 - Production |
Copyright (c) 1997, 1999, Oracle Corporation. All Rights Reserved. |
Oracle8i Enterprise Edition Release 8.1.6.1.0 - Production |
With the Partitioning option |
JServer Release 8.1.6.0.0 - Production |
SVRMGR>connect internal |
Connected. |
SVRMGR> shutdown |
Database closed. |
Database dismounted. |
ORACLE instance shut down. |
SVRMGR>startup |
ORACLE instance started. |
Total System Global Area 56012784 bytes |
Fixed Size 69616 bytes |
Variable Size 38993920 bytes |
Database Buffers 16777216 bytes |
Redo Buffers 172032 bytes |
Database mounted. |
Database opened. |
SVRMGR> quit |
Server Manager complete. |
不错,看来可以正常工作了。再用sqlplus试试 |
[oracle@only_you oracle]$ sqlplus |
SQL*Plus: Release 8.1.6.0.0 - Production on Sun Apr 15 09:20:12 2001 |
(c) Copyright 1999 Oracle Corporation. All rights reserved. |
Enter user-name: scott |
Enter password: tiger |
Connected to: |
Oracle8i Enterprise Edition Release 8.1.6.1.0 - Production |
With the Partitioning option |
JServer Release 8.1.6.0.0 - Production |
SQL> select * from emp |
应该出来一堆数据,有14条,看来没问题了。 |
SQL>quit |
10.恢复以前的glibc |
[root@only_you oracle] cd /usr/bin |
[root@only_you bin] rm –f gcc cc ld |
[root@only_you bin] mv ./saved/* . |
[root@only_you bin] rmdir saved |
[root@only_you bin] cd /usr/lib |
[root@only_you lib] mv ./saved/* . |
[root@only_you lib] rmdir saved |