Linux环境下Oracle10G和Oracle11G并存的安装和配置

Linux系统中可以实现Oracle10GOracle11G双版本数据库的并存吗?答案是肯定的,本文我们就介绍Linux下Oracle10G和Oracle11G双版本数据库并存的安装和配置,接下来我们就开始介绍。

环境

WMWARE WORKSTAION 7

OS OracleLinux-R6 32Bit 1G内存 30G硬盘1+20G硬盘2(用于存放安装软件)

DATABASE

10201_database_linux32

linux_11gR2

之所以选择的操作系统是OEL,主要是出于兼容性考虑,毕竟这是Oracle自家的玩意儿,自己公司的产品的兼容性肯定要比与别家的相比好点。

PS:不过令我很郁闷的一点就是,启动数据库安装程序的时候,为什么相同的环境变量配置,使用Red Hat Enterprise的时候都能够正常显示中文,但是一到OEL就是经典的方块,不过操作系统是5.x还是6.x,不过database是10.x还是11.x。

下面是安装过程的简单记录和汇总。

一、首先安装oracle10g

1. 建立oracle安装需要的组

root用户执行:

  1. groupadd oinstall  
  2.  
  3. groupadd dba  
  4.  
  5. groupadd oper 

2. 建立oracle用户

root用户执行:

  1. useradd oracle -g oinstall -G dba,oper  
  2.  
  3. passwd oracle 

3. 修改oracle的配置文件

oracle用户执行

添加下面的行到.bash_profile

  1. export EDITOR=vi #设置sqlplus默认编辑器为vi  
  2.  
  3. alias sqlplus=’rlwrap sqlplus’ #一个小工具,能够让sqlplus想windows下一样使用方向键  
  4.  
  5. export NLS_LANG=”SIMPLIFIED CHINESE_CHINA.UTF8″  
  6.  
  7. export ORACLE_SID=TEST10G 
  8.  
  9. export ORACLE_BASE=/opt/oracle/db/10g  
  10.  
  11. export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1  
  12.  
  13. export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/usr/local/lib:  
  14.  
  15. export PATH=$ORACLE_HOME/bin:/usr/bin:/usr/ccs/bin:/etc:/bin:/usr/openwin/bin:/usr/local/bin:/usr/X11R6/bin:  
  16.  
  17. umask 022 

4. 修改内核参数

root用户执行,添加下面的行到/etc/sysctl.conf

  1. kernel.shmmax = 2147483648 
  2.  
  3. kernel.shmmni = 4096 
  4.  
  5. kernel.shmall = 2097152 
  6.  
  7. kernel.sem = 250 32000 100 128  
  8.  
  9. fs.file-max = 65536 
  10.  
  11. net.ipv4.ip_local_port_range = 1024 65000  
  12.  
  13. net.core.rmem_default = 1048576 
  14.  
  15. net.core.rmem_max = 1048576 
  16.  
  17. net.core.wmem_default = 262144 
  18.  
  19. net.core.wmem_max = 262144 

5. 修改资源限制

root用户执行,添加下面的行到/etc/security/limits.conf

  1. oracle soft nofile 65536  
  2.  
  3. oracle hard nofile 65536  
  4.  
  5. oracle soft nproc 16384  
  6.  
  7. oracle hard nproc 16384 

4. 建立相关的目录

root用户执行:

  1. mkdir /opt/oracle  
  2.  
  3. chown oracle:oinstall /opt/oracle 

5. 格式化、挂载新增加的硬盘

root用户执行:

  1. [root@gtlions ~]# fdisk -l  
  2.  
  3. [root@gtlions ~]# fdisk /dev/sdb 

输入 n p 1 w

  1. [root@gtlions ~]# mkfs -t ext4 -c /dev/sdb1  
  2.  
  3. [root@gtlions ~]# mkdir /media/newdriver  
  4.  
  5. [root@gtlions ~]# mount /dev/sdb1 /media/newdriver/  
  6.  
  7. [root@gtlions ~]# mkdir /media/newdriver/ora  
  8.  
  9. [root@gtlions ~]# chown oracle:oinstall /media/newdriver/ora 

6. 上传软件并解压软件

oracle用户执行:unzip -q 10201_database_linux32.zip

7. 版本欺骗

root用户执行

  1. cp /etc/redhat-release /etc/redhat-release.bak  
  2.  
  3. vi /etc/redhat-release修改这个文件为  
  4.  
  5. #Red Hat Enterprise Linux Server release 6.0 (Santiago)  
  6.  
  7. Red Hat 4 

8. 乱码问题

oracle用户执行,在执行./runInstaller之前:export LANG=en_US。

9. 安装过程中遇到的错误

9.1. 缺少libXp包

root用户执行

Exception in thread “main” java.lang.UnsatisfiedLinkError: /tmp/OraInstall2011-07-30_01-41-36AM/jre/1.4.2/lib/i386/libawt.so: libXp.so.6: cannot open shared object file: No such file or directory

解决办法:缺少libXp包,Linux安装光盘中查找安装即可,具体安装细节不在赘述。

由于从来没有在Linux6版本中安装过10g版本的数据库,一开始还怕会有不少问题,还好,一切顺利,接下来的11g版本相信也不会有什么问题。

10. 安装rlwrap

root用户执行

  1. [root@gtlions ~]# tar zxvf rlwrap-0.37.tar.gz  
  2.  
  3. [root@gtlions ~]# cd rlwrap-0.37  
  4.  
  5. [root@gtlions rlwrap-0.37]# ./configure  
  6.  
  7. [root@gtlions rlwrap-0.37]# make  
  8.  
  9. [root@gtlions rlwrap-0.37]# make install 

11. 使用启动脚本

使用启动脚本之前需要做一些修改,主要是配置下ORACLE_HOME_LISTNER这个变量.

vi $ORACLE_HOME/bin/dbstart,把79行的ORACLE_HOME_LISTNER=/ade/vikrkuma_new/oracle修改成:ORACLE_HOME_LISTNER=$ORACLE_HOME。

否则报错:

  1. [oracle@gtlions bin]$ ./dbstart  
  2.  
  3. Failed to auto-start Oracle Net Listene using /ade/vikrkuma_new/oracle/bin/tnslsnr 

12. 使用关闭脚本

由于在10g版本当中没有随着关闭脚本配置关闭监听的功能,脚本中写道

# Oracle Net Listener is NOT shutdown using this script.

因此我们需要增加监听的停止脚本,我们可以借鉴下11g的关闭脚本,拷贝相关部分过来即可

  1. ORACLE_HOME_LISTNER=$ORACLE_HOME  
  2.  
  3. if [ ! $ORACLE_HOME_LISTNER ] ; then  
  4.  
  5. echo “ORACLE_HOME_LISTNER is not SET, unable to auto-stop Oracle Net Listener”  
  6.  
  7. echo “Usage: $0 ORACLE_HOME”  
  8.  
  9. else  
  10.  
  11. LOG=$ORACLE_HOME_LISTNER/listener.log  
  12.  
  13. # Set the ORACLE_HOME for the Oracle Net Listener, it gets reset to  
  14.  
  15. # a different ORACLE_HOME for each entry in the oratab.  
  16.  
  17. export ORACLE_HOME=$ORACLE_HOME_LISTNER  
  18.  
  19. # Stop Oracle Net Listener  
  20.  
  21. if [ -f $ORACLE_HOME_LISTNER/bin/tnslsnr ] ; then  
  22.  
  23. echo “$0: Stoping Oracle Net Listener” >> $LOG 2>&1  
  24.  
  25. $ORACLE_HOME_LISTNER/bin/lsnrctl stop >> $LOG 2>&1 &  
  26.  
  27. else  
  28.  
  29. echo “Failed to auto-stop Oracle Net Listener using $ORACLE_HOME_LISTNER/bin/tnslsnr”  
  30.  
  31. fi  
  32.  
  33. fi 

13. 配置/etc/oratab

增加或者修改如下内容,注意最后的一个Y,安装完成的时候默认是会写入这个文件一行记录,但是最后一位是N/etc/oratab TEST10G:/opt/oracle/db/10g/product/10.2.0/db_1:Y

二、接着安装oracle11g

1. 修改oracle的配置文件

注意,首先备份好这个文件,因为这个文件是10g版本使用的配置文件,只有同时保存了2个版本的对应的配置文件,在以后的使用过程中才能方便的切换。

备份后修改先前配置,修改后对应设置如下:

  1. export NLS_LANG=”SIMPLIFIED CHINESE_CHINA.UTF8″  
  2.  
  3. export ORACLE_SID=TEST11G 
  4.  
  5. export ORACLE_BASE=/opt/oracle/db/11g/base  
  6.  
  7. export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1  
  8.  
  9. export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/usr/local/lib:  
  10.  
  11. export PATH=$ORACLE_HOME/bin:/usr/bin:/usr/ccs/bin:/etc:/bin:/usr/openwin/bin:/usr/local/bin:/usr/X11R6/bin:  
  12.  
  13. umask 022 

2. 版本恢复原状

vi /etc/redhat-release修改这个文件为Red Hat Enterprise Linux Server release 6.0 (Santiago)

3. 乱码问题

在执行./runInstaller之前export LANG=en_US

三、配置和使用

最后,如何分别使用和同时使用这2个版本的数据库。

当然是通过使用不同的配置文件来实现的啦,重点在于每次使用不同版本的数据库的时候切换到相应的环境变量。

有多个办法比如:

1、逐个设置相关的变量;

2、备份2个版本的环境变量参数文件.bash_profile,登陆后手工切换;

3、这里我用的SecureCRT的ssh工具,针对oracle配置两个会话,设置在登录后执行不同的脚本,在这么我们就是要让它来替我们完成环境变量的设置。

四、最后

特地查看了下2个版本的安装目录的占用空间的大小,数据文件上差不多,10g的占用1.1g,11g的占用1.4g,但是安装软件占用的就相差很大了,11g的几乎是10g的3倍,前者是3.7g,后者才1.3g。大家伙啊11g。

关于Linux系统上Oracle10G和Oracle11G双版本数据库并存的安装和配置过程就介绍到这里了,希望可以带给您一些收获。

【编辑推荐】

  1. Oracle数据库基于用户管理的备份与恢复
  2. SQL Server 2008的BI组件SSAS使用详解
  3. Oracle数据库如何增加scott用户与相关的表
  4. 关于SQL Server数据库主键与索引的几点区别
  5. SQL Server数据同步Merge的一个BUG及解决方法

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/277642.html<

(0)
运维的头像运维
上一篇2025-05-11 05:24
下一篇 2025-05-11 05:25

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注