ORACLE-BASE - Oracle-Db-12cr2-Installation-On-Oracle-Linux-6-And-7
ORACLE-BASE - Oracle-Db-12cr2-Installation-On-Oracle-Linux-6-And-7
8i | 9i | 10g | 11g | 12c | 13c | 18c | 19c | 21c | Misc | PL/SQL | SQL | RAC | WebLogic | Linux
Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
This article describes the installation of Oracle Database 12c Release 2 (12.2) 64-bit on Oracle Linux 6 (OL6) and 7 (OL7) 64-bit. The article is
based on a server installation with a minimum of 2G swap and secure Linux set to permissive. An example of this type of Linux installation can
be seen here (OL6 or OL7).
Download Software
Unpack Files
Hosts File
Oracle Installation Prerequisites
Automatic Setup
Manual Setup
Additional Setup
Installation
Post Installation
Related articles.
Download Software
Download the Oracle software from OTN or MOS depending on your support status.
Unpack Files
Unzip the file.
unzip linuxx64_12201_database.zip
You should now have a single directory called "database" containing installation files.
Hosts File
The "/etc/hosts" file must contain a fully qualified name for the server.
For example.
ol7-122.localdomain
Automatic Setup
If you plan to use the "oracle-database-server-12cR2-preinstall" package to perform all your prerequisite setup, issue the following command.
It is probably worth doing a full update as well, but this is not strictly speaking necessary.
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 1/6
3/5/22, 9:07 AM ORACLE-BASE - Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
# yum update -y
It's worth running the all the YUM commands listed in the manual setup section. Depending on the OS package groups you have
selected, some additional packages might also be needed.
Manual Setup
If you have not used the "oracle-database-server-12cR2-preinstall" package to perform all prerequisites, you will need to manually perform the
following setup tasks.
Add the following lines to the "/etc/sysctl.conf" file, or in a file called "/etc/sysctl.d/98-oracle.conf".
fs.file-max = 6815744
kernel.sem = 250 32000 100 128
kernel.shmmni = 4096
kernel.shmall = 1073741824
kernel.shmmax = 4398046511104
kernel.panic_on_oops = 1
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048576
net.ipv4.conf.all.rp_filter = 2
net.ipv4.conf.default.rp_filter = 2
fs.aio-max-nr = 1048576
net.ipv4.ip_local_port_range = 9000 65500
Run one of the following commands to change the current kernel parameters, depending on which file you edited.
/sbin/sysctl -p
# Or
/sbin/sysctl -p /etc/sysctl.d/98-oracle.conf
Someone in the comments suggested you might need to add the previous lines into the "/etc/security/limits.conf" file also for CentOS7.
This is definitely not needed for OL7, but worth considering if the installer gives prerequisite failures for these settings.
The following packages are listed as required, including the 32-bit version of some of the packages. Many of the packages should be installed
already.
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 2/6
3/5/22, 9:07 AM ORACLE-BASE - Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 3/6
3/5/22, 9:07 AM ORACLE-BASE - Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
Additional Setup
The following steps must be performed, whether you did the manual or automatic setup.
passwd oracle
Set secure Linux to permissive by editing the "/etc/selinux/config" file, making sure the SELINUX flag is set as follows.
SELINUX=permissive
Once the change is complete, restart the server or run the following command.
# setenforce Permissive
If you have the Linux firewall enabled, you will need to disable or configure it, as shown here or here. To disable it, do the following.
If you are not using Oracle Linux and UEK, you will need to manually disable transparent huge pages.
mkdir -p /u01/app/oracle/product/12.2.0.1/db_1
chown -R oracle:oinstall /u01
chmod -R 775 /u01
Putting mount points directly under root without mounting separate disks to them is typically a bad idea. It's done here for simplicity, but
for a real installation "/" storage should be reserved for the OS.
Unless you are working from the console, or using SSH tunnelling, login as root and issue the following command.
xhost +<machine-name>
The scripts are created using the cat command, with all the "$" characters escaped. If you want to manually create these files, rather than
using the cat command, remember to remove the "\" characters before the "$" characters.
mkdir /home/oracle/scripts
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 4/6
3/5/22, 9:07 AM ORACLE-BASE - Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
export ORACLE_HOSTNAME=ol7-122.localdomain
export ORACLE_UNQNAME=cdb1
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=\$ORACLE_BASE/product/12.2.0.1/db_1
export ORACLE_SID=cdb1
export PATH=/usr/sbin:/usr/local/bin:\$PATH
export PATH=\$ORACLE_HOME/bin:\$PATH
export LD_LIBRARY_PATH=\$ORACLE_HOME/lib:/lib:/usr/lib
export CLASSPATH=\$ORACLE_HOME/jlib:\$ORACLE_HOME/rdbms/jlib
EOF
Add a reference to the "setEnv.sh" file at the end of the "/home/oracle/.bash_profile" file.
Create a "start_all.sh" and "stop_all.sh" script that can be called from a startup/shutdown service. Make sure the ownership and permissions are
correct.
export ORAENV_ASK=NO
. oraenv
export ORAENV_ASK=YES
dbstart \$ORACLE_HOME
EOF
export ORAENV_ASK=NO
. oraenv
export ORAENV_ASK=YES
dbshut \$ORACLE_HOME
EOF
Once the installation is complete and you've edited the "/etc/oratab", you should be able to start/stop the database with the following scripts
run from the "oracle" user.
~/scripts/start_all.sh
~/scripts/stop_all.sh
You can see how to create a Linux service to automatically start/stop the database here (OL6, OL7).
Installation
Log into the oracle user. If you are using X emulation then set the DISPLAY environmental variable.
Start the Oracle Universal Installer (OUI) by issuing the following command in the database directory.
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 5/6
3/5/22, 9:07 AM ORACLE-BASE - Oracle Database 12c Release 2 (12.2) Installation On Oracle Linux 6 (OL6) and 7 (OL7)
./runInstaller
You can see the type of installation I performed by clicking on the links below to see screen shots of each stage.
The "Database Configuration Assistant Complete" screen displays the Database Express 12c URL, which will be something like "https://ol7-
122.localdomain:5500/em".
Post Installation
Edit the "/etc/oratab" file setting the restart flag for each instance to 'Y'.
cdb1:/u01/app/oracle/product/12.2.0.1/db_1:Y
Home | Articles | Scripts | Blog | Certification | Videos | Misc | About
https://oracle-base.com/articles/12c/oracle-db-12cr2-installation-on-oracle-linux-6-and-7 6/6