快捷搜索:   nginx

ubuntu环境下安装oracle数据库11g

系统准备期:
请先用 apt-get update 与 apt-get upgrade 来保证你的系统现在是最新的. 然后我们开始.

11g现在完全基于java, 当然这是公司声称的, 实际情况我们不清楚, 但jvm是一定要的, 这个在ubuntu上是小事, 只要apt-get就可以了. 完后, 记得JAVA_HOME哦.

现在安装一些oracle安装时要用的包.

# apt-get install gcc make binutils lesstif2 libc6 libc6-dev rpm libmotif3 libaio libstdc++5 gawk alien libg++2.8.1.3-glibc2.2 ksh gcc-3.3 g++-3.3 libstdc++5

这些版本号其实不用管, 如果有更新的, 可以使用更新的版本.

对于oracle来说, 它认为的程序所在的位置与ubuntu系统的那些程序所在的位置不一样, 所以要作一下链接, 如果你在链接时, 没有找到程序, 那说明你还没有安装这个程序, 请用 apt-get install 来安装

# ln -s /usr/bin/awk /bin/awk
# ln -s /usr/bin/rpm /bin/rpm
# ln -s /usr/bin/basename /bin/basename

11g针对的linux系统基本就是redhat啦, 所以还要作一些工作哦

# mkdir /etc/rc.d
# ln -s /etc/rc0.d /etc/rc.d/rc0.d
# ln -s /etc/rc2.d /etc/rc.d/rc2.d
# ln -s /etc/rc3.d /etc/rc.d/rc3.d
# ln -s /etc/rc4.d /etc/rc.d/rc4.d
# ln -s /etc/rc5.d /etc/rc.d/rc5.d
# ln -s /etc/rc6.d /etc/rc.d/rc6.d
# ln -s /etc/init.d /etc/rc.d/init.d

加入下面这个文件来模拟redhat.

echo “Red Hat Linux release 4″ > /etc/redhat-release

在几乎所有的安装文章里都会提到, 要设置系统参数来保证满足oracle的需要, 实际情况是, 现在的系统基本都是满足的了, 要设置这些的, 请自己去找找文章来看看, 所以这段略过, 因为我就没有设置这些参数.

ORACLE安装前期:

在这个阶段, 我们要作一些实质的东东了. 首先要建立oracle的用户与用户组:

# addgroup oinstall
# addgroup dba
# addgroup nobody
# useradd -g oinstall -G dba -p password -d /home/oracle -s /bin/bash oracle
# usermod -g nobody nobody

我是把oracle直接安装在了oracle用户下的, 所以没有再另建立目录与设置目录权限, 要不然, 请建立你想安装的oracle的目录, 然后把权限设置给oracle用户, 组设置给oinstall.

设置一下oracle的.bashrc, 添加如下参数:

export GST_ID3_TAG_ENCODING=[GBK,GB13000,UTF-8]

export JAVA_HOME=/usr/lib/jvm/java-6-sun

export JRE_HOME=$JAVA_HOME/jre

export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib:$CLASSPATH

export ORACLE_BASE=/home/oracle/app/oracle
export ORACLE_HOME=/home/oracle/app/oracle/product/11.1.0/db_1
export PATH=$PATH:$ORACLE_HOME/bin
export ORACLE_OWNER=oracle
export ORACLE_SID=orcl
export ORACLE_TERM=gnome-terminal

export LD_LIBRARY_PATH=/lib:/usr/lib:$ORACLE_HOME/lib
export LC_ALL=zh_CN.UTF-8
export LANG=zh_CN.UTF-8
export LANGUAGE=zh_CN:zh:en_CN:en
export NLS_LANG="SIMPLIFIED CHINESE"_CHINA.UTF8

当 然这些目录的路径, 请自己根据自己的喜好来设置, 那个语言编码部分, 请参考你自己的客户端使用的语言编码, 我是设置成UTF8的, 后面会说到这个的用处. 另, 网上说要设置 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib:$ORACLE_HOME/lib/stubs / 而根据实际情况, 我发现这个是一定不能设置的, 要不然, 你会发现系统的比如ls啊之类的命令都不能使用了, 原因好像是11g会很神秘的把所有系统命令所用到的系统库, 都放一份在自己的lib目录下, 结果系统命令们要用到库时就会跑oracle的lib下找, 本来这也没什么, 就浪费一些硬盘空间吧, 但, 那些库居然有错, 造成这些命令根本不能用. 所以千万不要设置这个参数.

如果你现在直接用 su oracle 来运行安装程序, 你就会很惨的发现, 你的显示器居然是不满足oracle要求的, 通不过它的安装程序的检查, 这是怎么会事呢? 难道要登出, 然后用oracle登录来安装吗? 当然这也是一个解决办法, 不过这个办法太花时间了. 其实你只要运行下面这些命令就可以了.

# su
# xhost +
# exit
# su - oracle
$ export DISPLAY=:0.0

这段命令实际上是把xserver的权限管理关了. 让其它用户也可以使用你登录时用的xserver.

安装oracle:

这么一大段步骤后, 终于要安装了. 当你解完那个zip, 然后很高兴的 ./runInstaller 后, 你看见了一个都是框框框的很黄很暴力的界面, 于是你赶紧把它关了, 嗯,嗯.

这 个问题就是与java有关了, 你没有提供java虚拟机那些中文字体. 网上的这方面的中文资料都是10g的, 而虚拟机用的都是1.4, 如果你前面安装java时, 用的是apt-get install java的话, 那安装的应该是java1.6, 1.6与1.4的字体设置是不一样的, 而且你如果光设置了系统里的java的字体, 那安装是会显示出我们漂亮的中文, 但之后的数据库创建, 你又会看到框框框的很黄很暴力的界面了, 那次, 你要是关了, 你的劳动就白费啦.

这儿, 我们要分两个步骤来, 第一建立字体文件, 你可以找一个你喜欢的中文字体, 然后把它拷贝到/usr/share/fonts/zh_CN/TrueType中, 并命名为zysong.ttf. 第二步进入/usr/lib/jvm/java-6-sun/jre/lib下, 你就会看到很多的fontconfig, 打开 fontconfig.RedHat.properties.src , 找到

filename.-misc-zysong18030-medium-r-normal--*-%d-*-*-c-*-iso10646-1

这行, 看看是不是 /usr/share/fonts/zh_CN/TrueType/zysong.ttf , 如果不是, 那改为这个. 然后找

awtfontpath.chinese-cn-iso10646

这行, 看看是不是 /usr/share/fonts/zh_CN/TrueType , 如果不是, 也改为这个.

可能要重启系统, 我方面我不是很清楚, 反正我是重启了, 然后运行 ./runInstaller 那个很黄很暴力的界面就变成了和谐的中文界面了.

你 如果很欢快的直接用其的默认设置安装了一个数据库的话, 那么, 祝贺你, 你可能要重装oracle了, 因为, 你会发现, 在你在客户端显示出来的数据库的中文居然你都不认识了. 那是因为数据库里的中文的编码与你的客户端的编码可能不一样, 当然只是可能, 如果是一样的, 那就当我没说. 一般来说, 客户端会的编码会设置为

export LC_ALL=zh_CN.UTF-8
export LANG=zh_CN.UTF-8
export LANGUAGE=zh_CN:zh:en_CN:en
export NLS_LANG="SIMPLIFIED CHINESE"_CHINA.UTF8

如 果你是如我一样设置了, 那么在安装oracle时, 请也设置一下数据库的编码格式为utf8. 当然, 你用其它编码的话, 也请安装库时将其数据库语言设置为你现在客户端的编码格式, 不过个人还是推荐UTF8, 那比什么 ZHS16GBK 什么的好多了, 而且发现一个事实是, 在LINUX上与其去改客户端的编码, 还不如直接重装数据库, 改数据库的编码, 特别是在什么数据都没有的新数据库服务器上呢. 当然如果您是牛人, 知道如何在数据库端为 ZHS16GBK时, 怎么设置客户端的话, 请给我来信(), 我会感激不尽的.

安装完了, 请使用一下sqlplus 试试你的中文是不是是不是好的.

安装后:

创建自启动脚本, 本脚本来自 wiki.ubuntu.org.cn 中孙高勇先生的  Oracle 10g for ubuntu 安装指南 这个文章.

*  创建自启动脚本
创建 oracledb 脚本到/etc/init.d/oracledb,内容如下

#!/bin/bash
#
# /etc/init.d/oracledb
#
# Run-level Startup script for the Oracle Instance, Listener, and
# Web Interface
export ORACLE_HOME=/opt/ora10
export ORACLE_SID=compiere
export PATH=$PATH:$ORACLE_HOME/bin
ORA_OWNR="oracle"
# if the executables do not exist -- display error
if [ ! -f $ORACLE_HOME/bin/dbstart -o ! -d $ORACLE_HOME ]
then
echo "Oracle startup: cannot start"
exit 1
fi
# depending on parameter -- startup, shutdown, restart
# of the instance and listener or usage display
case "$1" in
start)
# Oracle listener and instance startup
echo -n "Starting Oracle: "
su $ORA_OWNR -c "$ORACLE_HOME/bin/lsnrctl start"
su $ORA_OWNR -c $ORACLE_HOME/bin/dbstart
touch /var/lock/oracle
su $ORA_OWNR -c $ORACLE_HOME/bin/emctl start dbconsole
echo "OK"
;;
stop)
# Oracle listener and instance shutdown
echo -n "Shutdown Oracle: "
su $ORA_OWNR -c "$ORACLE_HOME/bin/lsnrctl stop"
su $ORA_OWNR -c $ORACLE_HOME/bin/dbshut
rm -f /var/lock/oracle
su $ORA_OWNR -c $ORACLE_HOME/bin/emctl stop dbconsole
echo "OK"
;;
reload|restart)
$0 stop
$0 start
;;
***)
echo "Usage: `basename $0` start|stop|restart|reload"
exit 1
esac
exit 0

设置权限,放到启动脚本中去

#chmod 755 /etc/init.d/oracledb
#update-rc.d oracledb defaults 99

这里, oracle的安装就都结束了, 这是我花了N个星期安装了N遍oracle 11g的心得, 其中大部分时间用于解决很黄很蓝图的框框框, 与客户端编码上, 如果你照本文作了还没有那个中文问题, 请给我发信(), 或这儿回复也行, 我会很感谢的.

顶(0)
踩(0)

您可能还会对下面的文章感兴趣:

最新评论