WEB开发网
开发学院数据库Oracle Oracle 8i在GNU/Linux上的安装笔记 阅读

Oracle 8i在GNU/Linux上的安装笔记

 2008-09-08 12:52:51 来源:WEB开发网   
核心提示:硬件需求至少256M物理内存系统准备redhat8按server方式安装需要增加的安装包大类:1 包含一个X系统,建议使用GNOME,Oracle 8i在GNU/Linux上的安装笔记,2 将开发工具包DEVELOP TOOLS选上,标准的GCC工具等就有了,经常用来设置系统的参数,或者特殊系统视图)system/ma

硬件需求

========

至少256M物理内存

系统准备

========

redhat8按server方式安装需要增加的安装包大类:

1 包含一个X系统,建议使用GNOME,

2 将开发工具包DEVELOP TOOLS选上,标准的GCC工具等就有了。

3 建议将NETWORK UTILIETY选上,nmap mtr之类的小工具很有用

安装大约1.4G空间

安装后将语言环境设置缺省的en_US.UTF-8 (在RedHat 7.3下缺省是en_US.iso885915)改成en_US

root#vi /etc/sysconfig/i18n

改成:

LANG="en_US"

SUPPORTED="en_US:en"

一 安装前准备

下载:

最新的JAVA虚拟机:建议使用IBM JVM1.3

http://www-106.ibm.com/developerworks/java/jdk/

Oracle8.1.7的安装包:

linux81701.tar oracle8i的LINUX安装包

glibc-2.1.3-stubs.tar.gz 补丁程序

http://technet.oracle.com/software/products/oracle8i/content.html

1 安装JDK

root#rpm -i IBMJava2-SDK-1.3.1-2.0.i386.rpm
将JAVA_HOME设置到/etc/profile
root#vi /etc/profile
export JAVA_HOME=/opt/IBMJava2-131
export PATH=$PATH:/opt/IBMJava2-131/bin

2 创建用户和组

oracle8i服务用户名:oracle属于dba组

root#groupadd dba

root#useradd oracle -g dba

修改oracle用户密码:

root#passwd oracle

3 设置oracle用户的环境变量,增加以下设置:

oracle%vi ~oracle/.bash_profile
export LD_ASSUME_KERNEL=2.2.5 export ORACLE_BASE=/opt/oracleexport ORACLE_HOME=$ORACLE_BASE/product/8.1.7export NLS_LANG=americanexport PATH=$PATH:$ORACLE_HOME/bin

说明:

export LD_ASSUME_KERNEL=2.2.5

指让ORACLE运行在与Redhat 6.2所基于的glibc-2.1的环境中,很多人在后面的安装过程中运行runInstaller后界面迟迟出不来,多半是因为这个环境设置问题。以前很多文章都说要安装compat包,我试过可以不装;

ORACLE_BASE和ORACLE_HOME主目录环境设置。将来的ORACLE应用程序和数据库就装在相应目录下。当然你也可以设置为其他驱动器,比如安装说明推荐的:"/u01/oracle"等;

这里假设要安装到/opt/oracle目录下:如果/opt/oracle目录还不存在,则创建相应目录并设置为oracle用户/dba组拥有:

#mkdir /opt/oracle

#chown -R oracle:dba /opt/oracle

NLS_LANG是缺省的字符集设置,如果你的应用需要其他字符集设置,请参考:ORACLE所支持的字符集;

export PATH=$PATH:$ORACLE_HOME/bin是让oracle用户缺省就能访问到ORACLE的命令行工具;

如果需要让这些环境设置马上生效:

source .bash_profile

二 ORACLE的安装过程

解包linux81701.tar(大约530M)

oracle%tar xf linux81701.tar

用Oracle用户进入X环境,运行解包出的Disk1/runInstaller,如果安装界面迟迟出不来,

请检查一下LD_ASSUME_KERNEL=2.2.5这个环境变量,

要不就是你根本没有装开发工具包大类(Developer Tools,包含:gcc 等开发工具)。

整个安装过程最好开启2个窗口:一个是Oracle的Installer,在另外一个终端窗口里运行一些辅助脚本程序,以下是按步骤安装时2个窗口的切换过程:

Oracle installer界面脚本运行窗口
oracle%/PATH/TO/Disk1/runInstaller

按部就班地按照缺省选项安装就行。

Oracle包含了丰富的服务器组件LDAP JAVA应用服务器等,但如果只是用做数据库服务器的话,为了减少后面不必要的痛苦,建议不安装OPS,JServer等,否则会慢得让你怀疑死机了。

作为数据库服务器建议只选择以下组件:

Oracle Server

Net8

Oracle Utilities

Orcale Configuration Assistants

中间有关出现权限组设置时,都填写预先设置好的dba组当ORACLE安装提示运行oracle用户组权限设置脚本时:

root#./orainstRoot.sh

中间关于数据库安装的配置选择不安装数据库

(或者最后出现数据库助手时不安装,一定等用

oracle提供的glibc-2.1.3-stubs.tar.gz中的

setup_stub.sh打完补丁以后再装数据库)

当ORACLE安装提示用root运行root.sh时:Oracle8.1.7.0.1的版本此时的root.sh有个bug在第156行:

改正如下:RUID=`/usr/bin/id|$AWK -F( '{print $2}'|$AWK -F) '{print $1}'` 最后少写个单引号 '---------^root#root.sh

ORACLE应用程序安装完成,NET8配置按照缺省设置(Perform typical configuration)即可。

至此:数据库应用和网络服务基本安装初步完成,但数据库没有初始化,退出Installer安装界面。

切换回oracle用户打补丁程序:

oracle%cp glibc-2.1.3-stubs.tar.gz %ORACLE_HOME/

oracle%cd $ORACLE_HOME

oracle%tar zxf glibc-2.1.3-stubs.tar.gz

oracle%./setup_stubs.sh

补丁打完后,在X环境中,用oracle用户启动dbassist,并按照提示创建数据库。

oracle%dbassist

数据库安装完成

数据库设置完成后,将新安装的实例ORACLE_SID设置到.bash_profile里:假设新建的数据库实例ID名是:orcl

export ORACLE_SID=orcl

这时候已经可以使用dbstart脚本启动数据库了

oracle%dbstart

或者

oracle%sqlplus
SQL>connect internal
SQL>startup

远程服务监听端口启动

oracle%lsnrctl start

三 设置服务自动启动

设置相应数据库实例允许用系统服务自动启动:修改oratab文件

root# vi /etc/oratab

将最后的:

orcl:/home/oracle/product/8.1.7:N

改为:

orcl:/home/oracle/product/8.1.7:Y

简单的服务自动启动脚本

root# vi /etc/rc.local
#start oracle8i listener first
su - oracle -c 'lsnrctl start'
#start oracle8i
su - oracle -c 'dbstart'

四 表空间创建和用户创建

表空间/用户一一对应,命名规则:username ==> USERNAME.dbf 比如:demo ==> DEMO.dbf

创建表空间:

create tablespace DEMO datafile '$ORACLE_BASE/oradata/$ORACLE_SID/DEMO.dbf' size 200m;

创建用户:

create user demo identified by demo default tablespace DEMO quota 200m on DEMO;

grant connect to demo;

删除用户:

drop user demo CASCADE;

修改用户密码:

alter user demo identified by new_password;

安装后Oracle系统需要修改的缺省用户名和密码有:

sys/change_on_install (比system的权限更高,经常用来设置系统的参数,或者特殊系统视图)

system/manager (可以管理大部分的工作:表空间、用户、授权、数据文件等)

internal/oracle (经常用在通过svrmgrl来启动关闭数据库,因为缺省是os认证,所以不需要密码)

数据导出:

exp username/password@TNS file=user.dmp

按星期定期备份:

exp username/password@TNS file=$ORACLE_BASE/backup/user_`date +%w`.dmp

注意:在crontab中需要将“%”转义:%w

24 17 * * * (source /home/oracle/.bash_profile; exp newdemo/newdemo file=$ORACLE_BASE/backup/user_`date +%w`.dmp)

数据导入:

imp username/password file=name_of_backup.dmp fromuser=thatuser touser=thisuser

Tags:Oracle GNU Linux

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接