一. 调SCO系统参数
进入 scoadmin/Hardware/Kernel Manager,选择Tune Parameter, 作如下修改 15 SHMMAX 20 16 SEMMNI 20971520 之后relink,执行init 0 二. 安装SCO 关于Oracle 补丁文件 进入Software Manager,如列表内没有COFF Linker Supplement (Ver oss459A), 须先安装“SCO的Oracle 补丁”,否则安装的过程将出现难以想象的问题。 SCO的Oracle 补丁盘插入软驱后执行: #doscp a:/*.* /tmp #cd tmp #mv oss459a.z oss459a.Z #uncompress oss459a.Z #cp oss459a /tmp/VOL.000.000 回到Software Manager, 选择菜单 Sofware - Install new ... 选择:<*> From localhost Media Device选择 media images, Image Directory选择在/tmp中, 将显示 COFF Linker Supplement (Ver oss459A) 按[install]钮执行安装, 安装完成后,Software Manager列表内将出现 COFF Linker Supplement (Ver oss459A)。 注:1) mv oss459a.z oss459a.Z Z 大小写改动方法 三 创建dba组和 oracle用户 - oracle7 指明Oracle用户的根目录(例如:/u/oracle7) 指明用户属于dba组 四 编辑oracle7 [Oracle用户]的.profile文件 login:oracle7 password:**** $pwd /u/oracle7 $vi .profile 增加如下内容: ORACLE_BASE=/u/oracle7 ORACLE_HOME=/u/oracle7/product/734 ORACLE_SID=oracle7 ORACLE_TERM=ansi LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib ORACLE_NLS32=$ORACLE_HOME/ocommon/nls/admin/data ORACLE_PATH=$ORACLE_HOME/bin:/bin:/usr/bin:/opt/bin:/usr/lbin:. ULIMIT=2297152 TERM=ansi TMPDIR=/u/tmp PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin:/opt/bin:/usr/lbin:. export ORACLE_BASE ORACLE_HOME ORACLE_SID export ORACLE_TERM LD_LIBRARY_PATH export ORACLE_NLS32 ORACLE_PATH ULIMIT TERM TMPDIR PATH 五. 安装准备 # su - oracle7 $ mkdir u0 $ mkdir u1 $ mkdir u2 $ su root # mkdir cdrom # chmod 777 /cdrom # mkdir u # cd u # mkdir tmp # chmod 777 /u/tmp 六.在/etc/services 文件中加入一行:listener 1521/tcp # cd /etc # vi services 在文件中加入一行:listener 1521/tcp 七 开始安装 插入Oracle 7.3.4 Enterprise Edition光盘,开始安装 # /etc/mount -f RCKRDG,lower /dev/cd0 /cdrom # exit $ su - oracle7 $ cd /cdrom/orainst $ ./orainst 选择:custom方式 注:字符集WE8ISO8859P1 八 当安装程序提问 是否已执行rootpre.sh时,选NO (还没有)退出安装程序。 cd /cdrom/orainst ./rootpre.sh ./orainst 九 安装选件 Oracle On-Line Viewer Oracle Unix installer 4.0.1 Oracle distributed Database Oracle Server(RDBMS) 7.3 PL/SQL V2.3 SQL*NET SQL*PLUS TCP/IP Protocal Adapter 十 执行root.sh $ su root # cd $ORACLE_HOME/orainst # ./root.sh 安装完成 请启动数据库,在本地运行SQL*Plus测试一下。 十一 修改初始化文件 cd $ORACLE_BASE/admin/oracle/pfile vi initoracle.ora Oracle的参数调整 $cd $ORACLE_HOME/dbs $vi initoracle7.ora 除了将processes的参数保持为“Small”,其他各项的参数均打开为“Large”,且该数据库的“Total System Global Area”的大小(启动数据库时显示)为服务器所带内存的1/2~2/3之间,如果上述参数调整后达不到这个大小,则要对参数db_block_buffers的大小进行修改(增大其大小)。 另外还须将compatible的参数调整为:7.3.0.0 。 每次参数调整后要重启数据库才回生效。 $ svrmgrl SVRMGR>connect internal Connected. SVRMGR>startup ORACLE instance started. Total System Global Area 38791712 bytes Fixed Size 41880 bytes Variable Size 12371592 bytes Database Buffers 26214400 bytes Redo Buffers 163840 bytes Database mounted. Database opened. SVRMGR>shutdown immediate Database closed. Database dismounted. ORACLE instance shut down. SVRMGR> SVRMGR> 十一 编辑listener.ora tnsnames.ora #cp $ORACLE_HOME/network/admin/*.ora /etc #cd /etc #chown oracle7:dba tnsnames.ora #chown oracle7:dba listence.ora #vi tnsnames.ora ------------------------------------------------------ Tnsnames.ora编辑为 Oracle7= (DESCRIPTION= (ADDRESS=(PROTOCOL=TCP)(Host=sjztkl)(Port=1521)) (CONNECT_DATA=(SID=oracle7)) ) ------------------------------------------------------ #vi listener.ora ------------------------------------------------------ listener.ora编辑为: LISTENER= (ADDRESS_LIST= (ADDRESS=(PROTOCOL=TCP)(Host=sjtkl)(Port=1521)) ) SID_LIST_LISTENER= (SID_LIST= (SID_DESC= (GLOBAL_DBNAME=sjztkl.) (ORACLE_HOME=/u/oracle7/product/734) (SID_NAME=oracle7) ) ) STARTUP_WAIT_TIME_LISTENER=0 CONNECT_TIMEOUT_LISTENER=10 TRACE_LEVEL_LISTENER=OFF ------------------------------------------------------ #exit 十二 手动启动监听进程 $cd $ORACLE_HOME/bin $lsnrctl start 看监听进程是否成功启动。 如果启动成功,在工作站上测试是否可以通过SQL*Net连接到服务器的ORACLE上。 十四 实现机器启动后ORACLE数据库和Listener的自启动 #cd /etc #vi oratab 将N改为Y #cd /etc/rc2.d #vi S100dbstart 建立的新文件,键入: su oracle7 -c /u/oracle7/product/734/bin/dbstart & #cd /etc/rc0.d #vi K100dbshut 建立的新文件,键入: su oracle7 -c /u/oracle7/product/734/bin/dbshut & sleep 1000 ---------(以下带“;”号的为注释部分,可省去)--------- ------------------- ; vi lsnrstart(在目录:$ORACLE_HOME/bin下) ; 建立的新文件, 键入: /u/oracle7/product/734/bin/lsnrctl start ;往文件S100dbstart中键入:su- oracle7 -c /u/oracle7/product/734/bin/lsnrstart & ; vi lsnrstop(在目录:$ORACLE_HOME/bin下) ; 建立的新文件, 键入: /u/oracle7/product/734/bin/lsnrctl stop ;往文件K100dbshut中键入:su - oracle7 -c /u/oracle7/product/734/bin/lsnrstop & sleep 1000 ; 注:文件lsnrstart和lsnrstop的读写权限为:-rwxr-xr-x ------------------------------------------------------------------ # su - oracle7 $ cd $ORACLE_HOME/bin $ vi dbstart 将启动lsnrctl的语句加入 /svrmgrl 查找字符串 键入:$ORACLE_HOME/bin/lsnrctl start (放在该句"#Figure out if this is a V5,V6 or V7 database"之上) $ vi dbshut 将停止lsnrctl的语句加入 /svrmgrl 查找字符串 键入:$ORACLE_HOME/bin/lsnrctl stop (放在该句"#See if it is a V6 or V7 database"之上) $exit $/etc/shutdown 重启后测试,ORACLE数据库是否已经启动成功,监听进程时是否已经启动成功(工作站可以通过SQL*Net连接到服务器的ORACLE上) 十六 重新启动