当前位置: 澳门新濠3559 > 操作系统 > 正文

安装Oracle时的情景所谓是简历坎坷,所以将此次

时间:2019-11-07 21:41来源:操作系统
对linux和oracle一直是敬而远之,稍微有些了解.无奈由于工作需要这次要硬着头皮上了!@#!@@#$%^^ CentOS6.6安装Oracle11gr2 想起当初学习Oracle,安装Oracle时的情景所谓是简历坎坷,走了不少弯路,

对linux和oracle一直是敬而远之,稍微有些了解.无奈由于工作需要这次要硬着头皮上了!@#!@@#$%^^

CentOS6.6安装Oracle11gr2

想起当初学习Oracle,安装Oracle时的情景所谓是简历坎坷,走了不少弯路,学Oracle也有一段时间特写此文,帮初学Oracle的小伙伴们搭建一个基础的学习环境,本文详细描述了Oracle Database11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production在CentOS6.6上的安装和数据库配置的过程,以图文详细讲述了从VM虚拟机的创建,操作系统的安装,数据库的安装,到Oracle相关工具软件的安装。

本文在以下环境中安装完成:

Windows 7 旗舰版 Sevice Pack 1 内存 6G

VMware Workstation 11.0.0

CentOS-6.6-x86_64-bin-DVD1.iso

Oracle11GR2软件有两个软件可从Oracle官网上下载

linux.x64_11gR2_database_1of2.zip

linux.x64_11gR2_database_2of2.zip

Xmanager Enterprise 5 (Build 0436)

  1. 在vm中创建虚拟机

第一步:选择 自定义(高级)

图片 1

第二步: 默认

图片 2

第三步: 稍后安装操作系统

图片 3

第四步: Linux(L) 版本CentOS 64

图片 4

第五步:虚拟机名称,随意取,位置随意只要有空闲的磁盘空间就可以

图片 5

第六步:按照物理计算机的实际情况配置,我的是笔记本,一颗CPU 4核

图片 6

第七步:内存配置,最小1G,推荐2G,我的物理内存6G这里分配2G

图片 7

第八步: 使用权主机模式网络

图片 8

第九步:I/O类型默认

图片 9

第十步:虚拟磁盘类型 默认SCSI

图片 10

第十一步:创建新虚拟磁盘

图片 11

第十二步:最大磁盘大小 50G 将虚拟磁盘存储为单个文件

图片 12

第十三步:默认

图片 13

第十四步:查看摘要 完成

图片 14

第十五步:配置虚拟机设置,选择操作系统安装介质,选择CD/DVD(IDE)右边使用ISO映像文件,找到CentOS6.6的ISO 确定

图片 15

至此vm配置完成~~~~

2.操作系统安装

第一步:开户此虚拟机

图片 16

第二步:Install or upgrade on existing system

图片 17

第三步:询问是否测试安装介质 Skip

图片 18

第四步:Next

图片 19

第五步:语言选择,这里选择Chinese(Simplified)(中文(简体))

图片 20

第六步:键盘选择 美国英语式

图片 21

第七步:选择存储设备 基本存储设备

图片 22

第八步:因为是在虚拟磁盘中安装系统,所以选择 是,忽略所有数据

图片 23

第九步:默认,主机名安装完系统以后设置

图片 24

第十步时区选择,上海,不选系统时钟使用UTC时间

图片 25

第十一步:设置操作系统超级用户(root)密码

图片 26

第十二步:询问要怎么创建磁盘分区 创建自定义布局

图片 27

第十三步:创建分区,一个boot分区200M,一个根(/)分区40G,一个tmp分区10G,一个交换分区998M,其实这里相对于安装Oracle,交换分区太小, 安装Oracle 11G r2的swap的需求是物理内存在1G-2G之间的话 swap是物理内存的1.5倍,如果物理内存在2G-16G之间的话,swap等于物理内存就好.这里我是故意分配的,之后在增加swap大小,建议swap大小按文档来,分配大一点,朋友们安装可以分配大一点.以后就可以不用增加swap

图片 28

第十四步:默认

图片 29

第十五步:选择安装的服务器类型 Basic Server

图片 30

第十六步:开始安装

图片 31

第十七步:安装完成,重新引导

图片 32

3.安装环境环境配置

网络配置 :网络配置要示虚拟机网络配置而定,安装vm的时候我们选择的是仅主机所以在系统中只需要

设置IP地址和子网掩码,设置完后重启网络接口就可以使用ssh登录了.

图片 33

4.使用xmaanger xshell中的ssh连接Centos,填入用户名和密码后可爱的界面就出来了

图片 34

5.上传 Oracle安装所需要的软件 在xshell界面中点新建文件传输选择要上传的文件

图片 35

以下就是我们刚刚上传的软件,不知道有什么用的,请自行google

图片 36

6.为方便软件的安装需要配置yum源,Oracle所需包基本都在安装光盘的ISO文件中有了,所以只需配置

本地yum,所以还得上传CentOS的安装镜像

# mkdir /cdrom

# mount -t iso9660 -o loop /software/CentOS-6.6-x86_64-bin-DVD1.iso /cdrom

# echo '/software/CentOS-6.6-x86_64-bin-DVD1.iso /cdrom/ iso9660 loop 0 0' >> /etc/fstab

# cd /etc/yum.repos.d/

# rm -rf *

# vim cdrom.repo 添加

[cdrom]

name=cdrom

baseurl=file:///cdrom

enabled=1

gkgcheck=1

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

# yum clean all

# yum makecache all

7.安装Linux的一些基础开发包

# export LANG=en_US.UTF-8

# yum grouplist

export命令用于设置当前会话语言环境为英文,因为下一条命令yum grouplist列出软件包组为中文的话就太难看了

# yum groupinstall -y " Desktop Platform Development" "Development tools" "Compatibility libraries"

为了使Oracle安装的界面出现在我们本地的桌面上还得安装gdm和xdpyinfo

yum -y install gdm

yum -y install xdpyinfo

8.Oracle安装的前期准备

oracle官方文档位置:

# groupadd oinstall

# groupadd dba

# useradd -g oinstall -G dba oracle

# id oracle

uid=500(oracle) gid=500(oinstall) groups=500(oinstall),501(dba)

# mkdir -p /u01/app/oracle

# chown -R oracle.oinstall /u01

# chmod -R 775 /u01

这些命令没有人不懂了吧

配置内核参数和资源限制

# vim /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

# sysctl -p

更改shell限制

# vim /etc/security/limits.conf

oracle soft nproc 2047

oracle hard nproc 16384

oracle soft nofile 1024

oracle hard nofile 65536

还必须添加以下内容到vim /etc/pam.d/login

# vim /etc/pam.d/login

session required /lib/security/pam_limits.so

更改登录脚本

将以下内容添加到/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

# unzip linux.x64_11gR2_database_1of2.zip -d /tmp/

# unzip linux.x64_11gR2_database_1of2.zip -d /tmp/

# chown -R oracle.oinstall /tmp/database/

oracle安装界面乱码的解决

mkdir -p /usr/share/fonts/zh_CN/TrueType

[[email protected] ~]# cp /software/zysong.ttf /usr/share/fonts/zh_CN/TrueType

把主机名和ip地址的对应关系加入/etc/hosts文件,要不然安装过程中会出错

# echo '192.168.23.200 Oracle.Study' >> /etc/hosts

添加一个新的交换分区大小10,分区类型为82

# fdisk /dev/sdb

# swapon -s 查看当前swap情况

# mkswap /dev/sdb1 设置swap

# swapon /dev/sdb1

[[email protected] ~]# swapon -s

Filename Type Size Used Priority

/dev/sda5 partition 1021948 0 -1

/dev/sdb1 partition 10490408 0 -2

开机挂载并设置优先级

# vim /etc/fstab

# echo "/dev/sdb1 swap swap defaults,pri=1 0 0" >> /etc/fstab

pri为优先级,可以看到新添加的swap出来了。

图片 37

至此设置完毕,下一步开始Oracle的安装,下一步之前必须重启机器

9.Oracle的安装

# xhost +

access control disabled, clients can connect from any host

# su - oracle

$ w

19:34:08 up 6 min, 1 user, load average: 0.11, 0.08, 0.03

USER TTY FROM [email protected] IDLE JCPU PCPU WHAT

root pts/0 192.168.23.1 19:28 0.00s 0.19s 0.00s w

$ export DISPLAY=192.168.23.1:0.0

$ cd /tmp/database/

$ ./runInstaller

图片 38

下面可爱的中文图形界面就出来了:

图片 39

仅安装数据库软件

图片 40

单实例数据库安装

图片 41

默认

图片 42

企业版

图片 43

指定安装位置

基目录 :/u01/app/oracle

软件位置 :/u01/app/oracle/product/11.2.0/db_1

图片 44

创建产品清单

图片 45

特权操作系统组:默认

图片 46

执行先决条件检查:这里只需要安装64位包,32位包可以忽略

图片 47#yum -y install elfutils-libelf-devel unixODBC unixODBC-devel libaio-devel

#cd /software/

#yum localinstall pdksh-5.2.14-37.el5_8.1.x86_64.rpm

图片 48

开始安装:

图片 49

安装过程:

图片 50

以root用户执行以下两个脚本

图片 51

安装完成:

图片 52

10.为oracle用户添加环境变量

export ORACLE_BASE=/u01/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1

export PATH=$ORACLE_HOME/bin:$PATH

export LD_LIBRARY_PATH $ORACLE_HOME/lib:/usr/lib:/usr/lib64

至此Oracle安装完成 ,接下来还要还要创建数据库实例.
源文:

想起当初学习Oracle,安装Oracle时的情景所谓是简历坎坷,走了不少弯路,学Oracle也有一段时间特写此文,帮初学Oracle的...

        近两天在CentOS7上安装了oracle,在网上找了一些资料,发现不是很全面,为了方便以后再次安装,所以将此次安装记录下来,如果有不正确的地方,希望指出。

如何使用自动化安装程序? - 安装 Oracle Solaris 11 系统

对于重windows用户的我来说,简直是万种折磨.

以下参考:CentOS7安装Oracle 11gR2 图文详解_数据库技术_Linux公社-Linux系统门户网站

Oracle安装:使用响应文件静默安装_数据库技术_Linux公社-Linux系统门户网站

算是做个记录吧,一定要坚持下去.

                   centos安装oracle 11g 完全图解 - 郑文亮 - 博客园

Oracle之参数文件探究_数据库技术_Linux公社-Linux系统门户网站

准备

1,vmware 

2,centos 7 

CentOS下载

3,oracle 11g

原先打算在官网下,无奈要注册还英文乱78遭的后来找到了这里

4,xftp & xshell

传文件和远程登录用,这个网站广告少挺不错的,抽时间上去再收集点

一、环境准备

1.VMware-workstation-full-11.1.0-2496824.exe

2.CentOS-7-x86_64DVD1511.iso

3.linux.x64_11gR2_database_1of2.zip

4.linux.x64_11gR2_database_2of2.zip

Oracle主要配置文件介绍_数据库技术_Linux公社-Linux系统门户网站

安装教程步骤

搜了一大堆,视频也有看,还是这两个简单明了,照着一步步来,还是碰到不少坑!

Centos7下安装Oracle11g r2 - 慕河河 - 博客园 (部署部分详尽)

 

Linux上安装Oracle的辛酸史 - CSDN博客 (oracle安装步骤清楚,都有截图)

 

二、安装Oracle前的准备工作

1.创建运行oracle数据库的系统用户和用户组

[sonny@localhost ~]$ su root  #切换到root

Password:

[root@localhost sonny]# groupadd oinstall  #创建用户组oinstall

[root@localhost sonny]# groupadd dba  #创建用户组dba

[root@localhost sonny]# useradd -g oinstall -g dba -m oracle  #创建oracle用户,并加入到oinstall和dba用户组

[root@localhost sonny]# passwd oracle  #设置用户oracle的登陆密码,不设置密码,在CentOS的图形登陆界面没法登陆

Changing password for user oracle.

New password:   # 密码

BAD PASSWORD: The password is shorter than 8 characters

Retype new password:   # 确认密码

passwd: all authentication tokens updated successfully.

[root@localhost sonny]# id oracle # 查看新建的oracle用户

uid=1001(oracle) gid=1002(dba) groups=1002(dba)

[root@localhost sonny]#

为什么要创建oinstall用户组及dba组? 

参考:在 Oracle Enterprise Linux 和 iSCSI 上构建您自己的 Oracle RAC 11g 集群,第 2 页

2.创建oracle数据库安装目录

[sonny@localhost ~]$ su root

Password:

[root@localhost sonny]# mkdir -p /data/oracle  #oracle数据库安装目录

[root@localhost sonny]# mkdir -p /data/oraInventory  #oracle数据库配置文件目录

[root@localhost sonny]# mkdir -p /data/database  #oracle数据库软件包解压目录

[root@localhost sonny]# cd /data

[root@localhost data]# ls  #创建完毕检查一下

database  oracle  oraInventory

[root@localhost data]# chown -R oracle:oinstall /data/oracle  #设置目录所有者为oinstall用户组的oracle用户

[root@localhost data]# chown -R oracle:oinstall /data/oraInventory

[root@localhost data]# chown -R oracle:oinstall /data/database

[root@localhost data]#

3.修改OS系统标识

oracle默认不支持CentOS系统安装,我安装是64位数据库,On Linux x86-64:Red Hat Enterprise Linux 7  (RHEL 7)

另外,CentOS7.0.1511 基于 RHEL7.2  参考:CentOS 7-1511 发布下载_Linux下载_Linux公社-Linux系统门户网站

修改文件 /etc/RedHat-release

[sonny@localhost data]$ su root

Password:

[root@localhost data]# cat /proc/version

Linux version 3.10.0-327.el7.x86_64 (builder@kbuilder.dev.centos.org) (gcc version 4.8.3 20140911 (Red Hat 4.8.3-9) (GCC) ) #1 SMP Thu Nov 19 22:10:57 UTC 2015

[root@localhost data]# cat /etc/redhat-release

CentOS Linux release 7.2.1511 (Core)

[root@localhost data]# vi /etc/redhat-release

[root@localhost data]# cat /etc/redhat-release

redhat-7

[root@localhost data]#

4.安装oracle数据库所需要的软件包

Oracle Database Package Requirements for Linux x86-64 如下:(参考:docs.oracle.com/cd/E11882_01/install.112/e47689/pre_install.htm#BABCFJFG)

操作系统:Oracle Linux 7 and Red Hat Enterprise Linux 7

The following packages (or later versions) must be installed:

在我参考的那篇文章里因为写了具体要安装的具体版本信息,所以我也是那样写的,结果运行时一直出现没有这个命令,后来查了一些东西问了别人,做出修改,如下:

yum install binutils-*.x86_64

yum install compat-libcap1-*.x86_64

yum install gcc-*.x86_64

yum install gcc-c++-*.x86_64

yum install glibc-*.i686

yum install glibc-*.x86_64

yum install glibc-devel-*.i686

yum install glibc-devel-*.x86_64

yum install ksh-*

yum install libaio-*.i686

yum install libaio-*.x86_64

yum install libaio-devel-*.i686

yum install libaio-devel-*.x86_64

yum install libgcc-*.i686

yum install libgcc-*.x86_64

yum install libstdc++-*.i686

yum install libstdc++-*.x86_64

yum install libstdc++-devel-*.i686

yum install libstdc++-devel-*.x86_64

yum install libXi-*.i686

yum install libXi-*.x86_64

yum install libXtst-*.i686

yum install libXtst-*.x86_64

yum install make-*.x86_64

yum install sysstat-*.x86_64

[sonny@localhost data]$ su root

Password:

[root@localhost data]# yum install binutils

对于软件包的安装这里,也有部分文章采用的是rpm而不是yum,yum的好处简单来说:

<1>能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。

<2>yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而且命令简洁而又好记。

参考文章:linux yum命令详解 - chuncn - 博客园

                     Linux rpm 命令参数使用详解[介绍和应用] - 小炒花生米 - 博客园

                     rpm命令与yum命令_絮絮落英_新浪博客

5.关闭防火墙 CentOS 7.2默认使用的是firewall作为防火墙

[sonny@localhost /]$ su root

Password:

[root@localhost /]# systemctl status firewalld.service  #查看防火墙状态,运行中

● firewalld.service - firewalld - dynamic firewall daemon

Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)

Active: active (running) since Thu 2016-04-07 18:54:29 PDT; 2h 20min ago

Main PID: 802 (firewalld)

CGroup: /system.slice/firewalld.service

└─802 /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid

Apr 07 18:54:25 localhost.localdomain systemd[1]: Starting firewalld - dynamic firewall daemon...

Apr 07 18:54:29 localhost.localdomain systemd[1]: Started firewalld - dynamic firewall daemon.

[root@localhost /]# systemctl stop firewalld.service  #关闭防火墙

[root@localhost /]# systemctl status firewalld.service  #再次查看防火墙状态,发现已关闭

● firewalld.service - firewalld - dynamic firewall daemon

Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)

Active: inactive (dead) since Thu 2016-04-07 21:15:34 PDT; 9s ago

Main PID: 802 (code=exited, status=0/SUCCESS)

Apr 07 18:54:25 localhost.localdomain systemd[1]: Starting firewalld - dynamic firewall daemon...

Apr 07 18:54:29 localhost.localdomain systemd[1]: Started firewalld - dynamic firewall daemon.

Apr 07 21:15:33 localhost systemd[1]: Stopping firewalld - dynamic firewall daemon...

Apr 07 21:15:34 localhost systemd[1]: Stopped firewalld - dynamic firewall daemon.

[root@localhost /]# systemctl disable firewalld.service  #禁止使用防火墙(重启也是禁止的)

Removed symlink /etc/systemd/system/dbus-org.Fedoraproject.FirewallD1.service.

Removed symlink /etc/systemd/system/basic.target.wants/firewalld.service.

[root@localhost /]#

6.关闭selinux(需重启生效)

[root@localhost /]# vi /etc/selinux/config

[root@localhost /]# cat /etc/selinux/config

# This file controls the state of SELinux on the system.

# SELINUX= can take one of these three values:

#    enforcing - SELinux security policy is enforced.

#    permissive - SELinux prints warnings instead of enforcing.

#    disabled - No SELinux policy is loaded.

SELINUX=disabled  #此处修改为disabled

# SELINUXTYPE= can take one of three two values:

#    targeted - Targeted processes are protected,

#    minimum - Modification of targeted policy. Only selected processes are protected.

#    mls - Multi Level Security protection.

SELINUXTYPE=targeted

[root@localhost /]#

7.修改内核参数

加粗斜体部分为添加代码

[sonny@localhost /]$ su root

Password:

 [root@localhost /]# vi /etc/sysctl.conf 

[root@localhost /]# cat /etc/sysctl.conf

cat: /etc/sysct.conf: No such file or directory

[root@localhost /]# cat /etc/sysctl.conf 

# System default settings live in /usr/lib/sysctl.d/00-system.conf.

# To override those settings, enter new settings here, or in an /etc/sysctl.d/.conf file

#

# For more information, see sysctl.conf(5) and sysctl.d(5).

net.ipv4.icmp_echo_ignore_broadcasts = 1

net.ipv4.conf.all.rp_filter = 1

fs.file-max = 6815744 #设置最大打开文件数

fs.aio-max-nr = 1048576

kernel.shmall = 2097152 #共享内存的总量,8G内存设置:20971524k/1024/1024*

kernel.shmmax = 2147483648 #最大共享内存的段大小

kernel.shmmni = 4096 #整个系统共享内存端的最大数

kernel.sem = 250 32000 100 128

net.ipv4.ip_local_port_range = 9000 65500 #可使用的IPv4端口范围

net.core.rmem_default = 262144

net.core.rmem_max= 4194304

net.core.wmem_default= 262144

net.core.wmem_max= 1048576

[root@localhost /]#

使配置参数生效

[root@localhost /]# sysctl -p

net.ipv4.icmp_echo_ignore_broadcasts = 1

net.ipv4.conf.all.rp_filter = 1

sysctl: setting key "fs.file-max": Invalid argument

fs.file-max = 6815744 #设置最大打开文件数

fs.aio-max-nr = 1048576

sysctl: setting key "kernel.shmall": Invalid argument

kernel.shmall = 2097152 #共享内存的总量,8G内存设置:2097152*4k/1024/1024

sysctl: setting key "kernel.shmmax": Invalid argument

kernel.shmmax = 2147483648 #最大共享内存的段大小

sysctl: setting key "kernel.shmmni": Invalid argument

kernel.shmmni = 4096 #整个系统共享内存端的最大数

kernel.sem = 250 32000 100 128

sysctl: setting key "net.ipv4.ip_local_port_range": Invalid argument

net.ipv4.ip_local_port_range = 9000 65500 #可使用的IPv4端口范围

net.core.rmem_default = 262144

net.core.rmem_max = 4194304

net.core.wmem_default = 262144

net.core.wmem_max = 1048576

[root@localhost /]#

注:关于systctl的解释:Sysctl是一个允许改变正在运行中的Linux系统的接口,它包含一些 TCP/IP 堆栈和虚拟内存系统的高级选项。

参考文章:用Sysctl 调整Linux操作系统的性能 - 张善友 - 博客园

8.对oracle用户设置限制,提高软件运行性能(加粗斜体为添加部分)

[sonny@localhost /]$ su root

Password:

[root@localhost /]# vi /etc/security/limits.conf 

[root@localhost /]# cat /etc/security/limits.conf

# /etc/security/limits.conf

#

#This file sets the resource limits for the users logged in via PAM.

#It does not affect resource limits of the system services.

#

#Also note that configuration files in /etc/security/limits.d directory,

#which are read in alphabetical order, override the settings in this

#file in case the domain is the same or more specific.

#That means for example that setting a limit for wildcard domain here

#can be overriden with a wildcard setting in a config file in the

#subdirectory, but a user specific setting here can be overriden only

#with a user specific setting in the subdirectory.

#

#Each line describes a limit for a user in the form:

#

#Where:#can be:

#        - a user name

#        - a group name, with @group syntax

#        - the wildcard *, for default entry

#        - the wildcard %, can be also used with %group syntax,

#                for maxlogin limit##can have the two values:#        - "soft" for enforcing the soft limits

#        - "hard" for enforcing hard limits##can be one of the following:

#        - core - limits the core file size (KB)

#        - data - max data size (KB)

#        - fsize - maximum filesize (KB)

#        - memlock - max locked-in-memory address space (KB)

#        - nofile - max number of open file descriptors

#        - rss - max resident set size (KB)

#        - stack - max stack size (KB)

#        - cpu - max CPU time (MIN)

#        - nproc - max number of processes

#        - as - address space limit (KB)

#        - maxlogins - max number of logins for this user

#        - maxsyslogins - max number of logins on the system

#        - priority - the priority to run user process with

#        - locks - max number of file locks the user can hold

#        - sigpending - max number of pending signals

#        - msgqueue - max memory used by POSIX message queues (bytes)

#        - nice - max nice priority allowed to raise to values: [-20, 19]

#        - rtprio - max realtime priority

#

#*              soft    core            0

#*              hard    rss            10000

#@student        hard    nproc          20

#@faculty        soft    nproc          20

#@faculty        hard    nproc          50

#ftp            hard    nproc          0

#@student        -      maxlogins      4

oracle soft nproc 2047

oracle hard nproc 16384

oracle soft nofile 1024

oracle hard nofile 65536

# End of file

[root@localhost /]#

9.配置用户的环境变量(加粗斜体部分为添加代码)

[root@localhost /]# vi /home/oracle/.bash_profile

[root@localhost /]# cat /home/oracle/.bash_profile

# .bash_profile

# Get the aliases and functions

if [ -f ~/.bashrc ]; then

. ~/.bashrc

fi

# User specific environment and startup programs

PATH=$PATH:$HOME/.local/bin:$HOME/bin

export PATH

export ORACLE_BASE=/data/oracle #oracle数据库安装目录

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1 #oracle数据库路径

export ORACLE_SID=orcl #oracle启动数据库实例名

export ORACLE_TERM=xterm #xterm窗口模式安装

export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH #添加系统环境变量

export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib #添加系统环境变量

export LANG=C #防止安装过程出现乱码

export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK  #设置Oracle客户端字符集,必须与Oracle安装时设置的字符集保持一致,如:ZHS16GBK,否则出现数据导入导出中文乱码问题

[root@localhost /]#

使上述配置立即生效:

[oracle@localhost /]$ su root

Password:

[root@localhost /]# source /home/oracle/.bash_profile

[root@localhost /]#

10.上传安装包,我也是用xftp上传的,很好用的工具,将oracle安装包上传到/usr/local/src

11.解压安装包

[oracle@localhost /]$ cd /usr/local/src  #进入/usr/local/src目录

[oracle@localhost src]$ ls

linux.x64_11gR2_database_1of2.zip  linux.x64_11gR2_database_2of2.zip

[oracle@localhost src]$ unzip linux.x64_11gR2_database_1of2.zip -d /data/database/  #解压

(省略...)

[oracle@localhost src]$ unzip linux.x64_11gR2_database_2of2.zip -d /data/database/  #解压

(省略...)

[oracle@localhost src]$ su root

Password:

[root@localhost src]# chown -R oracle:oinstall /data/database/database/

[root@localhost src]#

接下来终于到了oracle的安装啦,小伙伴们,要加油奥。

三、oracle安装

我昨天安装没有截图,可以参考:CentOS7安装Oracle 11gR2 图文详解 第3页_数据库技术_Linux公社-Linux系统门户网站

1.图形界面登陆oracle用户

2.启动oralce安装,到/data/database/database/目录下,执行./runInstaller

这里会出现乱码情况,解决如下:

先执行:export LANG=zh_CN.UTF-8 【中文】      export LANG=en_US.UTF-8 【英文】

再运行:./runInstaller

3.去掉勾,Email可以不用填写,个人使用环境不需要自动接收Oracle的安全更新。

4.下一步,只安装数据库软件,选择install database software only

5.选择单例安装,前面的所有配置均为单例安装。

6.添加语言,选择English(united Kingdom)

7.默认安装版本企业版-Enterprise Edition

8.确定数据软件的安装路径,自动读取前面Oracle环境变量中配置的值,我是默认安装路径。

9.理论上要创建Database Operation(OSOPER)Group:oper ,个人用,可以就使用dba用户组

10.安装检查,按照提示信息一个一个解决。

swap空间不足解决 :(要求2.67G 实际2G)

[root@localhost oracle]# free -m  #查看当前虚拟内存

total        used        free      shared  buff/cache  available

Mem:          1824        1369          93          10        361        250

Swap:          2048          20        2028

[root@localhost oracle]# dd if=/dev/zero of=/home/swap bs=1024 count=1024000  #将当前swap空间由2048M 增加到 3048M 新增一个2014的swap文件

1024000+0 records in

1024000+0 records out

1048576000 bytes (1.0 GB) copied, 29.4051 s, 35.7 MB/s

[root@localhost oracle]# mkswap /home/swap

Setting up swapspace version 1, size = 1023996 KiB

no label, UUID=5e3d39d7-285e-4c74-b321-1e2b3ffabf83

[root@localhost oracle]# free -m

total        used        free      shared  buff/cache  available

Mem:          1824        1275          95          10        454        342

Swap:          2048        141        1907

[root@localhost oracle]# swapon /home/swap  #增加并启用虚拟内容

swapon: /home/swap: insecure permissions 0644, 0600 suggested.

[root@localhost oracle]# free -m  #再次查看

total        used        free      shared  buff/cache  available

Mem:          1824        1275          94          10        454        342

Swap:          3048        141        2907

注:增加swap的时候注意后面是几个零奥,不要写错了,我第一次少写了一个0,后来又增加了一个swap1。

11.一个一个检查package,在准备阶段中漏掉的,此处再安装,有些系统报错是因为现有的包的版本比检测要高,最后忽略即可

12.准备完毕,fuck “Finish”开始安装

13.安装过程是一个漫长的过程,中间有几次卡住,没有出现任何画面,屏幕中间有条小线,尝试多次,发现光标在该线上,右键点击Closed。

注:这里的线是一个消息提示框,可以拉伸开来,查看具体信息。

14.提示安装成功

注:安装过程中(我是第8步,安装路径那里),有时会出现界面卡着一直不动,我就遇到了这种情况,点击关闭什么的都没有反应,没办法只好用kill杀死进程。这里大概遇到了4、5次,最后请教别人才发现,我的空间不够,因为安装了好几次,所以安装日志就有好多,删了前面的那些安装日志,再重新开始运行./runInstaller就可以了。

查看进程号:ps -ef | grep java

杀死进程方法:kill -9 进程号

四、配置监听listener

1.执行netca 报错

[Oracle@localhost ~]$ netca

Oracle Net Services Configuration:

#

# An unexpected error has been detected by HotSpot Virtual Machine:

#

#  SIGSEGV (0xb) at pc=0x00007f69a69fcb9d, pid=8033, tid=140092892297024

#

# Java VM: Java HotSpot(TM) 64-Bit Server VM (1.5.0_17-b03 mixed mode)

# Problematic frame:

# C  [libclntsh.so.11.1+0x62ab9d]  snlinGetAddrInfo+0x1b1

#

# An error report file with more information is saved as hs_err_pid8033.log

#

# If you would like to submit a bug report, please visit:

#

/data/oracle/product/11.2.0/db_1/bin/netca: line 178:  8033 Aborted                (core dumped) $JRE $JRE_OPTIONS -classpath $CLASSPATH oracle.net.ca.NetCA $*

[oracle@localhost ~]$

错误原因:安装操作系统是默认主机名localhost造成错误

解决办法:

[racle]# cat /etc/sysconfig/network

# Created by anaconda

[root@localhost oracle]# vi /etc/sysconfig/network  #增加HOSTNAME

[root@localhost oracle]# cat /etc/sysconfig/network

# Created by anaconda

HOSTNAME=odb-sonny

[root@localhost oracle]# cat /etc/hosts

127.0.0.1  localhost localhost.localdomain localhost4 localhost4.localdomain4

::1        localhost localhost.localdomain localhost6 localhost6.localdomain6

[root@localhost oracle]# vi /etc/hosts  #增加HOSTNAME

[root@localhost oracle]# cat /etc/hosts

127.0.0.1  localhost localhost.localdomain localhost4 localhost4.localdomain4 odb-sonny

::1        localhost localhost.localdomain localhost6 localhost6.localdomain6

[root@localhost oracle]# hostname odb-sonny  #执行

[root@localhost oracle]#

最后注销当前oracle用户,重新登陆即可!

五、创建Oracle数据实例Orcl

注意:必须先创建监听,并且监听是启动中,否则报错。

su – oracle #切换到oracle用户

dbca #启动oracle实例安装界面

Next

选择第一项:创建数据库

Next

默认选择第一项:一般用途或事务处理

Next

全局数据库名:orcl

SID:orcl

Next

默认即可,Next

口令配置,可以为每个账户设置不同的口令,也可以为所有账户设置一个相同的口令

选择第二项:所有账户使用同一管理口令

Next

存储类型:文件系统

存储位置:使用模版中的数据库文件位置

Next

默认选择:指定快速恢复区

Next

快速恢复区大小设置,如果系统剩余空间小于设置值会出现上面的提示

Next

默认,Next

切换到调整大小:进程300(可以根据服务器配置设置)

切换到字符集设置

选择第三项:从字符集列表中选择

选择:ZHS16GBK- GBK 16-bit Simplified Chinese

国家字符集:AL16UTF16-Unicode UTF-16 Universal character set

默认语言:Simplified Chinese

默认地区:China

切换到连接模式,选择:专用服务器模式

Next

全部设置完成之后,点Finish

勾选:创建数据库

勾选:生成数据库创建脚本

点Finish

Ok

Ok

Ok

注意:这里如果出现上面的提示,可以等安装完成之后用root账号登录,执行下面两个命令

/data/oracle/product/11.2.0/db_1/root.sh

/data/oraInventory/orainstRoot.sh

生成/etc/oratab文件

正在创建数据库

数据库创建完成,点Exit退出

六、启动oracle数据库

su – oracle #切换到oracle用户

sqlplus /nolog #进入sqlplus

conn / as sysdba #以超级管理员权限登录

startup #启动数据库实例

quit #退出

lsnrctl start #启动监听

startup参数说明:

startup #不带任何参数,启动数据库实例并打开数据库,一般选择这种启动方式

startup nomount #只启动数据库实例,不打开数据库,一般用于创建新的数据库时使用

startup mount #启动数据库实例,并加载数据库,但不打开数据库,一般用于修改数据库名称等管理时使用

七、关闭oracle数据库

su – oracle #切换到oracle用户

lsnrctl stop #关闭监听器

sqlplus /nolog #进入sqlplus

shutdown immediate #关闭数据库实例

quit #退出

注:sqlplus /nolog  /nolog是不登陆到数据库服务器的意思,如果不加 /nolog sqlplus会提示输入用户名和密码。

参考文献:www.360doc.com/content/10/1119/14/2614615_70659801.shtml

shutdown参数说明:

normal #等待所有的用户断开连接,执行命令后不允许新连接

immediate #等待用户完成当前的语句后,再断开用户连接,不允许新用户连接

transactional #等待用户完成当前的事务后断开连接,不允许新用户连接

abort #强行断开连接并直接关闭数据库

前面三种方法不会导致数据库出错,最后一种方法非特殊状况不建议使用,

一般使用shutdown immediate关闭数据库

备注:如果执行shutdown immediate出现ORA-01012: not logged on错误

请先执行以下语句

ps -ef|grep ora_dbw0_$orcl

kill -9 pid #pid为进程号

其中orcl 是数据库的SID

八、设置oracle开机启动

说明:linux下默认安装完Oracle后不会实现开机自启动

1、su – root #切换到root用户操作

/data/oracle/product/11.2.0/db_1/root.sh #执行脚本,生成/etc/oratab文件

/data/oraInventory/orainstRoot.sh

2、vi /etc/oratab  #编辑

找到:$ORACLE_SID:$ORACLE_HOME::

取消前面的#注释,修改为:

orcl:/data/oracle/product/11.2.0/db_1:Y  #orcl为oracle数据库实例名称

:wq! #保存退出

3、vi /data/oracle/product/11.2.0/db_1/bin/dbstart #编辑

找到:ORACLE_HOME_LISTNER=$1

修改为:ORACLE_HOME_LISTNER=$ORACLE_HOME

4、vi /data/oracle/product/11.2.0/db_1/bin/dbshut #编辑

找到:ORACLE_HOME_LISTNER=$1

修改为:ORACLE_HOME_LISTNER=$ORACLE_HOME

5、创建oracle启动脚本

vi /etc/init.d/oracle #编辑,添加以下代码

##########################################################

#!/bin/sh

# chkconfig: 0356 99 10

# description: Startup Script for Oracle Databases

# Script path:/etc/init.d/oracle

# Author:www.osyunwei.com by qihang01

#

ORACLE_BASE=/data/oracle

ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1

ORACLE_SID=orcl

PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH

export ORACLE_BASE ORACLE_HOME ORACLE_SID PATH

#

ORA_OWNR="oracle"

#

if [ ! -f $ORACLE_HOME/bin/dbstart -o ! -d $ORACLE_HOME ]

then

echo "Oracle startup: cannot start"

exit 1

fi

#

case "$1" in

start)

su – $ORA_OWNR -lc $ORACLE_HOME/bin/dbstart

echo "Oracle Start Succesful!"

;;

stop)

#

su – $ORA_OWNR -lc $ORACLE_HOME/bin/dbshut

echo "Oracle Stop Succesful!"

;;

restart)

$0 stop

$0 start

;;

*)

echo $"Usage: `basename $0` {start|stop|restart}"

exit 1

esac

exit 0

##########################################################

:wq! #保存退出

chown oracle.oinstall /etc/init.d/oracle #更改文件所有者

chmod 755 /etc/init.d/oracle #添加执行权限

ln -s /etc/init.d/oracle /etc/rc3.d/S99oracle #添加系统启动级别3软连接

ln -s /etc/init.d/oracle /etc/rc5.d/S99oracle #添加系统启动级别5软连接

ln -s /etc/init.d/oracle /etc/rc0.d/K01oracle #添加系统关机软连接

ln -s /etc/init.d/oracle /etc/rc6.d/K01oracle #添加系统重启软连接

chkconfig –add oracle #添加系统服务

chkconfig oracle on #设置开机启动

备注:# chkconfig: 0356 99 10

0356:定义运行级别

99:开机启动优先级(数字越大启动越晚)

10:关机停止优先级(数字越小关闭越早)

6、恢复操作系统标识

vi /etc/redhat-release #编辑

把:redhat-7

修改为:CentOS Linux release 7.2.1511 (Core)

:wq! #保存退出

7、更改系统默认启动级别为3

vi /etc/inittab #编辑

id:3:initdefault: #修改5为3

:wq! #保存退出

8、测试

shutdown -r now #重启系统

service oracle start #启动oracle

service oracle stop #关闭oracle

/etc/init.d/oracle restart #重启oracle

su – oracle #切换到oracle用户

dbstart #启动oracle

dbshut #关闭oracle

ps -ef | grep ora #查看oracle进程

ps -ef | grep LISTEN | grep -v gre #查看oracle端口监听

lsnrctl status #查看oracle运行状态

至此,CentOS下安装Oracle 11g R2完成。

Linux下用静默方式删除oracle软件_数据库技术_Linux公社-Linux系统门户网站

坑!

Oracle 11g数据库软件静默安装_数据库技术_Linux公社-Linux系统门户网站

坑!!

Oracle 11g静默安装简明版_数据库技术_Linux公社-Linux系统门户网站

坑!!!

Oracle 11g静默安装软件+手工创建数据库_数据库技术_Linux公社-Linux系统门户网站

坑!!!~~

1,敲了安装命令,调不出来图形安装界面

  注销后用oracle登录可解决

  #passwd oracle #修改下密码

2,安装界面出现英文

      方法1) LANG=en_US   ./runInstaller  #这个靠谱些,应该是中文语言造成的

  方法2) 度到了修改配置文件什么的,麻烦!

3,安装时出现提示框显示不出来!

    #LANG=en_US ./runInstaller -jreLoc /usr/lib/jvm/jre-1.8.0 #不知道啥意思,照着敲吧

4,安装过程中卡死,关掉重装

    #ps -aux | grep oracle #查找安装程序的pid
    #kill id #杀死进程

5,64位系统缺少32位的包 glibc-devel  报错ins_ctx.mk

找到了这里下载 xftp上传,然后发现,rpm安装提示缺少依赖项,继续度度度到了 yum

  #yum localinstall glibc-develXXXXX

Glibc-devel Download (RPM)

6,挖了这么多,一心向往着点那个finish按钮的时候,又提示磁盘空间满了...

  好吧,关掉vmware,再分点空间,重启进系统,习惯性的找磁盘管理,找了一通懵逼了,那种马又在心中奔腾起来啦.何止1M点伤害!@#!$#@#$%^&

  继续度吧:

  1)写的确实很详细,但依葫芦画瓢确实是很痛苦的事.(失败)

    Linux中VMware虚拟机增加磁盘空间的扩容操作[图文]_Linux教程_Linux公社-Linux系统门户网站

    

  2)终于找到一个图形界面的工具(失败)

  最简单的Linux虚拟机磁盘扩容方法 - 俊雨廷休 - 博客园

  

  3)重装了....(下来要恶补磁盘管理方面的东西)

7,重装后发现,配置完成开始安装的时候,安装界面卡死,so 好像忘了一步需要装vmware tools

  Linux安装VMware Tools教程_Linux教程_Linux公社-Linux系统门户网站

  

 

 


 

雨过天晴,打完收工!,耗时1天半,真悲催

 

图片 53

 

 

Linux平台Oracle 11g单实例 安装部署配置 快速参考_数据库技术_Linux公社-Linux系统门户网站

编辑:操作系统 本文来源:安装Oracle时的情景所谓是简历坎坷,所以将此次

关键词:

  • 上一篇:没有了
  • 下一篇:没有了