热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linnux下Oracle10G和Oracle11G双版本数据库并存的安装和配置-mysql教程

心血来潮,突然想在OEL6下面安装Oracle10g和Oracle11g,2个版本共存,方便学习和实验,这个安装过程其实不难操作,如果你有分别安

心血来潮,突然想在OEL6下面安装Oracle10g和Oracle11g,2个版本共存,方便学习和实验,这个安装过程其实不难操作,如果你有分别安

心血来潮,突然想在OEL6下面安装Oracle10g和Oracle11g,2个版本共存,方便学习和实验,这个安装过程其实不难操作,如果你有分别安装过10g和11g的经验,相信具体操作是很容易的,最总要的一点是如何让2个版本共存和正常使用。
在虚拟机上测试了整个安装过程,本本比较懒,过程相当缓慢。

环境
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用户执行
groupadd oinstall
groupadd dba
groupadd oper
2. 建立oracle用户
root用户执行
useradd oracle -g oinstall -G dba,oper
passwd oracle
3. 修改oracle的配置文件
oracle用户执行
添加下面的行到.bash_profile
export EDITOR=vi #设置sqlplus默认编辑器为vi
alias sqlplus=’rlwrap sqlplus’ #一个小工具,能够让sqlplus想windows下一样使用方向键
export NLS_LANG=”SIMPLIFIED CHINESE_CHINA.UTF8″
export ORACLE_SID=TEST10G
export ORACLE_BASE=/opt/oracle/db/10g
export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/usr/local/lib:
export PATH=$ORACLE_HOME/bin:/usr/bin:/usr/ccs/bin:/etc:/bin:/usr/openwin/bin:/usr/local/bin:/usr/X11R6/bin:
umask 022
4. 修改内核参数
root用户执行
添加下面的行到/etc/sysctl.conf
kernel.shmmax = 2147483648
kernel.shmmni = 4096
kernel.shmall = 2097152
kernel.sem = 250 32000 100 128
fs.file-max = 65536
net.ipv4.ip_local_port_range = 1024 65000
net.core.rmem_default = 1048576
net.core.rmem_max = 1048576
net.core.wmem_default = 262144
net.core.wmem_max = 262144
5. 修改资源限制
root用户执行
添加下面的行到/etc/security/limits.conf
oracle soft nofile 65536
oracle hard nofile 65536
oracle soft nproc 16384
oracle hard nproc 16384
4. 建立相关的目录
root用户执行
mkdir /opt/oracle
chown oracle:oinstall /opt/oracle
5. 格式化、挂载新增加的硬盘
root用户执行
[root@ ~]# fdisk -l
[root@ ~]# fdisk /dev/sdb
输入 n p 1 w
[root@ ~]# mkfs -t ext4 -c /dev/sdb1
[root@ ~]# mkdir /media/newdriver
[root@ ~]# mount /dev/sdb1 /media/newdriver/
[root@ ~]# mkdir /media/newdriver/ora
[root@ ~]# chown oracle:oinstall /media/newdriver/ora
6. 上传软件并解压软件
oracle用户执行
unzip -q 10201_database_linux32.zip
7. 版本欺骗
root用户执行
cp /etc/RedHat-release /etc/redhat-release.bak
vi /etc/redhat-release修改这个文件为
#Red Hat Enterprise Linux Server release 6.0 (Santiago)
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用户执行
[root@ ~]# tar zxvf rlwrap-0.37.tar.gz
[root@ ~]# cd rlwrap-0.37
[root@ rlwrap-0.37]# ./configure
[root@ rlwrap-0.37]# make
[root@ 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
否则报错:
[oracle@gtlions bin]$ ./dbstart
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的关闭脚本,拷贝相关部分过来即可
ORACLE_HOME_LISTNER=$ORACLE_HOME
if [ ! $ORACLE_HOME_LISTNER ] ; then
echo “ORACLE_HOME_LISTNER is not SET, unable to auto-stop Oracle Net Listener”
echo “Usage: $0 ORACLE_HOME”
else
LOG=$ORACLE_HOME_LISTNER/listener.log

# Set the ORACLE_HOME for the Oracle Net Listener, it gets reset to
# a different ORACLE_HOME for each entry in the oratab.
export ORACLE_HOME=$ORACLE_HOME_LISTNER

# Stop Oracle Net Listener
if [ -f $ORACLE_HOME_LISTNER/bin/tnslsnr ] ; then
echo “$0: Stoping Oracle Net Listener” >> $LOG 2>&1
$ORACLE_HOME_LISTNER/bin/lsnrctl stop >> $LOG 2>&1 &
else
echo “Failed to auto-stop Oracle Net Listener using $ORACLE_HOME_LISTNER/bin/tnslsnr”
fi
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个版本的对应的配置文件,在以后的使用过程中才能方便的切换。
备份后修改先前配置,修改后对应设置如下:
export NLS_LANG=”SIMPLIFIED CHINESE_CHINA.UTF8″
export ORACLE_SID=TEST11G
export ORACLE_BASE=/opt/oracle/db/11g/base
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/usr/local/lib:
export PATH=$ORACLE_HOME/bin:/usr/bin:/usr/ccs/bin:/etc:/bin:/usr/openwin/bin:/usr/local/bin:/usr/X11R6/bin:
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。


-The End-

linux

推荐阅读
  • FreeBSD环境下PHP GD库安装问题的详细解决方案
    在 FreeBSD 环境下,安装 PHP GD 库时可能会遇到一些常见的问题。本文详细介绍了从配置到编译的完整步骤,包括解决依赖关系、配置选项以及常见错误的处理方法。通过这些详细的指导,开发者可以顺利地在 FreeBSD 上完成 PHP GD 库的安装,确保其正常运行。此外,本文还提供了一些优化建议,帮助提高安装过程的效率和稳定性。 ... [详细]
  • Linux CentOS 7 安装PostgreSQL 9.5.17 (源码编译)
    近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x ... [详细]
  • V8不仅是一款著名的八缸发动机,广泛应用于道奇Charger、宾利Continental GT和BossHoss摩托车中。自2008年以来,作为Chromium项目的一部分,V8 JavaScript引擎在性能优化和技术创新方面取得了显著进展。该引擎通过先进的编译技术和高效的垃圾回收机制,显著提升了JavaScript的执行效率,为现代Web应用提供了强大的支持。持续的优化和创新使得V8在处理复杂计算和大规模数据时表现更加出色,成为众多开发者和企业的首选。 ... [详细]
  • Linux基础知识:Vi与Vim编辑器详解
    Linux基础知识:Vi与Vim编辑器详解 ... [详细]
  • Leetcode学习成长记:天池leetcode基础训练营Task01数组
    前言这是本人第一次参加由Datawhale举办的组队学习活动,这个活动每月一次,之前也一直关注,但未亲身参与过,这次看到活动 ... [详细]
  • 2020年9月15日,Oracle正式发布了最新的JDK 15版本。本次更新带来了许多新特性,包括隐藏类、EdDSA签名算法、模式匹配、记录类、封闭类和文本块等。 ... [详细]
  • 包含phppdoerrorcode的词条 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • C盘无法格式化的原因及解决方法
    本文探讨了C盘无法格式化的原因,并提供了详细的解决方案,帮助用户顺利进行系统维护。 ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • CentOS 7 中 iptables 过滤表实例与 NAT 表应用详解
    在 CentOS 7 系统中,iptables 的过滤表和 NAT 表具有重要的应用价值。本文通过具体实例详细介绍了如何配置 iptables 的过滤表,包括编写脚本文件 `/usr/local/sbin/iptables.sh`,并使用 `iptables -F` 清空现有规则。此外,还深入探讨了 NAT 表的配置方法,帮助读者更好地理解和应用这些网络防火墙技术。 ... [详细]
  • Vim 编辑器功能强大,但其默认的配色方案往往不尽如人意,尤其是注释颜色为蓝色时,对眼睛极为不友好。为了提升编程体验,自定义配色方案显得尤为重要。通过合理调整颜色,不仅可以减轻视觉疲劳,还能显著提高编码效率和兴趣。 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 在本文中,我们将探讨如何在Docker环境中高效地管理和利用数据库。首先,需要安装Docker Desktop以确保本地环境准备就绪。接下来,可以从Docker Hub中选择合适的数据库镜像,并通过简单的命令将其拉取到本地。此外,我们还将介绍如何配置和优化这些数据库容器,以实现最佳性能和安全性。 ... [详细]
author-avatar
早起床的小鸟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有