centos7安装oracle11在实战(centos7安装oracle11g)
sinye56 2024-09-16 14:28 3 浏览 0 评论
一、环境描述
- 操作系统:centos 7,2C4G,系统盘40G,数据盘:50G.
- 数据库:oracle11.2.0.4
二、部署过程
2.1 安装前的设置
2.1.1 下载相应软件
下载oracle 11.2.0.4软件,需要下载如下软件包,具体如下:
unzip linux.x64_11gR2_database_1of2.zip
unzip linux.x64_11gR2_database_2of2.zip
解压完成后,会在当前解压目前生成一个叫database的目录 。
2.1.2 修改hosts file文件
cat /etc/hostname
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
192.168.199.128 ol7.localdomain ol7
在/etc/hostname文件中设置安装机器的主机名,这里设置为o17
2.1.3 更新系统软件包至最新(可选)
# yum update
2.1.4 设置系统的内核参数
cat /etc/sysctl.conf
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 536870912
kernel.shmmni = 4096
# semaphores: semmsl, semmns, semopm, semmni
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=1048586
运行如下命令使参数生效:
sysctl -p
参数说明:
- kernel.shmall:设置共享内存总页数。这个值太小有可能导致数据库启动报错。很多人调整系统内核参数的时候只关注SHMMAX参数,而忽略了SHMALL参数的设置。这个值推荐设置为物理内存大小除以分页大小。例示:
通过getconf获取分页的大小,用来计算SHMALL的合理设置值:SQL> select 32*1024*1024*1024/4096 from dual;
32*1024*1024*1024/4096----------------------8388608对于32G的内存,4K分页大小的系统而言,SHMALL的值应该设置为8388608。
- kernel.shmmax:Linux进程可以分配的单独共享内存段的最大值。一般设置为内存总大小的一半。这个值的设置应该大于SGA_MAX_TARGET或MEMORY_MAX_TARGET的值,因此对于安装Oracle数据库的系统,shmmax的值应该比内存的二分之一大一些。
- kernel.shmmni = 4096:设置系统级最大共享内存段数量。Oracle11g推荐最小值为4096,可以适当比4096增加一些。
2.1.5 /etc/security/limits.conf
vim /etc/security/limits.conf
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 4096
oracle hard nofile 65536
oracle soft stack 10240
添加下列行至 "/etc/pam.d/login" file。
session required pam_limits.so
2.1.6 系统安装相应软件包
yum install binutils -y
yum install compat-libstdc++-33 -y
yum install compat-libstdc++-33.i686 -y
yum install gcc -y
yum install gcc-c++ -y
yum install glibc -y
yum install glibc.i686 -y
yum install glibc-devel -y
yum install glibc-devel.i686 -y
yum install ksh -y
yum install libgcc -y
yum install libgcc.i686 -y
yum install libstdc++ -y
yum install libstdc++.i686 -y
yum install libstdc++-devel -y
yum install libstdc++-devel.i686 -y
yum install libaio -y
yum install libaio.i686 -y
yum install libaio-devel -y
yum install libaio-devel.i686 -y
yum install libXext -y
yum install libXext.i686 -y
yum install libXtst -y
yum install libXtst.i686 -y
yum install libX11 -y
yum install libX11.i686 -y
yum install libXau -y
yum install libXau.i686 -y
yum install libxcb -y
yum install libxcb.i686 -y
yum install libXi -y
yum install libXi.i686 -y
yum install make -y
yum install sysstat -y
yum install unixODBC -y
yum install unixODBC-devel -y
yum install zlib-devel -y
yum install elfutils-libelf-devel -y
2.1.7 创建相应的用户和组
groupadd -g 54321 oinstall
groupadd -g 54322 dba
groupadd -g 54323 oper
#groupadd -g 54324 backupdba
#groupadd -g 54325 dgdba
#groupadd -g 54326 kmdba
#groupadd -g 54327 asmdba
#groupadd -g 54328 asmoper
#groupadd -g 54329 asmadmin
useradd -g oinstall -G dba,oper oracle
2.1.8关闭selinx和防火墙
1、关闭selinux
vim /etc/sysconfig/selinux,编辑如下:
SELINUX=disabled
2、关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
2.1.9 创建oracle相应目录
mkdir -p /u01/app/oracle/product/11.2.0.4/db_1
chown -R oracle:oinstall /u01
chmod -R 775 /u01
2.1.10 设置oracle用户环境变量
vim /home/oracle/.bash_profile,内容如下:
# Oracle Settings
TMP=/tmp; export TMP
TMPDIR=$TMP; export TMPDIR
ORACLE_HOSTNAME=ol7.localdomain; export ORACLE_HOSTNAME
ORACLE_UNQNAME=DB11G; export ORACLE_UNQNAME
ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/11.2.0.4/db_1; export ORACLE_HOME
ORACLE_SID=DB11G; export ORACLE_SID
ORACLE_TERM=xterm; export ORACLE_TERM
PATH=/usr/sbin:$PATH; export PATH
PATH=$ORACLE_HOME/bin:$PATH; export PATH
LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib; export LD_LIBRARY_PATH
CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH
2.2 安装oracle
2.2.1 oracle 部署过程
登陆至oracle用户,如果使用的是x仿真,则设置display环境变量
DISPLAY=<machine-name>:0.0; export DISPLAY
通过如下命令启动Oracle Universal Installer(OUI)的安装。
./runInstaller
继续进行您选择的安装。您可以通过单击下面的链接查看我执行的安装类型,以查看每个阶段的屏幕截图。“ pdksh”软件包将被列出为丢失,可以忽略,因为我们安装了“ ksh”软件包。
如果要为企业管理器存储库进行安装,请记住进行高级安装并选择ALT32UTF8字符集或ZHS16GBK字符集。
1、配置安全更新
2、选择安装选项
3、系统类别
4、节点选择
5、选择安装类型
6、典型安装配置
7、创建库存
8、执行先决条件检查
9、概要
10、安装产品
11、数据库配置助手
12、数据库配置助手2
13、执行配置脚本
14、完
2.2.2 安装后设置
编辑“ / etc / oratab”文件,将每个实例的重启标志设置为“ Y”。
DB11G:/u01/app/oracle/product/11.2.0.4/db_1:Y
三、常见问题
3.1 提示pdksh软件包不存在。
pdksh”软件包将被列出为丢失,可以忽略,因为我们安装了“ ksh”软件包。
3.2 在连接阶段,调用“ ins_emagent.mk”文件时会遇到错误
要解决此问题,请编辑“ $ ORACLE_HOME / sysman / lib / ins_emagent.mk”,进行搜索并替换下面显示的行。
从:
$(MK_EMAGENT_NMECTL)
至 :
$(MK_EMAGENT_NMECTL)-lnnz11
四、附录
4.1 自动启动脚本
以root用户身份创建一个名为“ /etc/init.d/dbora”的文件,其中包含以下代码。调整路径以匹配您的系统。
#!/bin/sh
# chkconfig: 345 99 10
# description: Oracle auto start-stop script.
#
# Set ORA_HOME to be equivalent to the $ORACLE_HOME
# from which you wish to execute dbstart and dbshut;
#
# Set ORA_OWNER to the user id of the owner of the
# Oracle database in ORA_HOME.
#ORA_HOME=/u01/app/oracle/product/10.2.0/db_1
#ORA_HOME=/u01/app/oracle/product/11.1.0/db_1
ORA_HOME=/u01/app/oracle/product/11.2.0.4/db_1
#ORA_HOME=/u01/app/oracle/product/12.1.0.2/db_1
#ORA_HOME=/u01/app/oracle/product/12.2.0.1/db_1
ORA_OWNER=oracle
export ORACLE_UNQNAME=db12c
if [ ! -f $ORA_HOME/bin/dbstart ]
then
echo "Oracle startup: cannot start"
exit
fi
case "$1" in
'start')
# Start the Oracle databases:
# The following command assumes that the oracle login
# will not prompt the user for any values
# Remove "&" if you don't want startup as a background process.
su $ORA_OWNER -c "$ORA_HOME/bin/dbstart $ORA_HOME" &
touch /var/lock/subsys/dbora
;;
'stop')
# Stop the Oracle databases:
# The following command assumes that the oracle login
# will not prompt the user for any values
su $ORA_OWNER -c "$ORA_HOME/bin/dbshut $ORA_HOME"
rm -f /var/lock/subsys/dbora
;;
esac
用chmod 命令修改权限为 750.
chmod 750 /etc/init.d/dbora
将“ dbora”服务与适当的运行级别相关联,并使用以下命令将其设置为自动启动。
chkconfig --add dbora
现在,相关实例应在系统启动/关闭时自动启动/关闭。
另附Oracle数据库版本介绍
首先来说下Oracle的版本背景。
根据Oracle的产品线规划,18c开始的新版本将是年度版,版本将是发布年度的最后两位数字。原本计划作为12.2.0.2的版本就是现在发布中的18c,12.2.0.3将以19c的版本形式发布。预期Oracle数据库19将是12.2的最后一个版本(“长期支持”版本)。
所以经历了8,8i,9i,10g,11g,12c之后,接下来的就是18c,19c,现在是2020年了,最新版本按照规划还是19c,可没有20c,要不会被笑话。
从版本V2发展至今,我细数了如下的一些版本情况。
版本发布年 | 版本 |
1979 | 2.3 |
1983 | 3.1.3 |
1984 | 4.1.4.0 |
1985 | 5.0.22 |
1988 | 6.0.17 |
1992 | 7.0.12 |
1997 | 8.0.3 |
1998 | 8.1.5.0 |
2001 | 9.0.1.0 |
2002 | 9.2.0.1 |
2003 | 10.1.0.2 |
2005 | 10.2.0.1 |
2007 | 11.1.0.6 |
2009 | 11.2.0.1 |
2013 | 12.1.0.1 |
2016 | 12.2.0.1 |
2018 | 18.1.0 |
2019 | 19c |
如果要从整体看出版本的差异情况,可以看下面的柱状图。
这个图没有体现版本之间的时间差,仅仅从版本的变化情况来看。
仅仅从这个图上就能够看出一种鲜明的差异,那就是类似SQL Server这样的年度版本,能够对于版本的差异没有那么敏感。
Oracle数据库版本规划
我们能够看到有很多的版本,如果要选择升级数据库,到底是选择12c还是18c,还是19c呢,我们来看一个版本路线图,可以参考在MOS 官方文章:Release Schedule of Current Database Releases (文档 ID 742060.1)
这个图是理解整个内容的核心,可以看到19c的定位是长期版本,而且扩展服务的截止时间是目前最长的。
相比而言18c的生命周期就会短许多,有点像昙花一些的过渡版本,从性价比来看似乎还不如早一些的12.2.0.1这个版本,如何和当时的时间背景联系起来,应该是一批早期用户从11g升级,在没有12.2版本发布时,选择了升级到12.1.0.2,所以看到的12.2.0.1和18c的发布时间也很接近。
值得一提的是,在2020年4月15日,Oracle修改了12.2.0.1的扩展服务截止时间,从2020年12月1日扩展到了2020年3月31日。(Added Limited Error Correction for 12.2.0.1 from Dec 1, 2020 until March 31, 2022)
Oracle数据库服务支持
对于扩展服务,我们可能有些陌生,大体分来,支持的强度分为三个级别:Premier Support(最高优先级的支持),Extended Support(中等优先级的支持),Sustaining Support(最低优先级的支持)。
如果和上面的图联系起来,其实就是对于扩展服务打了一些补丁,可以举个例子来说明,比如主流版本是11g,那么会有一个相对稳定产品生命周期,比如是5年,那么在这5年内是官方大力支持的阶段,会修复一系列的版本bug,推出一些改进和新功能,临近产品生命周期,就需要考虑升级,如果不升级服务支持力度上就会打一定的折扣,比如说扩展服务周期是2年,那么2年后正常来说是无法下载一些补丁更新的,如果过了扩展服务周期还没有升级,如果是大客户,花钱继续支持也可以,如果又跨越了多个时段,但是原来的版本支持还是需要,就需要做定制化的支持了。
对于数据库版本来说,10g是个坎,升级到11g是个坎,升级到12c的选择空间从上图来看就比较有限了,目前可选的就是12.2.0.1,18c和19c了。我们来看下这3个版本,我来划一下重点。
版本 | 补丁截止时间 | 备注和说明 | |
19c Long-Term Release | Mar 31, 2023 with no ES/ULA Mar 31, 2026 with ES/ULA |
| |
18c Annual Release | Jun 08, 2021 |
| |
12.2.0.1 Annual Release | * March 31, 2022 with Limited Error Correction from Dec 1, 2020 |
|
从上面的图来看,为了求稳,我们不是选择最接近的低版本,而是要首选尽可能稳定的大版本,避免后续的大版本改动。如果说得更清楚些,那就是选择19c.
版本的情况基本说完了,我们来看下升级的正确姿势,因为环境的差异,肯定初始版本都不大相同。
Oracle数据库版本升级矩阵
对于11g的数据库来说,如果是11g的最新版本,则可以直接升级到19c,这是一个极大的利好消息,避免了过渡升级带来的潜在隐患和服务不可用过长。
对于12c以上的版本(12.1.0.2以上),则可以直接升级到19c。
升级的过程可以考虑纯手工方式升级数据字典,也可以考虑使用DBUA来做。
Oracle 19c - Complete Checklist for Upgrading to Oracle Database 19c (19.x) using DBUA (Doc ID 2545064.1)
如果使用DBUA来升级,直接升级可以参考如下的表格:
Source Database | Target Database |
11.2.0.4 and Higher | 19.x |
12.1.0.2 | 19.x |
12.2.0.1 | 19.x |
18.1 | 19.x |
对于有些版本来说,则不可以直接升级,就需要过渡,比如你的版本是11.2.0.2,则需要先升级到11.2.0.4之后才可以升级到19c.
Source Database | Intermediate upgrade path | Target database | ||
11.2.0.1/11.2.0.2/11.2.0.3 | --> | 11.2.0.4 | --> | 19.x |
11.1.0.6/11.1.0.7 | --> | 11.2.0.4 | --> | 19.x |
10.2.0.2, 10.2.0.3, 10.2.0.4, 10.2.0.5 | --> | 11.2.0.4/12.1.0.2 | --> | 19.x |
10.1.0.5 | --> | 11.2.0.4/12.1.0.2 | --> | 19.x |
9.2.0.8 or earlier | --> | 11.2.0.4 | --> | 19.x |
12.1.0.1 | --> | 12.1.0.2/12.2.0.1 | --> | 19.x |
5 尝鲜新版本
此外,如果我们想先尝尝鲜,做下测试,
Oracle提供了另外两种方式来体验新版本,一种是LiveSQL,链接是
https://livesql.oracle.com,同时也可以通过dosc.oracle.com进行了解。
相关推荐
- Linux在线安装JDK1.8
-
首先在服务器pingwww.baidu.com查看是否可以连网然后就可以在线下载一、下载安装JDK1.81、在下载安装的同时做好一些准备工作...
- Linux安装JDK,超详细
-
1、了解RPMRPM是Red-HatPackageManager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux...
- Linux安装jdk1.8(超级详细)
-
前言最近刚购买了一台阿里云的服务器准备要搭建一个网站,正好将网站的一个完整搭建过程分享给大家!#一、下载jdk1.8首先我们需要去下载linux版本的jdk1.8安装包,我们有两种方式去下载安装...
- Linux系统安装JDK教程
-
下载jdk-8u151-linux-x64.tar.gz下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.ht...
- 干货|JDK下载安装与环境变量配置图文教程「超详细」
-
1.JDK介绍1.1什么是JDK?SUN公司提供了一套Java开发环境,简称JDK(JavaDevelopmentKit),它是整个Java的核心,其中包括Java编译器、Java运行工具、Jav...
- Linux下安装jdk1.8
-
一、安装环境操作系统:CentOSLinuxrelease7.6.1810(Core)JDK版本:1.8二、安装步骤1.下载安装包...
- Linux上安装JDK
-
以CentOS为例。检查是否已安装过jdk。yumlist--installed|grepjdk或者...
- Linux系统的一些常用目录以及介绍
-
根目录(/):“/”目录也称为根目录,位于Linux文件系统目录结构的顶层。在很多系统中,“/”目录是系统中的唯一分区。如果还有其他分区,必须挂载到“/”目录下某个位置。整个目录结构呈树形结构,因此也...
- Linux系统目录结构
-
一、系统目录结构几乎所有的计算机操作系统都是使用目录结构组织文件。具体来说就是在一个目录中存放子目录和文件,而在子目录中又会进一步存放子目录和文件,以此类推形成一个树状的文件结构,由于其结构很像一棵树...
- Linux文件查找
-
在Linux下通常find不很常用的,因为速度慢(find是直接查找硬盘),通常我们都是先使用whereis或者是locate来检查,如果真的找不到了,才以find来搜寻。为什么...
- 嵌入式linux基本操作之查找文件
-
对于很多初学者来说都习惯用windows操作系统,对于这个系统来说查找一个文件简直不在话下。而学习嵌入式开发行业之后,发现所用到的是嵌入式Linux操作系统,本想着跟windows类似,结果在操作的时...
- linux系统查看软件安装目录的方法
-
linux系统下怎么查看软件安装的目录?方法1:whereis软件名以查询nginx为例子...
- Linux下如何对目录中的文件进行统计
-
统计目录中的文件数量...
- Linux常见文件目录管理命令
-
touch用于创建空白文件touch文件名称mkdir用于创建空白目录还可以通过参数-p创建递归的目录...
- Linux常用查找文件方法总结
-
一、前言Linux系统提供了多种查找文件的命令,而且每种查找命令都具有其独特的优势,下面详细总结一下常用的几个Linux查找命令。二、which命令查找类型:二进制文件;...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- 关闭防火墙linux (53)