网站首页 > 技术文章 正文
概述
目前centos 6由于大部分yum源已经停止了更新,在centos部署oracle数据库目前都转移至centos 7了,centos7部署oracle与centos6部署虽然大体相同,但是今天在实际部署的时候还是遇到了一些问题,下面分享一下具体过程。
一、环境描述
- 操作系统: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
现在,相关实例应在系统启动/关闭时自动启动/关闭。
猜你喜欢
- 2024-10-16 centos 7下Oracle12c静默安装 linux静默安装oracle11g步骤
- 2024-10-16 如何限制ip访问Oracle数据库? oracle in限制
- 2024-10-16 首次在Linux上安装Oracle数据库,需要提前做好哪些准备工作?
- 2024-10-16 Linux环境中oracle数据库启动过程
- 2024-10-16 lnmp环境下连接oracle数据库php连接oracle
- 2024-10-16 oracle 11g服务器,plsql客户端安装配置
- 2024-10-16 Oracle学习笔记(六)Oracle数据库基础
- 2024-10-16 3.Oracle集群安装—配置文件 oracle集群部署
- 2024-10-16 数据库笔试面试155——在Oracle中,创建ASM磁盘的方式有哪几种?
- 2024-10-16 Oracle数据库知识点及错误汇总 oracle数据库知识点及错误汇总表
你 发表评论:
欢迎- 05-10如何优化数据库和前端之间的交互?
- 05-10前端代码优化小秘籍(前端优化24条建议)
- 05-10VS Code当中的15个神仙插件,值得收藏
- 05-10如何自己开发一个Google浏览器插件?
- 05-10前端流行框架Vue3教程:14. 组件传递Props效验
- 05-10吃了一年的SU,最好用的插件都在这了
- 05-10前端必看!这款神器让网站界面告别千篇一律
- 05-10程序员请收好:10个非常有用的 Visual Studio Code 插件
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)