今天来记录一下ubuntu下安装oracle11的详细过程。安装过程是我亲自安装得情况下记录的,是可行的方案。

一 :环境

ubuntu:ubuntu 14.04 LTS amd64位
oracle:oracle11
jdk:jdk1.7
内存:1G
硬盘:20G
CPU:1个

二:安装

1.下载oracle11

在官网下载oracle11,下载地址如下:
oracle11:http://www.oracle.com/technetwork/database/enterprise-edition/downloads/index.html

下载到/home下,有两个压缩文件,利用如下命令解压:

sudo tar -zxvf linux.x64_11gR2_database_1of2.zip
sudo tar -zxvf linux.x64_11gR2_database_2of2.zip

解压完后,在home目录下生成一个database文件夹,这就是oracle的安装目录。

2.安装jdk1.7

安装jdk的方法可以参考我的另外一篇博文ubuntu或者linux下卸载和安装多个jdk版本,1.6,1.7和1.8版本
可以不用安装那么多,安装jdk1.7即可。

或者直接用ubuntu linux默认有自己的OpenJdk:

sudo apt-get install openjdk-7-jre 
sudo apt-get install openjdk-7-jdk 

3.安装远程可视化桌面

因为oracle的安装涉及到利用安装向导进行安装,所以一定要安装可视化远程桌面。安装方法见我另外一篇博文:
window远程连接Ubuntu 14.04的桌面,做完这一步才能开始安装。

4.更新源文件

因为ubuntu的官方源并不全,特别是安装ia32-libs包的时候没有,首先我们备份源文件,然后把以下源增加到源列表:(删除原来的所有源,然后把下面的源粘贴进去):

sudo cp /etc/apt/sources.list /etc/apt/sources.list_back

把/etc/apt/sources.list源文件的内容替换成以下源:

deb http://mirrors.163.com/ubuntu/ precise main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ precise-security main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ precise-updates main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ precise-proposed main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ precise-backports main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ precise main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ precise-security main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ precise-updates main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ precise-proposed main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ precise-backports main restricted universe multiverse

deb http://extras.ubuntu.com/ubuntu trusty main
deb-src http://extras.ubuntu.com/ubuntu trusty main
deb http://archive.ubuntu.com/ubuntu/ raring main restricted universe multiverse

#163源:
deb http://mirrors.163.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-backports main restricted universe multiverse
#阿里源:

deb http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.aliyuncs.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.aliyuncs.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.aliyuncs.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.aliyuncs.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.aliyuncs.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.aliyuncs.com/ubuntu/ trusty-backports main restricted universe multiverse


5.安装依赖包

替换完后执行一下命令进行更新:

sudo apt-get update
sudo apt-get upgrade

然后安装以下依赖包,一定每个包都安装成功,要不然可能oracle安装不成功。

sudo apt-get install bzip2 
sudo apt-get install elfutils 
sudo apt-get install automake 
sudo apt-get install autotools-dev 
sudo apt-get install binutils 
sudo apt-get install expat 
sudo apt-get install gawk 
sudo apt-get install gcc 
sudo apt-get install gcc-multilib 
sudo apt-get install g++-multilib 
sudo apt-get install ia32-libs 
sudo apt-get install ksh 
sudo apt-get install less 
sudo apt-get install lesstif2 
sudo apt-get install lesstif2-dev 
sudo apt-get install lib32z1 
sudo apt-get install libaio1 
sudo apt-get install libaio-dev 
sudo apt-get install libc6-dev 
sudo apt-get install libc6-dev-i386 
sudo apt-get install libc6-i386 
sudo apt-get install libelf-dev 
sudo apt-get install libltdl-dev 
sudo apt-get install libmotif4 
sudo apt-get install libodbcinstq4-1 libodbcinstq4-1:i386 
sudo apt-get install libpth-dev 
sudo apt-get install libpthread-stubs0 
sudo apt-get install libpthread-stubs0-dev 
sudo apt-get install libstdc++5 
sudo apt-get install lsb-cxx 
sudo apt-get install make 
sudo apt-get install openssh-server 
sudo apt-get install pdksh 
sudo apt-get install rlwrap 
sudo apt-get install rpm 
sudo apt-get install sysstat 
sudo apt-get install unixodbc 
sudo apt-get install unixodbc-dev 
sudo apt-get install unzip 
sudo apt-get install x11-utils 
sudo apt-get install zlibc

6.检查系统变量

sudo /sbin/sysctl -a | grep sem 
sudo /sbin/sysctl -a | grep shm 
sudo /sbin/sysctl -a | grep file-max 
sudo /sbin/sysctl -a | grep aio-max 
sudo /sbin/sysctl -a | grep ip_local_port_range 
sudo /sbin/sysctl -a | grep rmem_default 
sudo /sbin/sysctl -a | grep rmem_max 
sudo /sbin/sysctl -a | grep wmem_default 
sudo /sbin/sysctl -a | grep wmem_max 

然后根据上面命令中得到的参数值在/etc/sysctl.conf中增加对应数据,可以打开两个终端,这样方便填写:

sudo vim /etc/sysctl.conf

把sysctl.conf中的以下内容用查得的值填上

fs.aio-max-nr = ? 
fs.file-max = ? 
kernel.shmall = ? 
kernel.shmmax = ? 
kernel.shmmni = ? 
kernel.sem = ? 
net.ipv4.ip_local_port_range = ? 
net.core.rmem_default = ? 
net.core.rmem_max = ? 
net.core.wmem_default = ? 
net.core.wmem_max = ?

运行一下命令更新内核参数:

sudo sysctl -p  

7.添加对当前用户的内核限制在 /etc/security/limits.conf 文件中增加以下数据(XXX为你当前用户名)

XXX  soft nproc 2047
XXX  hard nproc 16384 
XXX  soft nofile 1024 
XXX  hard nofile 65536 
XXX  soft stack 10240

8.检查/etc/pam.d/login,增加以下行(有了就不用增加了):
session required pam_limits.so
检查/etc/pam.d/su,没有以下行就自己加上:
session required pam_limits.so

9.oracle默认不支持ubuntu需要欺骗一下oracle安装程序,执行以下命令:

sudo mkdir /usr/lib64 
sudo ln -s /etc /etc/rc.d 
sudo ln -s /lib/x86_64-linux-gnu/libgcc_s.so.1 /lib64/ 
sudo ln -s /usr/bin/awk /bin/awk 
sudo ln -s /usr/bin/basename /bin/basename 
sudo ln -s /usr/bin/rpm /bin/rpm 
sudo ln -s /usr/lib/x86_64-linux-gnu/libc_nonshared.a /usr/lib64/ 
sudo ln -s /usr/lib/x86_64-linux-gnu/libpthread_nonshared.a /usr/lib64/ 
sudo ln -s /usr/lib/x86_64-linux-gnu/libstdc++.so.6 /lib64/ 
sudo ln -s /usr/lib/x86_64-linux-gnu/libstdc++.so.6 /usr/lib64/ 
echo ‘Ubuntu Linux release 14.04′ > /etc/ubuntu-release 

最后一个命令执行不了的话,可以用以下命令执行:

sudo vim /etc/ubuntu-release

在ubuntu-release文本中增加Ubuntu Linux release 14.04,然后保存退出即可。

10.配置oracle的环境变量

sudo gedit ~/.profile
打开.profile文件,为文件中添加以下行:
xxx换成你目前的用户名

export ORACLE_BASE=/home/xxx/app/xxx 
export ORACLE_HOME=${ORACLE_BASE}/product/11.2.0/dbhome_1 
export ORACLE_SID=orcl 
export ORACLE_UNQNAME=orcl 
export PATH=PATH:${ORACLE_HOME}/bin/; 

11.启动oracle安装程式开始安装

首先检查一下oracle的环境变量是否是你设定的:

echo $ORACLE_BASE 
echo $ORACLE_HOME 
echo $PATH

如果不是,重新开启一个终端,应该就可以了。或者执行以下命令:

source ~/.profile

这个命令的作用是使你设的环境变量生效。

接下来执行以下命令打开远程桌面服务:

vncservser :1

记住不要这个命令前面不要加上sudo ,否则打开的是root用户的远程桌面,而不是你要安装的用户,开启后的输出结果如下:

这里写图片描述
现在可以在window上利用VNC-Viewer软件进行连接:

这里写图片描述
注意:后面的1数字一定要和你开启的端口一致。

打开的远程桌面后,打开桌面里的终端,我的安装程序解压在主目录:/home/database
所以cd进去:cd /home/database
为了不乱码,终端先export LANG=US一下
再运行目录下面的runInstaller: ./runInstaller
可进入图形化安装界面,接着根据安装向导提示做就行了
先决条件检查会提示一堆fails,不用管它,直接把ignore All挑上,直接finish
这里要提一句,如果你的swap空间不够的话,会提示交换空间不够,不能继续
解决方式:
可以另开一个终端用下面的命令临时提升交换空间,再去recheck一下,就行了:

free -m 
mkdir /swapfile 
cd /swapfile 
sudo dd if=/dev/zero of=swap bs=1024 count=400000 
sudo mkswap -f swap 
sudo swapon swap 

12.安装到68%时的错

ins_ctx.mk的错误提示,直接contiue跳过去
后面还回报错:
make file ‘/……emagent.mk’出错
解决方法:
另开一个终端,键入命令行:

sudo sed -i 's/^\(\s*\$(MK_EMAGENT_NMECTL)\)\s*$/\1 -lnnz11/g' $ORACLE_HOME/sysman/lib/ins_emagent.mk 

点击安装界面的retry,就可以继续了
类似的后面还会提示四次,以下面的命令行如法炮制 ,把以下命令执行完。

sudo sed -i 's/^\(\$LD \$LD_RUNTIME\) \(\$LD_OPT\)/\1 -Wl,--no-as-needed \2/g' $ORACLE_HOME/bin/genorasdksh 
sudo sed -i 's/^\(\s*\)\(\$(OCRLIBS_DEFAULT)\)/\1 -Wl,--no-as-needed \2/g' $ORACLE_HOME/srvm/lib/ins_srvm.mk 
sudo sed -i 's/^\(TNSLSNR_LINKLINE.*\$(TNSLSNR_OFILES)\) \(\$(LINKTTLIBS)\)/\1 -Wl,--no-as-needed \2/g' $ORACLE_HOME/network/lib/env_network.mk 
sudo sed -i 's/^\(ORACLE_LINKLINE.*\$(ORACLE_LINKER)\) \(\$(PL_FLAGS)\)/\1 -Wl,--no-as-needed \2/g' $ORACLE_HOME/rdbms/lib/env_rdbms.mk 

13.安装完成会提示有两个sh文件需要运行:

还是另开一个终端:

sudo /home/xxx/app/xxx/oracle/oraInventory/orainstRoot.sh 
sudo /home/xxx/app/xxx/oracle/Oracle11gee/product/11.2.0/dbhome_1/root.sh 

安装完成!

三:测试

1,运行sqlplus

运行sqlplus前测试一下oracle的环境变量:

echo $ORACLE_BASE 
echo $ORACLE_HOME 
echo $PATH 

如果显示的是你配置的值,可以继续以下步骤。

2.查看数据库的监听状态
利用一下命令查看是否正在监听,正常情况会显示很多监听信息
这里如果没有输出,说明无监听,需要自己配置 :

lsnrctl status 

没有监听的解决办法:
运行 netca 可以创建监听,调出图形界面设置监听
如果没有创建库此时可以dbca 创建数据库.
顺便运行以下代码修复 dbconsole
emca -repos drop
emca -repos create
emca -config dbcontrol db
emca start dbconsole
到此数据库应该就可以跑起来了

如果没有监听,执行一下命令启动监听:

lsnrctl start

3.启动oracle数据库
输入以下命令,启动sqlplus:

sqlpus / as sysdba

oracle的启动和停止命令是:

SQL>startup
SQL>shutdown

startup时会显示你创建的orcl实例已经正常加载。

4..sqldeveloper连不上oracle的问题:
如果需要远程连接oracle数据库,需要修改一下oracle的监听地址:
修改/home/oracle/app/oracle/product/11.2.0/dbhome_1/network/admin/listener.ora文件内容为:
这里写图片描述

改/home/oracle/app/oracle/product/11.2.0/dbhome_1/network/admin/tnsnames.ora的内容如下:
这里写图片描述

修改完以上文件后,关闭监听并重启监听,数据库不用停止和启动:

lsnrctl stop
lsnrctl start

这样你就可以远程连接你的oracle了。

完结。。。。。。。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐