本文整理自网络,侵删。
在计算机信息安全领域中,数据库系统无疑有着举足轻重的地位。比如:SQL Server、MySQL、DB2、Oracle等,都是比较知名的数据库管理软件,由于Oracle数据库的安全性,所以在一些比较重要的场合被普遍使用,比如:电信、银行、政府部门等。
本次博文以Oracle 12c数据库的64位企业版为例,学习如何在Centos 操作系统中的安装和基本配置,包括安装的准备等。
博文大纲:
一、安装Oracle 12c
二、创建Oracle 12c数据库
三、Oracle 12c数据库的启动与关闭
四、将Oracle数据库设置为开机自启动
一、安装Oracle 12c
1.安装CentOS 7操作系统的注意事项
由于本次安装Oracle 12c软件是在CentOS 7系统上实现的,那么首次安装CentOS 7操作系统有几点要求:
- 防火墙的配置选项设置为禁用;
- SELinux设置为禁用;
- 默认安装设置为软件开发;
- 内核选择3.10.0-862.el7.x86_64及以上版本;
2.前置条件的准备
Oracle数据库是一个相对庞大的应用软件,对服务器的系统类型、内存和交换分区、硬盘空阿金、内核参数、软件环境、用户环境等都有相应的要求。只要满足了这些必备的条件,才能确保Oracle 12c安装成功并稳定运行。
(1)系统及配置要求
Oracle 12c明确支持的Linux操作系统包括Oracle Linux 7、Oracle Linux 6、Oracle Linux 5、Red Hat Enterprise Linux 7、Red Hat Enterprise Linux 6、Red Hat Enterprise Linux 5等,因为Red Hat Enterprise 和CentOS属于同步并行的操作系统,所以Oracle 12 c同样支持CentOS 7、CentOS 6、CentOS 5操作系统。在其他Linux系统中安装时,个别软件或配置文件可能需要进行适当的调整。
[root@localhost ~]# cat /etc/centos-release //查看系统版本信息 CentOS Linux release 7.5.1804 (Core) [root@localhost ~]# uname -r //查看系统内核信息 3.10.0-862.el7.x86_64
Linux操作系统要求:
- 物理内存:必须高于1GB,对于VMware虚拟机建议不少于2GB;
- 交换空间:物理内存为1~2GB时,交换分区为物理内存的1.5~2倍;物理内存为2~16GB时,交换分区于物理内存大小相同;物理内存超过16GB时,交换分区使用16GB就可以了;
如果交换分区空间不足的话,可以使用以下方式扩展交换分区
[root@localhost ~]# dd if=/dev/zero of=/swap_file bs=1024 count=2097152 //这是扩展了2GB的交换分区,2097152除以1024等于2048,所以是2GB [root@localhost ~]# mkswap /swap_file [root@localhost ~]# swapon /swap_file //完成之后,再次查询就会发现交换分区多了2GB的空间
[root@localhost ~]# grep MemTotal /proc/meminfo MemTotal: 7992344 kB [root@localhost ~]# grep SwapTotal /proc/meminfo SwapTotal: 18568716 kB //交换分区空间及内存空间已经满足要求
对于Oracle 12c数据库,若程序文件和数据文件安装在同一分区,则该分区硬盘空间的最要要求为企业级为6.4G,标准版6.1G;除此之外,还应确保/tmp目录的可用空间不少于1G。总的来说,建议安装Oracle 12c准备至少15G的硬盘空间。
[root@localhost ~]# df -hT /tmp //查看/tmp目录的磁盘使用情况 文件系统 类型 容量 已用 可用 已用% 挂载点 /dev/mapper/centos-root xfs 50G 21G 30G 42% / //很明显,满足了要求
安装Oracle数据库前,要求规划好主机名和IP。服务器的主机名、IP地址应提前确认无误,一旦Oracle数据库安装完成,建议不要轻易的修改主机名,否则会导致数据库启动失败。方法如下:
[root@localhost ~]# sed -i '1c oracle' /etc/hostname //设置主机名为oracle [root@localhost ~]# echo -e "192.168.1.1 oracle" >> /etc/hosts //添加主机名与IP地址的对应关系
(2)软件环境要求
Oracle 12c的安装过程通常是在图形界面中进行,因此建议使用已安装有GNOME中文桌面环境的CentOS服务器,软件开发工具当然是必不可少的,应使用yum方式安装以下必要的软件环境。
[root@localhost ~]# yum -y install binutils compat-* gcc gcc-c++ glibc glibc-devel ksh \ libaio libaio-devel libgcc libstdc++ libstdc++-devel libXi libXtst make sysstat \ unixODBC unixODBC-devel //使用本地光盘或者网络yum都可以
Oracle 12c自身集成了Java运行环境,但安装界面对中文的支持并不完善,因此若希望使用中文的Oracle安装界面,建议提前安装好Java软件包。
(3)内核要求
为了确保数据库运行稳定,Oracle 12c针对Linux内核参数,进程会话限制提出了一些要求,其中一部分设置可以在安装过程中自动检测并进行修复,但并一定很完整,所以最好的做法是根据安装文档提前进行配置。
内核参数调整体现在/etc/sysctl.conf文件中,主要包括与内存调度、端口范围、打开文件数、I/O请求等相关的一些设置,相关数值不可低于安装要求。如下:
[root@localhost ~]# vim /etc/sysctl.conf ……………… //省略部分内容,在末尾添加即可! fs.aio-max-nr = 1048576 fs.file-max = 6815744 kernel.shmall = 2097152 kernel.shmmax = 4294967295 kernel.shmmni = 4096 kernel.sem = 250 32000 100 128 net.ipv4.ip_local_port_range = 9000 65500 net.core.rmem_max = 4194304 net.core.rmem_default = 262144 net.core.wmem_default = 262144 net.core.wmem_max = 1048576 [root@localhost ~]# sysctl -p //重新加载配置文件
各参数详解:
- fs.aio-max-nr:此参数限制并发未完成的请求,应该设置避免I/O子系统故障;
- fs.file-max:该参数决定了系统中所允许的最大可以打开的文件数量;
- kernel.shmall:该参数控制可以使用的共享内存的总页数;.
- kernel.shmmax:是核心参数中最重要的参数之一,用于定义单个共享内存段的最大值。
- 建议:
- 32位linux系统:可取最大值为4GB(4294967296bytes)-1byte,即4294967295。建议值为多于内存的一半,所以如果是32为系统,一般可取值为4294967295。
- 64位linux系统:可取的最大值为物理内存值-1byte,建议值为多于物理内存的一半,例如,如果为12GB物理内存,可取1210241024*1024-1=12884901887。
- kernel.shmmni:该参数是共享内存段的最大数量。shmmni缺省值4096,一般肯定是够用了。
- kernel.sem:
- 以kernel.sem = 250 32000 100 128为例:
- 250是参数semmsl的值,表示一个信号量集合中能够包含的信号量最大数目。
- 32000是参数semmns的值,表示系统内可允许的信号量最大数目。
- 100是参数semopm的值,表示单个semopm()调用在一个信号量集合上可以执行的操作数量。
- 128是参数semmni的值,表示系统信号量集合总数。
- net.ipv4.ip_local_port_range:表示应用程序可使用的IPv4端口范围;
- net.core.rmem_default:表示套接字接收缓冲区大小的缺省值;
- net.core.rmem_max:表示套接字接收缓冲区大小的最大值;
- net.core.wmem_default:表示套接字发送缓冲区大小的缺省值;
- net.core.wmem_max:表示套接字发送缓冲区大小的最大值;
(4)Oracle用户环境要求
Oracle 12c需要固定的运行用户oracle、安装组oinstall、管理组dba,这些账号应提前创建好。用于存放Oracle程序及数据库文件的基本目录也应提前创建好。
[root@localhost ~]# groupadd oinstall [root@localhost ~]# groupadd dba [root@localhost ~]# useradd -g oinstall -G dba oracle [root@localhost ~]# echo '123456' | passwd --stdin oracle 更改用户 oracle 的密码 。 passwd:所有的身份验证令牌已经成功更新。 [root@localhost ~]# mkdir -p /u01/app/oracle [root@localhost ~]# chown -R oracle:oinstall /u01/app [root@localhost ~]# chmod -R 775 /u01/app/oracle
Oracle 12c的安装任务应以运行用户oracle的身份执行,需适当调整oracle用户的环境配置以满足需求。
[root@localhost ~]# vim /home/oracle/.bash_profile ……………… //省略部分内容,在末尾添加即可! umask 022 ORACLE_BASE=/u01/app/oracle #oracle基本目录 ORACLE_HOME=/u01/app/oracle/product/12.2.0/dbhome_1/ #安装家目录 ORACLE_SID=orcl #定义数据库实例名称 NLS_LANG="SIMPLIFIED CHINESE_CHINA".UTF8 #是针对Oracle语言、地区、字符集的设置 PATH=$PATH:$ORACLE_HOME/bin LANG=zh_CN.UTF-8 #LANG是针对Linux系统的语言、地区、字符集的设置。 DISPLAY=:0.0 #在哪个终端可以使用图形 export PATH LANG NLS_LANG ORACLE_BASE ORACLE_HOME ORACLE_SID DISPLAY #将变量导出为全局变量
(5)oracle用户资源限制要求
进程会话限制可以采用pam_limits认证模块来实现,通过修改登录程序login的PAM设置以启用该认证,然后修改/etc/security/limits.conf 文件,使用户oracle能够打开的进程数、进程使用的文件数加大。
[root@localhost ~]# vim /etc/pam.d/login ……………… //省略部分内容,在末尾添加即可! session required /lib/security/pam_limits.so session required pam_limits.so [root@localhost ~]# vim /etc/security/limits.conf ……………… //省略部分内容,在末尾添加即可! oracle soft nproc 2047 #设置进程数软限制 oracle hard nproc 16384 #设置进程数硬限制 oracle soft nofile 1024 #设置文件数软限制 oracle hard nofile 65536 #设置文件数硬限制 oracle soft stack 10240 # Oracle软堆栈限制
配置oracle用户资源限制,不配置也不会影响oracle数据库的成功安装,但是考虑到若有糟糕的sql语句对服务器资源的无限占用,导致长时间对用户请求无响应,建议提前限制oracle用户资源。
[root@localhost ~]# vim /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
准备工作完成后重新启动系统,重启之后,再次检查之前的配置是否生效。
3.Oracle 12c安装过程
Oracle的中文官方网址是https://www.oracle.com/index.html 可以自行进行下载,也可通过本人提供的Oracle安装包 进行安装。
[root@oracle ~]# cd / [root@oracle /]# unzip /root/linuxx64_12201_database.zip //进入根目录对下载的Oracle软件包进行解压 [root@oracle /]# ls database/ //解压之后生成database目录 install response rpm runInstaller sshsetup stage welcome.html
授权允许用户oracle使用图形终端,例如执行:xhost + oracle@localhost,表示允许用户oracle从本机访问,或者执行xhost + 表示取消所有限制,这里执行xhost +即可。
[root@oracle /]# xhost + //一定要以root用户的身份在图形环境中操作 [root@oracle /]# su - oracle //切换到oracle用户 [oracle@oracle ~]$ cd /database/ [oracle@oracle database]$ export DISPLAY=:0.0 设置DISPLAY环境变量 [oracle@oracle database]$ ./runInstaller //执行安装脚本
执行完成后会弹出图形化界面,进行以下操作:
执行过程中,会有这样的提示信息:
相关阅读 >>
更多相关阅读请进入《oracle》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。