【参考资料】Linux(CentOS 7.0)安装Oracle11g R2

简介:

// 注释     # root用户   $oracle用户

1. 关闭安全措施  

# chkconfig iptables off // 永久关闭防火墙

# serviceiptables stop // 暂时关闭防火墙,重启系统后会自动打开

# sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/config // 关闭Selinux


2. 验证硬件

2.1 内存:

要求:内存最小1G,推荐2G或者更高。

查看命令:# grep MemTotal /proc/meminfo

 

2.2 Swap:

要求:

RAW Swap
1G至2G 1.5倍
2G至16G 同RAW相等
16G以上 16G

查看命令:# grep SwapTotal /proc/meminfo

          # free


3. 验证软件

3.1 操作系统

  • Asianux Server 3 SP2

  • Oracle Linux 4 Update 7

  • Oracle Linux 5 Update 2 (with Red Hat Compatible Kernel)

  • Oracle Linux 5 Update 5

  • Oracle Linux 6

  • Oracle Linux 6 (with Red Hat Compatible Kernel)

  • Red Hat Enterprise Linux 4 Update 7

  • Red Hat Enterprise Linux 5 Update 2

  • Red Hat Enterprise Linux 5 Update 5 (with the Oracle Unbreakable Enterprise Kernel for Linux)

  • Red Hat Enterprise Linux 6

  • Red Hat Enterprise Linux 6 (with the Oracle Unbreakable Enterprise Kernel for Linux)

  • SUSE Linux Enterprise Server 10 SP2

  • SUSE Linux Enterprise Server 11

CentOS7本文按照Red Hat Enterprise Linux 6来配置。

 

# cat /proc/version // 查看版本

 

3.2 内核

  • On Oracle Linux 4 and Red Hat Enterprise Linux 4 2.6.9 or later

  • On Oracle Linux 5 Update 2 with Red Hat Compatible Kernel 2.6.18 or later

  • On Oracle Linux 5 Update 5 with Red Hat Compatible Kernel 2.6.18 or later

  • On Oracle Linux 5 Update 5 with Unbreakable Enterprise Kernel 2.6.32-100.0.19 or later

  • On Oracle Linux 6 2.6.32-100.28.5.el6.x86_64 or later

  • On Oracle Linux 6 with Red Hat Compatible Kernel 2.6.32-71.el6.x86_64 or later

  • On Red Hat Enterprise Linux 5 Update 2 2.6.18 or later

  • On Red Hat Enterprise Linux 5 Update 5 2.6.18 or later

  • On Red Hat Enterprise Linux 5 Update 5 with Unbreakable Enterprise Kernel 2.6.32 or later

  • On Red Hat Enterprise Linux 6 2.6.32-71.el6.x86_64 or later

  • On Red Hat Enterprise Linux 6 with Unbreakable Enterprise Kernel 2.6.32-100.28.5.el6.x86_64 or later

  • On Asianux Server 3 2.6.18 or later

  • On SUSE Linux Enterprise Server 10 2.6.16.21 or later

  • On SUSE Linux Enterprise Server 11 2.6.27.19 or later

# uname -r   //查看内核

 

3.3 验证需要的包:

# rpm -qa binutils compat-libstdc++-33 elfutils-libelf elfutils-libelf-devel elfutils-libelf-devel-static gcc gcc-c++ glibc glibc-common glibc-devel glibc-headers glibc-static kernel-headers pdksh libaio libaio-devel libgcc libgomp libstdc++ libstdc++-devel libstdc++-static make numactl-devel sysstat unixODBC unixODBC-devel // 验证命令26个包

  • kernel-headers-3.10.0-123.el7.x86_64

  • gcc-c++-4.8.2-16.el7.x86_64

  • numactl-devel-2.0.9-2.el7.x86_64

  • glibc-headers-2.17-55.el7.x86_64

  • glibc-common-2.17-55.el7.x86_64

  • binutils-2.23.52.0.1-16.el7.x86_64

  • unixODBC-devel-2.3.1-10.el7.x86_64

  • libaio-0.3.109-12.el7.x86_64

  • make-3.82-21.el7.x86_64

  • elfutils-libelf-0.158-3.el7.x86_64

  • elfutils-libelf-devel-0.158-3.el7.x86_64

  • sysstat-10.1.5-4.el7.x86_64

  • glibc-static-2.17-55.el7.x86_64

  • glibc-devel-2.17-55.el7.x86_64

  • glibc-2.17-55.el7.x86_64

  • elfutils-libelf-devel-static-0.158-3.el7.x86_64

  • libaio-0.3.109-12.el7.i686

  • gcc-4.8.2-16.el7.x86_64

  • libgcc-4.8.2-16.el7.i686

  • libstdc++-static-4.8.2-16.el7.x86_64

  • libaio-devel-0.3.109-12.el7.x86_64

  • libstdc++-4.8.2-16.el7.x86_64

  • libaio-devel-0.3.109-12.el7.i686

  • unixODBC-2.3.1-10.el7.x86_64

  • libstdc++-devel-4.8.2-16.el7.x86_64

  • compat-libstdc++-33-3.2.3-71.el7.x86_64

  • libgcc-4.8.2-16.el7.x86_64

  • libgomp-4.8.2-16.el7.x86_64

#rpm -ivh 安装包名 // 安装程序包

 注:

(1)安装glibc-2.17-55.el7.i686.rpm时,因为依赖包相互依赖,需要与依赖包同时安装:
  rpm -ivh glibc-2.17-55.el7.i686.rpm nss-softokn-freebl-3.15.4-2.el7.i686.rpm
(2)RHEL7中缺少包compat-libstdc++-33,可以在RHEL6中找到.
(3)在Oracle数据库软件安装时,ksh实际是用的pdksh,但ksh也是可以使用的,只是安装时会有警告,pdksh是一个早期的软件包,可以在以下网站找到.    http://rpm.pbone.net/

 

4. 创建组和用户

# groupadd dba
# groupadd oinstall
# useradd -m -g oinstall -G dba oracle
# passwd oracle
// 如果nobody用户不存在(id nobody命令查看),则创建:
# useradd nobody

 

5. 配置内核

注:配置大于系统数据需要配置更改,否则不需要配置。

要求配置:

参数 最小值 文件 命令
semmsl
semmns
semopm
semmni
50
32000
100
128
/proc/sys/kernel/sem # /sbin/sysctl -a | grep sem
shmall 2097152 /proc/sys/kernel/shmall # /sbin/sysctl -a | grep shm
shmmax 4294967296 /proc/sys/kernel/shmmax
// 最大共享内存,官方文档建议是内存的1/2
// 我的服务器是8G内存,所以为4*1024*1024*1024
// 最小值为536870912(1G内存/2)
# /sbin/sysctl -a | grep shm
shmmni 4096 /proc/sys/kernel/shmmni # /sbin/sysctl -a | grep shm
file-max 6815744 /proc/sys/fs/file-max # /sbin/sysctl -a | grep file-max
ip_local_port_range 9000 65500 /proc/sys/net/ipv4/ip_local_port_range # /sbin/sysctl -a | grep ip_local_port_range
rmem_default 262144  /proc/sys/net/core/rmem_default # /sbin/sysctl -a | grep rmem_default
rmem_max 4194304 /proc/sys/net/core/rmem_max # /sbin/sysctl -a | grep rmem_max
wmem_default 262144 /proc/sys/net/core/wmem_default # /sbin/sysctl -a | grep wmem_default
wmem_max  1048576 /proc/sys/net/core/wmem_max # /sbin/sysctl -a | grep wmem_max
aio-max-nr 1048576

# vi /etc/sysctl.conf

按照系统值对比添加: 

fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 536870912
kernel.shmmni = 4096
kernel.sem = 250 32000 100 128
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048576


保存后生效命令:

# /sbin/sysctl -p

 

6. 创建安装目录

# mkdir -p /opt/oracle/product/11.2.0.1
# chown -R oracle:oinstall /opt/oracle

# mkdir /var/oracle
# chown oracle:oinstall  /var/oracle
# chmod 755 /var/oracle

 

7. 配置环境变量

vi /etc/profile

增加下面行:
if [ $USER = "oracle" ]; then
        if [ $SHELL = "/bin/ksh" ]; then
              ulimit -p 16384
              ulimit -n 65536
        else
              ulimit -u 16384 -n 65536
        fi
fi

 

使用Oracle用户登陆:
su - oracle
vi ~/.bash_profile
以下是配置文件的内容,里面已有的部分就不必在次添加了。
# .bash_profile
# Get the aliases and functions
if [ -f ~/.bashrc ]; then
        . ~/.bashrc
fi
# User specific environment and startup programs
umask 022
# +--------------------------+
# | SETUP ORACLE ENVIRONMENT |
# +--------------------------+

TMP=/tmp
TMPDIR=/tmp
export TMP TMPDIR
# 如果安装出现相关问题请屏蔽下面5行,
# 安装好后再取消屏蔽这些环境变量设置
export ORACLE_HOME=/opt/oracle/product/11.2.0.1    //跟之前创建的目录路径一直
export ORACLE_BASE=/opt/oracle
export ORACLE_SID=afcsc                            //根据自己的环境添加SID名称
export TNS_ADMIN=$ORACLE_HOME/network/admin
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK          //显示英文字符环境,可解决安装图形界面乱码。
export PATH=$PATH:$ORACLE_HOME/bin
# +--------------------------+
# | LINUX STUFF |
# +--------------------------+
export LANG=AMERICAN_AMERICA.ZHS16GBK
unset USERNAME
# +-------------+
# | "GREETINGS" |
# +-------------+
echo ".bash_profile executed"

 

执行:source ~/.bash_profile

 

8. 设置进程数和最大会话数

编辑文件:

# vi /etc/security/limits.conf 加入以下语句:
oracle           soft    nproc           2047
oracle           hard    nproc           16384
oracle           soft    nofile          1024
oracle           hard    nofile          65536

 

9. 关联设置
编辑文件:vi /etc/pam.d/login 加入以下语句:
session    required     pam_limits.so
(注意:根据最后一条session规则的注释,应该加在最后一条规则之前)

9. 解压缩

将linux.x64_11gR2_database_1of2.zip和linux.x64_11gR2_database_2of2.zip移动到移动到/tmp目录下进行解压缩。

$ cd /tmp

$ unzip linux.x64_11gR2_database_1of2.zip

$ unzip linux.x64_11gR2_database_2of2.zip

 

10. 安装

$ cd /tmp/database/

$ ./runInstaller

 

注意:
选择advance install
数据库home设置为/opt/oracle/product/11.2.0.1
数据库全局名称设置为afcsc                         //跟之前.bash_profile内的值一致
字符集选Simplified Chinese ZHS16GBK

 

检查后会运行图形化安装界面。

安装过程中连接库时会出现两个错误:

 

  • 第一个:

/lib64/libstdc++.so中memcpy@GLIBC_2.4找不到。

问题:glibc是2.17的库,连接找的是2.14的库。

解决办法:改成静态链接。

查看 /usr/lib64/libc.a是否存在。

修改oracle安装目录下:$ORACLE_HOME/ctx/lib/ins_ctx.mk

ctxhx: $(CTXHXOBJ)
        $(LINK_CTXHX) $(CTXHXOBJ) $(INSO_LINK)

修改为:

ctxhx: $(CTXHXOBJ)
        -static $(LINK_CTXHX) $(CTXHXOBJ) $(INSO_LINK) /usr/lib64/libc.a

然后点击retry通过。

 

  • 第二个:

问题:undefinied reference symbol'B_DestroyKeyObject',查看日志,实际就是没有找到nnz11这个库。

解决办法:

修改/opt/oracle/product/11.2.0.1/sysman/lib/ins_emagent

$(MK_EMAGENT_NMECTL)

修改为:

$(MK_EMAGENT_NMECTL) -lnnz11

然后点击retry通过。

 

 

注:安装需要远程图形化连接安装oracle,具体方式和软件这里不说了。











本文转自 qq8658868 51CTO博客,原文链接:http://blog.51cto.com/hujizhou/1782154,如需转载请自行联系原作者
目录
相关文章
|
9月前
|
存储 Ubuntu Linux
VMware-安装CentOS系统教程及安装包
虚拟机相当于是一个独立于你电脑的环境,在这个环境上面,你可以安装Linux、Windows、Ubuntu等各个类型各个版本的系统,在这个系统里面你不用担心有病读等,不用担心文件误删导致系统崩溃。 虚拟机也和正常的电脑系统是一样的,也可以开关机,不用的时候,你关机就可以了,也不会占用你的系统资源,使用起来还是比较方便 这里也有已经做好的CentOS 7系统,下载下来解压后直接用VMware打开就可以使用
1459 69
|
8月前
|
存储 分布式计算 Linux
安装篇--CentOS 7 虚拟机安装
VMware 装 CentOS 7 不知道从哪下手?这篇超详细图文教程手把手教你在 VMware Workstation 中完成 CentOS 7 桌面系统的完整安装流程。从 ISO 镜像下载、虚拟机配置,到安装图形界面、设置用户密码,每一步都有截图讲解,适合零基础新手快速上手。装好之后无论你是要搭 Hadoop 集群,还是练 Linux ,这个环境都够你折腾一整天!
3274 3
|
9月前
|
Ubuntu Linux 索引
Centos 7、Debian及Ubuntu系统中安装和验证tree命令的指南。
通过上述步骤,我们可以在CentOS 7、Debian和Ubuntu系统中安装并验证 `tree`命令。在命令行界面中执行安装命令,然后通过版本检查确认安装成功。这保证了在多个平台上 `tree`命令的一致性和可用性,使得用户无论在哪种Linux发行版上都能使用此工具浏览目录结构。
745 78
|
10月前
|
Linux 网络安全 Apache
针对在Centos/Linux安装Apache过程中出现的常见问题集锦
以上每个问题的解决方案应深入分析错误日志、系统消息和各种配置文件,以找到根本原因并加以解决。务必保持系统和Apache软件包更新到最新版本,以修复已知的bugs和安全漏洞。安装和管理Web服务器是一项需要细致关注和不断学习的任务。随着技术的发展,推荐定期查看官方文档和社区论坛,以保持知识的更新。
362 80
|
8月前
|
安全 关系型数据库 MySQL
CentOS 7 yum 安装 MySQL教程
在CentOS 7上安装MySQL 8,其实流程很清晰。首先通过官方Yum仓库来安装服务,然后启动并设为开机自启。最重要的环节是首次安全设置:需要先从日志里找到临时密码来登录,再修改成你自己的密码,并为远程连接创建用户和授权。最后,也别忘了在服务器防火墙上放行3306端口,这样远程才能连上。
1887 16
|
9月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
651 10
|
10月前
|
人工智能 数据挖掘 Linux
Centos安装Python3.7(亲测可用)
本指南详细介绍了在基于Linux(以CentOS系统为例,使用yum包管理器)的系统上安装Python 3.7版本的完整流程。Python是一种广泛使用的高级编程语言,在各种领域如软件开发、数据分析、人工智能和区块链开发等都有着重要的应用。
797 2
|
9月前
|
运维 网络协议 Linux
CentOS下Bind服务的安装与故障排查
通过以上的步骤,您应该能够在CentOS系统上安装并配置BIND DNS服务,并进行基本的故障排查。
686 0
|
9月前
|
存储 Ubuntu Linux
安卓手机免root安装各种Linux系统:Ubuntu, Centos,Kali等
此外还可以安装Slackware、Archstrike等系统,还可以通过github查找方法安装更多有趣的东西。 昨日小编就是通过Termux安装的Kali Linux工具包。