一、环境

系统:Ubuntu 14.04.5 LTS(为了贴近生产我装了个Ubuntu14的服务器版本)

JDK:jdk-8u121-linux-x64.tar.gz

Oracle:linux.x64_11gR2_database_1of2.ziplinux.x64_11gR2_database_2of2.zip

工具:Xshell5、

注:以上软件或者工具自行去相关官网下载

二、安装JDK

解压JDK

tar -zxvf jdk-8u121-linux-x64.tar.gz

注:tools这个目录是我新建的,当然你也可以放在别的位置

移动jdk1.8.0_121目录到/usr/local/java,这个Java目录是我新建的。

mv jdk1.8.0_121//usr/local/java/

接下来我们开始配置环境变量:

vi .bashrc

在文件.bashrc文件末尾处新增以下配置:

export JAVA_HOME=/usr/local/java/jdk1.8.0_121

export JRE_HOME=${JAVA_HOME}/jre

export CLAsspATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib

export PATH=${JAVA_HOME}/bin:$PATH

然后执行wq!进行保存并退出

同时记得重新刷新一下文件,输入以下命令:

source .bashrc

检查一下Java是否配置成功:

java -version

说明我们按照成功了,这里解释一下为什么要装JDK,因为oracle有一部分的代码是通过Java编写的。

三、安装依赖包

sudo apt-get install automake //成功

sudo apt-get install autotools-dev//系统已经安装

sudo apt-get install binutils//只更新了一个文件,成功

sudo apt-get install bzip2//系统已经安装

sudo apt-get install elfutils//成功

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 //lib32ncurses5和lib32z1代替

sudo apt-get install ksh

sudo apt-get install less

sudo apt-get install lesstif2

sudo apt-get install lesstif2-dev

注:但是这五个包是32位的,需要更新源(以下操作是root用户)

终端输入:

sudo -i

cd /etc/apt/sources.list.d

echo "debhttp://cz.archive.ubuntu.com/ubuntu precise main universe">ia32-libs-raring.list

apt-get update

apt-get install +包名

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 //成功

安装成功之后再还原:

rm /etc/apt/sources.list.d/ia32-libs-raring.list

apt-get update

退出当前root用户

root@Ubuntu14:/etc/apt/sources.list.d# exit

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 //成功

sudo apt-get install libodbcinstq4-1:i386//成功

sudo apt-get install libpth-dev//成功

sudo apt-get install libpthread-stubs0//成功

注:这个包是32位的需要更换源,我在上面已经写好步骤了(紫色字体部分)

apt-get install libpthread-stubs0

exit 退出当前用户

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//成功

到此依赖包就算安装完成了,以上的这些依赖包也是可以代替的http://packages.ubuntu.com/precise/i386/ia32-libs-multiarch/download这个网址就是Ubuntu的软件包源地址,有兴趣的自行去研究。

四、配置oracle环境

1、用以下命令检查系统变量(注以下的这些操作请用记事本把这些参数记录下来)

/usr/local/java$ /sbin/sysctl -a | grep sem

/usr/local/java$ /sbin/sysctl -a | grep shm

/sbin/sysctl -a | grep file-max

/sbin/sysctl -a | grep aio-max

/sbin/sysctl -a | grep ip_local_port_range

/sbin/sysctl -a | grep rmem_default

/sbin/sysctl -a | grep rmem_max

/sbin/sysctl -a | grep wmem_default

2、根据上面命令中得到的参数值在/etc/sysctl.conf中增加对应数据

cd/etc/

sudovi /etc/sysctl.conf

把以下参数添加进去并保存文件:

kernel.sem =32000102400000050032000

kernel.shmall =18446744073692774399

kernel.shmmax =18446744073692774399

kernel.shmmni =4096

fs.file-max =96898

fs.aio-max-nr =65536

net.ipv4.ip_local_port_range= 3276860999

net.core.rmem_max= 212992

net.core.rmem_default= 212992

net.core.wmem_default= 212992

net.core.wmem_max= 212992

保存文件并退出,然后运行以下命令更新内核参数:

sysctl -p

3、添加用户的内核限制在/etc/security/limits.conf文件中增加以下数据,注:其中shiyajing

是我ubuntu系统的普通用户

cd /etc/security/

sudo vi limits.conf

打开文件之后在末尾加入以下几行:

shiyajing soft nproc 2047

shiyajing hard nproc 16384

shiyajing soft nofile 1024

shiyajing hard nofile 65536

shiyajing soft stack 10240

保存之后关闭文件窗口。

注:shiyajing这个用户是我当前操作的用户,网上有些需要建立用户组之类的,当然你也可以建立oracle用户组。看个人喜好,不过也可以建立oracle用户,这样容易区分。

同样的方法打开文件/etc/pam.d/login,增加以下行(有了就不用增加了):

session requiredpam_limits.so

同样检查/etc/pam.d/su,没有以下行就自己加上:

session requiredpam_limits.so

4、创建oracle需要的文件夹

shiyajing@Ubuntu14:~$ mkdir oracle11g

注:当然你也可以自己取喜好的名字,这里没有限制。

还有oracle安装的时候差不多要占系统空间8个G左右,所以尽量放在硬盘上。除非你的初始系统空间很大,那么不存在此问题。

5、为oracle配置环境变量

export ORACLE_BASE=/home/shiyajing/oracle11g

//oracle安装目录

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1

//现在还看不到这个文件夹,在Oracle安装过程中系统会自动创建,后面安装时选择路径要和这里设置的一致。

export ORACLE_SID=orcl

//在安装时会有一个设置的地方,默认是orcl,也可以设置成其他

export ORACLE_UNQNAME=orcl

//默认字符集

export NLS_LANG=.AL32UTF8

//环境变量

export PATH=${PATH}:${ORACLE_HOME}/bin/:$ORACLE_HOME/lib64;

6、欺骗oracle的安装程序

Oracle本身并不支持ubuntu来安装,所以要进行欺骗oracle的安装程序(sudo执行):

sudo mkdir /usr/lib64

sudoln -s /etc /etc/rc.d

sudo ln -s /lib/x86_64-linux-gnu/libgcc_s.so.1 /lib64/

sudoln -s /usr/bin/awk /bin/awk

sudoln -s /usr/bin/basename /bin/basename

sudoln -s /usr/bin/rpm /bin/rpm

sudoln -s /usr/lib/x86_64-linux-gnu/libc_nonshared.a /usr/lib64/

sudoln -s /usr/lib/x86_64-linux-gnu/libpthread_nonshared.a /usr/lib64/

sudoln -s /usr/lib/x86_64-linux-gnu/libstdc++.so.6 /lib64/

sudoln -s /usr/lib/x86_64-linux-gnu/libstdc++.so.6 /usr/lib64/

到此oracle的预备工作已经做完了。接下来开始啦。

五、开始安装oracle

1.从官网下载oracle安装包,复制到/home/shiyajing/oracle11g

然后解压:

cd /home/shiyajing/oracle11g/

unzip linux.x64_11gR2_database_1of2.zip

unzip linux.x64_11gR2_database_2of2.zip

解压之后会出现一个database文件夹。

2.安装远程可视化桌面

参考资料:http://www.jb51.net/os/Ubuntu/104948.html

http://blog.csdn.net/jlds123/article/details/9064437

http://blog.csdn.net/kylin_fire_zeng/article/details/42082415

安装vncserver

sudo apt-get install vnc4server

执行vncserver

sudoapt-get install xfce4

cd ~/.vnc

vi xstartup

安装完成xfce4后,修改xstartup文件,如下:

sesion-manager& xfdesktop & xfce4-panel &

xfce4-menu-plugin&

xfsettingsd&

xfconfd &

xfwm4 &

执行vncserver -kill :1,最好重启vncserver就可以了,由于VNC不是本文重点,有兴趣的自行百度或者google。

3.开始在窗口中安装oracle

进入VNC界面

并切换到当前安装oracle的用户

cd /home/shiyajing/oracle11g

cd database

./runInstaller

接着就跳出了oracle安装界面了

把勾去掉点击下一步

肯定选yes

继续下一步,选择第一个,也可以选择第二个,可以自行尝试

继续下一步,把该填的填了

下一步,默认就好,有些系统安装可能没有这一步。

下一步,把lgore all点上勾。

继续下一步

点击安装,应该在68%的时候会报3次错,顺序不定,看清错误target

第一个报错

这个问题忽略现在跳过,选择continue。

紧接着第二个报错出来了

Error in invoking target ‘agent nmhs’ ofmakefile

‘/home/shiyajing/oracle11g/product/11.2.0/dbhome_1/sysman/lib/ins_emagent.mk’

解决方案:

打开新的终端窗口执行以下命令(我这里用的是Xshell)

cd /home/shiyajing/oracle11g/product/11.2.0/dbhome_1/sysman/lib/

sudo vi ins_emagent.mk

将文件中的$(MK_EMAGENT_NMECTL)修改成$(MK_EMAGENT_NMECTL -lnnz11)即可(应该有两处需要修,也有可能只有一处)。

然后点击retry,接着往下执行

第三个错误:

解决办法:

打开一个新的终端,输入如下四个命令:

sudo sed -i's/^\(TNSLSNR_LINKLINE.*\$(TNSLSNR_OFILES)\) \(\$(LINKTTLIBS)\)/\1-Wl,--no-as-needed \2/g'/home/shiyajing/oracle11g/product/11.2.0/dbhome_1/network/lib/env_network.mk

sudo sed -i's/^\(ORACLE_LINKLINE.*\$(ORACLE_LINKER)\) \(\$(PL_FLAGS)\)/\1-Wl,--no-as-needed \2/g'/home/shiyajing/oracle11g/product/11.2.0/dbhome_1/rdbms/lib/env_rdbms.mk

sudo sed -i 's/^\(\$LD \$LD_RUNTIME\)\(\$LD_OPT\)/\1 -Wl,--no-as-needed \2/g' /home/shiyajing/oracle11g/product/11.2.0/dbhome_1/bin/genorasdksh

sudo sed -i's/^\(\s*\)\(\$(OCRLIBS_DEFAULT)\)/\1 -Wl,--no-as-needed \2/g'/home/shiyajing/oracle11g/product/11.2.0/dbhome_1/srvm/lib/ins_srvm.mk

//如果不行的话尝试进入文件路径之后在执行

然后在图形界面点击‘Retry’就能继续安装了。

百分之68我们过去了,基本上后面就不会报错了。

还有就是在cd /home/shiyajing/oraInventory/logs

这里有三个文件,我们可以实时监控安装的过程:

tail -finstallActions2017-05-09_09-13-05PM.log

然后按照安装程序提示最后执行两个脚本(这一步我只遇到一个脚本,但是并不影响):

sudo /home/shiyajing/oraInventory/orainstRoot.sh(次要)

sudo /home/shiyajing/oracle11g/product/11.2.0/dbhome_1/root.sh(主要)

一路回车就行,也可能只需要回车一次。

这个可能权限不够,不过无伤大雅。友情提醒,oracle安装的时候会占用8G的容量,所以尽量把oracle安装目录放入硬盘,一般服务器都有硬盘。当然你服务器初始化容量很大的话不存在此问题。

如果放入硬盘的话,记得把硬盘存放的目录权限给当前用户。否则后果你懂的,关于目录权限命令。

例子:chown -R oracle /mnt/vdc/oracle11g

chown -R oracle /mnt/vdc/oracle11g/

六、测试oracle是否安装成功

1、先测试一下oracle的环境变量,在终端输入命令

echo $ORACLE_BASE

echo $ORACLE_HOME

echo $PATH

看看是不是你配置的值,没问题继续向下。如果没有则配置一下oracle的环境变量即可。

2、开启监听器,在终端输入命令

lsnrctl start

TNS-01106:使用侦听器名称侦听器的LISTENER已经启动

命令lsnrctl status可以查看监听信息

如果没有可以自己配置监听,配置文件在

cd /home/shiyajing/oracle11g/product/11.2.0/dbhome_1/network/admin/

vi listener.ora

然后按照上面的命令在启动一次监听。

启动oracle数据库

sqlplus /nolog

这里我碰到一个问题,不过有解决办法,输入以下命令:

sudo ln -s/home/shiyajing/oracle11g/product/11.2.0/dbhome_1/bin/sqlplus /usr/bin/sqlplus

一般是不会出现的,只有当你oracle环境变量配置错了才会出现的。

conn / as sysdba

以系统默认用户sysdba登录

因为创建实例的时候,已经启动了,所以会提示下面这个错误。

创建用户并设置密码,并设置权限。

create user shiyajing identified bys123456;

grant create user,drop user,alteruser,create any view,drop anyview,exp_full_database,imp_full_database,dba,connect,resource,create sessionto shiyajing;

exit退出.

当然监听器也可以停止(lsnrctl stop),还有重启,自行百度。

到此Oracle已经安装配置成功啦。

关于外网访问这个自行访问百度,网上很多。(多么痛的领悟)此教程百分百成功,实战实测。再次申明依赖包一定要安装好。

恩,谢谢。

ubuntu 14.04 oracle 11g 64位数据库安装的更多相关文章

  1. 详解前端HTML5几种存储方式的总结

    本篇文章主要介绍了前端HTML5几种存储方式的总结 ,主要包括本地存储localstorage,本地存储sessionstorage,离线缓存(application cache),Web SQL,IndexedDB。有兴趣的可以了解一下。

  2. ios中的.dylib和.a lib有什么区别?

    我知道Objectivec中的编译和运行时是什么,但是我想知道是什么画了这两个库之间的界限?他们的目的是什么,除了陈述一个是静态的而另一个是动态的?我们何时需要一个而不是另一个?

  3. xamarin.ios – ShareKit与MonoTouch如何?

    有人可以验证ShareKit实际上是否可用于MonoTouch并指导我完成使其工作所需的步骤?解决方法您首先从getsharekit.com下载还是使用ShareKit2.0?

  4. ios – iPhone崩溃日志不能正确地符号化并且是双重间隔的

    任何建议超过欢迎.谢谢.解决方法当这件事发生在我身上时,它只是我通过电子邮件收到的日志.如果我记得,至少有一些是在.msg文件中,我不得不把它们拿出来.它可能是Exchange编码更改.如果你显示不可见的字符,你可能会看到每个字符之间的东西.您可以找到并替换它们以删除它们或更改编辑器中的编码.

  5. iOS推送通知适用于Dev而不是Enterprise Distribution

    本网站上没有其他问题,我已经能够找到实际上提出了Dev将工作的原因,但企业分布不会.为什么归档总是使aps环境生产?

  6. ios – Xcode 7 beta 2:LaunchScreen.storyboard无法打开文档

    我在两个不同的Mac(iMac和MacBookpro)上收到这个错误.不知道为什么人们不能再现它,但我需要一些帮助.在运行XX优胜美地10.10.4的Mac上运行Xcode7beta2(15六月’15).甚至无法编译和运行我的项目..我从创建菜单创建了一个视图应用程序项目,就是这样.编辑:我试图删除并重新添加storyboard文件(也可以打开Main.storyboard插件),我仍然得到相同的

  7. ios – 存档期间不存在Xcode环境变量

    我有一个具有TestFlight构建方案的iOS应用程序.在此方案中,我在“运行”选项卡中设置了一个称为TESTFLIGHT的环境变量,值为1.此外,在构建方案的“配置文件”选项卡中,它已选中“使用RUn操作的参数和变量”选项,并在列表中看到相应的EV.当从Xcode运行应用程序时,这可以正常工作,但是当我在存储设备上运行应用程序时,环境变量TESTFLIGHT不存在.我的问题是有一个我在这里缺少的选项/方案选项卡?

  8. ios – 为具有多个目标和不同平台的项目编写Podfile

    如何让CocoaPods成功整合到我的项目和iOS/Mac目标?我已经阅读了Podfile文档,但发现它在这方面缺乏.解决方法得到它了!从我的每个目标和运行的pod安装中删除libPods-xxxx.a文件,再次执行了我的目标集成.

  9. ios – 在/usr/lib/system/libcache.dylib中,缺少必需的架构armv6

    在试图为iphoneos编写一个虚拟程序时,Xcode4,gcc似乎没有超出初始的sysroot目录如果我把sysroot,以下作品,但感觉非常干酪,而且不可伸缩.这里发生了什么?

  10. 在iOS 7中预加载数据库

    或者是否已经不再可以将预装数据库与应用程序一起发货?

随机推荐

  1. crontab发送一个月份的电子邮件

    ubuntu14.04邮件服务器:Postfixroot收到来自crontab的十几封电子邮件.这些邮件包含PHP警告.>我已经解决了这些警告的原因.>我已修复每个cronjobs不发送电子邮件(输出发送到>/dev/null2>&1)>我删除了之前的所有电子邮件/var/mail/root/var/spool/mail/root但我仍然每小时收到十几封电子邮件.这些电子邮件来自cronjobs,

  2. 模拟两个ubuntu服务器计算机之间的慢速连接

    我想模拟以下场景:假设我有4台ubuntu服务器机器A,B,C和D.我想在机器A和机器C之间减少20%的网络带宽,在A和B之间减少10%.使用网络模拟/限制工具来做到这一点?

  3. ubuntu-12.04 – 如何在ubuntu 12.04中卸载从源安装的redis?

    我从源代码在Ubuntu12.04上安装了redis-server.但在某些时候它无法完全安装,最后一次makeinstallcmd失败.然后我刚刚通过apt包安装.现在我很困惑哪个安装正在运行哪个conf文件?实际上我想卸载/删除通过源安装的所有内容,只是想安装一个包.转到源代码树并尝试以下命令:如果这不起作用,您可以列出软件自行安装所需的步骤:

  4. ubuntu – “apt-get source”无法找到包但“apt-get install”和“apt-get cache”可以找到它

    我正在尝试下载软件包的源代码,但是当我运行时它无法找到.但是当我运行apt-cache搜索squid3时,它会找到它.它也适用于apt-getinstallsquid3.我使用的是Ubuntu11.04服务器,这是我的/etc/apt/sources.list我已经多次更新了.我尝试了很多不同的debs,并没有发现任何其他地方的错误.这里的问题是你的二进制包(deb)与你的源包(deb-src)不

  5. ubuntu – 有没有办法检测nginx何时完成正常关闭?

    &&touchrestarted),因为即使Nginx没有完成其关闭,touch命令也会立即执行.有没有好办法呢?这样的事情怎么样?因此,pgrep将查找任何Nginx进程,而while循环将让它坐在那里直到它们全部消失.你可以改变一些有用的东西,比如睡1;/etc/init.d/Nginx停止,以便它会休眠一秒钟,然后尝试使用init.d脚本停止Nginx.你也可以在某处放置一个计数器,这样你就可以在需要太长时间时发出轰击信号.

  6. ubuntu – 如何将所有外发电子邮件从postfix重定向到单个地址进行测试

    我正在为基于Web的应用程序设置测试服务器,该应用程序发送一些电子邮件通知.有时候测试是使用真实的客户数据进行的,因此我需要保证服务器在我们测试时无法向真实客户发送电子邮件.我想要的是配置postfix,以便它接收任何外发电子邮件并将其重定向到一个电子邮件地址,而不是传递到真正的目的地.我正在运行ubuntu服务器9.10.先感谢您设置本地用户以接收所有被困邮件:你需要在main.cf中添加:然后

  7. ubuntu – vagrant无法连接到虚拟框

    当我使用基本的Vagrantfile,只配置了两条线:我看到我的虚拟框打开,但是我的流氓日志多次显示此行直到超时:然后,超时后的一段时间,虚拟框框终于要求我登录,但是太久了!所以我用流氓/流氓记录.然后在我的物理机器上,如果我“流氓ssh”.没有事情发生,直到:怎么了?

  8. ubuntu – Nginx – 转发HTTP AUTH – 用户?

    我和Nginx和Jenkins有些麻烦.我尝试使用Nginx作为Jenkins实例的反向代理,使用HTTP基本身份验证.它到目前为止工作,但我不知道如何传递带有AUTH用户名的标头?}尝试将此指令添加到您的位置块

  9. Debian / Ubuntu – 删除后如何恢复/ var / cache / apt结构?

    我在ubuntu服务器上的空间不足,所以我做了这个命令以节省空间但是现在在尝试使用apt时,我会收到以下错误:等等显然我删除了一些目录结构.有没有办法做apt-getrebuild-var-tree或类似的?

  10. 检查ubuntu上安装的rubygems版本?

    如何查看我的ubuntu盒子上安装的rubygems版本?只是一个想法,列出已安装的软件包和grep为ruby或宝石或其他:)dpkg–get-selections

返回
顶部