您的位置:首页 > 数据库 > Oracle

Linux(Centos5.4)上安装oracle10gR2(10.2.1)

2012-12-27 12:57 441 查看
http://www.puschitz.com/InstallingOracle10g.shtml

我用的是Centos5.4 DVD光盘安装的linux操作系统,安装linux的时候选上开发工具,Xmanager,与数据库相关的包。

操作系统安装完成之后需要进行一系列的配置才能安装oracle10g,下面把 主要步骤记录下来。

1.安装完操作系统之后还是有些包没有安装,然而安装oracle10g的时候 需要用到,没有安装的包有:

libXp-1.0.0-8.i386.rpm

openmotif-2.3.0-0.3.el5.i386.rpm

compat-db-4.2.52-5.1.i386.rpm

ps

依赖的包有:

1.binutils-2.17.50.0.6-12.el5

  2.compat-db-4.2.52-5.1

  3.control-center-2.16.0-16.el5

  4.gcc-4.1.2-46.el5_4.1

  5.gcc-c++-4.1.2-46.el5_4.1

  6.glibc-2.5-42

  7.glibc-common-2.5-42

  8.libstdc++-4.1.2-46.el5_4.1

  9.libstdc++-devel-4.1.2-46.el5_4.1

  10.make-3.81-3.el5

  11.pdksh-5.2.14-36.el5

  12.sysstat-7.0.2-3.el5

  13.libaio-0.3.106-3.2

  14.openmotif22-2.2.3-18

  15.libXp-1.0.0-8.1.el5

2.添加组和用户

groupadd dba --创建dba组

groupadd oinstall --创建oinstall组

useradd -g oinstall -G dba -m oracle

-g表示 oracle用户属于oinstall组,也就是前面创建的oinstall组

-G表示 oracle的附加组为dba,也就是前面创建的dba组

-m表示自动创建 oracle用户的登入目录

passwd oracle --给oracle创建密码 需要连续输入两次

3.创建安装目录和授予权限

mkdir -p /u01/app/oracle --创建ORACLE_BASE目录,我是将/u01/app/oracle单独挂在到一个磁盘

chown -R oracle.oinstall /u01 --让oracle用户成为/u01的拥有者

4.在/etc/sysctl.conf中添加如下内容

kernel.shmall = 2097152 (已经定义了,直接在上面修改)

kernel.shmmax = 2147483648 (已经定义了,直接修改)

kernel.shmmni = 4096

# semaphores: semmsl, semmns, semopm, semmni

kernel.sem = 250 32000 100 128

fs.file-max = 65536

net.ipv4.ip_local_port_range = 1024 65000

net.core.rmem_default=262144

net.core.rmem_max=262144

net.core.wmem_default=262144

net.core.wmem_max=262144

我是 添加到最末尾的,注意对齐

5. 运行如下命令使刚才修改的参数生效

/sbin/sysctl -p

6.在/etc/security/limits.conf 文 件中增加如下内容

* soft nproc 2047

* hard nproc 16384

* soft nofile 1024

* hard nofile 65536

注意 我是在 END FILE 之前添加的,注意对齐

7.在/etc/pam.d/login 中 添加如下内容

session required /lib/security/pam_limits.so

8. 因为 SELINUX 对 oracle 有影响,所以把 secure
linux 设成无效,编辑文件 /etc/selinux/config : SELINUX=disabled

9.改 变操作系统版本,因为 oraclce10g 不支持 Centos5.4(RHEL5),将 /etc/redhat-release 里面的 5 改成 4 ,安装完之后该回来 Centos5.4 里
面是 5.4 (Final)

10.以oracle用户登录系统

vi .bash_profile 增加下面内容到.bash_profile中

export NLS_LANG="AMERICAN_AMERICA.UTF8"

TMP=/tmp; export TMP

TMPDIR=$TMP; export TMPDIR

ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE

ORACLE_HOME=$ORACLE_BASE/product/10.2.1/db_1; export ORACLE_HOME

ORACLE_SID=oracle; export ORACLE_SID

ORACLE_TERM=xterm; export ORACLE_TERM

PATH=$PATH:$ORACLE_HOME/bin; export PATH

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib; export LD_LIBRARY_PATH

CLASSPATH=$ORACLE_HOME/JREORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH

到此准备过程基本完成,在安装快要结束的时候会要求以root身份执行两个脚本

我们可以通过cygwin远程连接 到linux主机安装oracle10g,如果这样安装需要xhost + ,export DISPLAY

也可以直接在linux主机上用图 形化的界面安装oracle10g,我们只需打开一个shell,将oracle的runInstaller拖拽到shell中,稍等片刻就会出现熟悉的 安装界面了。

***********************

四、 自启动设置

Oracle 10g需要启动以下服务(在oracle用户下)

$ lsnrctl start

$ dbstart

$ emctl start dbconsole

$ isqlplusctl start

所以需要做以下配置:

默认dbstart是不起作用的。需要以下配置

1.修改/etc/oratab

$ vi /etc/oratab

oradb:/opt/ora10/product/10.2.0.1:Y(原来是N改为Y)

2.拷贝一个系统配置好的 PFILE 到 dbs 目录下

# cp /opt/ora10/admin/oradb/pfile/init.ora.2292007201045 $ORACLE_HOME/dbs/init.ora ($ORACLE_HOME路径要看安装路径而定)

现在你可以测试一下

$ dbstart

注:如果安装版本是10201,可能会出现这个错误:

Failed to auto-start Oracle Net Listene using /ade/vikrkuma_new/oracle/bin/tnslsnr

修改dbstart的第78行 ($ORACLE_HOME/bin/dbstart)

ORACLE_HOME_LISTNER=/ade/vikrkuma_new/oracle

为ORACLE_HOME_LISTNER=$ORACLE_HOME

$emctl start dbconsole : 还有,我在启动EM控制台的时候又遇到了错误:Environment variable ORACLE_UNQNAME not defined. Please set ORACLE_UNQNAME to database unique name.

设置了这个变量后(运行export ORACLE_UNQNAME=xxxx实例名)后,再启动EM控制台,又出现了新的错误:OC4J Configuration issue. /u01/app/oracle/product/11.2.0/db_1/oc4j/j2ee/OC4J_DBConsole_xxxx not found.没有这个文件?去查了一下,确实是没有这样一个文件存在,怎么办呢?其实很简单,运行:

emca -config dbcontrol db

根据向导重新配置一下就可以了,port 要配对,默人listen的port是1521.

$ dbshut

最后在/etc/rc.d/rc.local中加入如下代码:

su - oracle -c "lsnrctl start"

su - oracle -c "dbstart"

su - oracle -c "emctl start dbconsole"

su - oracle -c "isqlplusctl start"

这样重启动服务器后Oracle就会自动启动了。

五、 Oracle 10g设置

iSQL*Plus URL:连接地址:http://server:5560/isqlplus

iSQL*Plus DBA URL:连接地址:http://server:5560/isqlplus/dba

Enterprise Manager 10g Database Control URL:连接地址:http://server:1158/em

用户名:sys

口令:******

连接身份:SYSDBA

继续登陆请单击 “我同意”按键;

#su – oracle

$ startx

$netca启动配置网络配置助手

$sqlplus /nolog启动sqlplus

$dbca 启动数据库配置助手(DCA),建oracle数据库

其他参考网址:

在 Linux x86 上安装 Oracle 数据库 10g

http://www.oracle.com/technology/global/cn/pub/articles/smiley_10gdb_install.html

Oracle® Database Quick Installation Guide

10g Release 2 (10.2) for Linux x86-64

http://download-west.oracle.com/docs/cd/B19306_01/install.102/b15668/toc.htm

Installing Oracle Database 10g Release 1 and 2 (32-bit/64-bit) on Red Hat Enterprise Linux AS 4, 3, 2.1, Red Hat Fedora Core 4, 3, 1, RH 9 on x86 and x86-64 (AMD64/EM64T) Architecture

http://www.puschitz.com/InstallingOracle10g.shtml

=========================================================

Oracle10g:如何以DBA身份登陆iSQL*Plus
导读:

  一般用户登陆isqlplus的网址http://ip:port/isqlplus,进入该网址后会直接进入数据库用户登陆界面,使用数据库中的普通用户即可登陆。

  DBA用户登陆isqlpus的网址http://ip:port/isqlplus/dba,进入该网址后首先会弹出一个登陆框,要求先输入iSQL*Plus DBA的用户和密码,注意这里不是数据库用户,而是isqlplus应用服务器要求的用户和密码。

  要以DBA身份登陆isqlplus,必须先配置好oc4j用户。oc4j可以使用两种身份认证方式:

  基于xml配置文件(jazn-data.xml)

  基于LDAP(Oracle Internet Directory)

  本文只涉及第一种方式,也就是采用xml配置文件认证的方式。该配置文件位于$ORACLE_HOME/oc4j/j2ee/isqlplus/application-deployments/isqlplus/config。

  但 是该配置文件中的密码是加密过的,所以我们不能手动修改该文件,而是通过JAZN(Java AuthoriZatioN)来配置。JAZN是oracle提供的一个JASS(Java Authentication and Authorization Service)工具,java的东西我不太懂,所幸这里只要照着文档一步步操作就ok。

  通过JAZN,可以完成以下任务

  Create users

  List users

  Grant the webDba role

  Remove users

  Revoke the webDba role

  Change user passwords

以上任务,可以先进入JAZN命令环境后再执行,也可以直接通过一条完整的命令行实现。完整的命令行其实就是在进入JAZN的命令后面直接加上对应的任务选项即可,本文只以JAZN命令环境为例。

  如何进入JAZN命令环境

  1.进入到目录$ORACLE_HOME/oc4j/j2ee/isqlplus/application-deployments/isqlplus/

  2.确保JAVA_HOME环境变量指向了正确的jdk(需要1.4以上)路径,可以使用oracle自带的jdk,位于$ORACLE_HOME/jdk

  3.执行以下命令

  java -Djava.security.properties=$ORACLE_HOME/sqlplus/admin/iplus/provider -jar $ORACLE_HOME/oc4j/j2ee/home/jazn.jar -user "iSQL*Plus DBA/admin" -password welcome -shell

  其中realm=iSQL*Plus DBA,user=admin,这些可以从xml配置文件中看到,admin的默认密码是welcome,但是admin用户默认没有webDba权限,不能直接用于登陆isqlplus。

  注意该命令一定要先进入第一步的目录后再执行,否则会报错

  oracle.security.jazn.JAZNRuntimeException: Configuration file "configjazn.xml" does not exist. Check your JAAS configuration settings.

  或者

  Realm [iSQL*Plus DBA] does not exist in system.

  如果报以上的错误,请仔细检查你的当前目录是否和第一步中给出的目录完全一致。

  进入JAZN命令环境后,可以执行所有的任务:

  1.新建用户ning,密码pass

  JAZN:> adduser "iSQL*Plus DBA" ning pass

  2.列出用户

  JAZN:> listusers

  iSQL*Plus DBA/admin

  iSQL*Plus DBA/ning

  JAZN:> listusers "iSQL*Plus DBA"

  admin

  ning

  3.授予用户登陆isqlplus DBA的权限

  JAZN:> grantrole webDba "iSQL*Plus DBA" ning

  4.撤销用户登陆isqlplus DBA的权限

  JAZN:> revokerole webDba "iSQL*Plus DBA" ning

  5.删除用户

  JAZN:> remuser "iSQL*Plus DBA" ning

  6.修改用户密码

  JAZN:> setpasswd "iSQL*Plus DBA" ning pass newpass

  7.退出JAZN命令环境

  JAZN:> exit

  假设上面我们创建了一个用户ning,密码为pass,并且已经授予webDba权限。

  接下来重新启动isqlplus应用服务器

  isqlplusctl stop

  isqlplusctl start

  再进入网址http://ip:port/isqlplus/dba,在弹出的对话框中输入ning和pass,就可以进入到数据库登陆界面了,选择以sysdba或sysoper身份登陆了。

  参考文章

  Oracle10g如何启用isqlplus :http://ningoo.itpub.net/post/2149/200372

Oracle官方文档中关于如何启用dba身份登陆isqlplus:http://download-west.oracle.com/
... 57/ch2.htm#CIHDEFBA

====================================================


oracle 10g em 按钮乱码解决

1.修改jdk 下面的字体。

[oracle@rac2 db_1]$ cd $ORACLE_HOME/jdk/jre/lib/

[oracle@rac2 lib]$ mv font.properties font.properties_bak

[oracle@rac2 lib]$

[oracle@rac2 lib]$ cp font.properties.zh_CN.Redhat font.properties

[oracle@rac2 lib]$

2.修改jre 下面的字体

[oracle@rac2 lib]$ cd $ORACLE_HOME/jre/1.4.2/lib

[oracle@rac2 lib]$ mv font.properties font.properties_bak

[oracle@rac2 lib]$ cp font.properties.zh_CN.Redhat font.properties

非redhat系统 ,打开 font.properties 最后一行把字体路径改为自己系统中的中文字体路径

最简单的就是把浏览器设成第一语言为 English, 用英文管理就没什么乱码了。

3.清除em的cache

[oracle@rac2 lib]$ cd $ORACLE_HOME/oc4j/j2ee/oc4j_applications/applications/em/em/cabo/images/cache/zhs

[oracle@rac2 zhs]$ rm *.gif

4. 重新启动em

[oracle@rac2 zhs]$ emctl stop dbconsole

[oracle@rac2 zhs]$ emctl start dbconsole
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: