169it科技资讯


当前位置:  数据库>oracle

教你如何静默安装ORACLE

    来源: 互联网  发布时间:2014-10-04

由于本次的实验我是将上次的虚拟机直接拷贝过来,然后将里面图形化界面安装好了的oracle给删除,再次重新安装,所以这里要修改一些配置。

首先修改的是我们的IP地址

# system-config-network

完成后我们修改一下hosts文件,将里面的ip地址给修改一下

# vi /etc/hosts

接着我们删除上次安装过的ORACLE文件

# cd $ORACLE_BASE
# ls
# rm -rf *

进入root:rm -rf /etc/ora*
还是在安装前进行配置。
接下来进行静默安装。首先我们先要创建一个相应文件,这个文件里记录了我们oracle安装的所有过程

[oracle@oracle ~]$ cd /u01/database/response
$ cp enterprise.rsp /u01
$ vi /u01/enterprise.rsp

修改一下内容:

35 UNIX_GROUP_NAME=\"oinstall\"
 62 ORACLE_HOME=\"/u01/app/oracle/10.2.0/db_1\"
 70 ORACLE_HOME_NAME=\"OraDbHome1\"
 351 COMPONENT_LANGUAGES={\"en,zh_CN\"}
 384 s_nameForDBAGrp=\"dba\"
 392 s_nameForOPERGrp=\"oper\"
 422 n_configurationOption=3

开始安装:

[oracle@oracle ~]$ cd /u01/database
$ ./runInstaller -silent -responseFile /u01/enterprise.rsp

安装完成后执行以下脚本

$ORACLE_BASE/oraInventory/orainstRoot.sh
$ORACLE_HOME/root.sh

执行完脚本以后使用:sqlplus / as sysdba即可知道oracle的版本为:10.2.0.1.0
静默升级数据库

$ cp /u01/Disk1/response/patchset.rsp /u01
vi /u01/patchset.rsp编辑如下行:
  45 UNIX_GROUP_NAME=\"oinstall\"
  87 ORACLE_HOME=\"/u01/app/oracle/10.2.0/db_1\"
  99 ORACLE_HOME_NAME=\"OraDbHome1\"
  533 MYORACLESUPPORT_USERNAME=\"zhaoming@sina.com\"
  542 MYORACLESUPPORT_PASSWORD=\"b\"
  603 DECLINE_SECURITY_UPDATES=true

进行安装升级的补丁

$ ./runInstaller -silent -responseFile /u01/patchset.rsp

升级成功

$ sqlplus / as sysdba;
Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

 接下来进行手工建库

$ vi $ORACLE_HOME/dbs/initorcl.ora
写入以下内容:
compatible=10.2.0.5
instance_name=orcl
db_name=orcl
sga_target=500M
sga_max_size=500M
job_queue_processes=10
undo_management=auto
undo_tablespace=undotbs
audit_file_dest=$ORACLE_BASE/admin/orcl/adump
background_dump_dest=$ORACLE_BASE/admin/orcl/bdump
core_dump_dest=$ORACLE_BASE/admin/orcl/cdump
user_dump_dest=$ORACLE_BASE/admin/orcl/udump
control_files=\'/u01/app/oracle/oradata/orcl/control01.ctl\',\'/u01/app/oracle/oradata/orcl/control02.ctl\'
保存退出

 创建跟踪目录:

mkdir -p $ORACLE_BASE/admin/orcl/{a,b,c,u}dump

创建控制文件的位置

mkdir -p /u01/app/oracle/oradata/orcl/

  启动到实例:

sqlplus / as sysdba
create spfile from pfile;
startup nomount

 接下来进行创建数据库
 vi createdb.sql写入如下内容:

CREATE DATABASE orcl
  USER SYS IDENTIFIED BY a  ---这里需要修改你的密码
  USER SYSTEM IDENTIFIED BY a
  LOGFILE GROUP 1 (\'/u01/app/oracle/oradata/orcl/redo01.log\') SIZE 50M,
      GROUP 2 (\'/u01/app/oracle/oradata/orcl/redo02.log\') SIZE 50M,
      GROUP 3 (\'/u01/app/oracle/oradata/orcl/redo03.log\') SIZE 50M
  MAXLOGFILES 5
  MAXLOGMEMBERS 5
  MAXLOGHISTORY 1
  MAXDATAFILES 100
  MAXINSTANCES 1
  CHARACTER SET utf8
  NATIONAL CHARACTER SET utf8
  DATAFILE \'/u01/app/oracle/oradata/orcl/system01.dbf\' SIZE 325M REUSE
  EXTENT MANAGEMENT LOCAL
  SYSAUX DATAFILE \'/u01/app/oracle/oradata/orcl/sysaux01.dbf\' SIZE 325M REUSE
  DEFAULT TABLESPACE users datafile \'/u01/app/oracle/oradata/orcl/users01.dbf\' size 200M
  DEFAULT TEMPORARY TABLESPACE temp
   TEMPFILE \'/u01/app/oracle/oradata/orcl/temp01.dbf\'
   SIZE 20M REUSE
  UNDO TABLESPACE undotbs
   DATAFILE \'/u01/app/oracle/oradata/orcl/undotbs01.dbf\'
   SIZE 200M REUSE AUTOEXTEND ON MAXSIZE UNLIMITED
/

 然后在sql中引用到这些脚本

sql> get /u01/create.sql  ---解释一下get的作用:就是引用操作系统目录下的任意一个文件引入到sql中来。
sql> .........
sql>/

-----执行完这些脚本语句之后就会在相应的位置产生控制文件、数据文件、日志文件等----
 接着执行

sql>desc dba_tables
ERROR:
ORA-04043: object dba_tables does not exist

----解释一下:这里查询的是数据字典,我们这里只不过建好了数据库,并没有将数据库相关的视图、表、索引、数据字典等建好。----
 所以我们呢要来建这些视图、表、索引了。

$ cd /u01
vi jb.sql写入如下内容:
@?/rdbms/admin/catalog.sql ----catalog.sql:创建数据字典
@?/rdbms/admin/catproc.sql  ----catproc.sql:安装ORACLE自定义的包
conn system/a
@?/sqlplus/admin/pupbld.sql  ----pupbld.sql:屏蔽sqlplus错误

 接着在数据库中执行这段脚本:

sql>@/u01/jb.sql

---这里解释一下:@:可以执行操作系统下的某个脚本中sql语句

 紧接着就是漫长的等待,估计20多分钟吧。

 执行完成后,你会看到很多什么表啊视图什么的,does not exist。不用管他,这是创建数据字典时候先去查询这些表存不存在。当然不存在啊,因为都还没创建,所以自然会报错。

sql>desc dba_tables

 完了后这个时候就有内容了。

sql> select count(*) from dba_tables

 接下来我们进行OEM的安装,安装之前我们先将补丁给补上。补丁我们也是采用禁默安装。补丁:

p8350262_10205_Generic.zip

 将补丁上传到目录:$ORACLE_HOME/OPatch/  解压缩:
$ unzip p8350262_10205_Generic.zip
 得到一个目录为:8350262
 打补丁:

$ emctl stop dbconsole
$ cd $ORACLE_HOME/OPatch
$ ./opatch apply 8350262

 补丁安装上去之后

$ lsnrctl status 显示: No Listener

 然后我们做:

$ cd /u01/database/response/
$ cp netca.rsp /u01
$ netca /silent /responseFile /u01/netca.rsp

 安装完监听器后我们进入sqlplus去将数据库注册到这个监听器上。

$ sqlplus / as sysdba;
sqlplus>alter system register

 监听器安装完成后我们进行安装资料库

SQL> select username from dba_users where username=\'SYSMAN\';
     no rows selected

 执行安装资料库命令:

$ emca -repos create 
STARTED EMCA at Mar 30, 2013 9:57:23 AM
EM Configuration Assistant, Version 10.2.0.1.0 Production
Copyright (c) 2003, 2005, Oracle. All rights reserved.
Enter the following information:
Database SID: orcl
Listener port number: 1521
Password for SYS user: 
Password for SYSMAN user: 
Password for SYSMAN user: 
Do you wish to continue? [yes(Y)/no(N)]: Y
Mar 30, 2013 9:58:28 AM oracle.sysman.emcp.EMConfig perform
INFO: This operation is being logged at /u01/app/oracle/10.2.0/db_1/cfgtoollogs/emca/orcl/emca_2013-03-30_09-57-2-AM.log.
Mar 30, 2013 9:58:28 AM oracle.sysman.emcp.EMReposConfig createRepository
INFO: Creating the EM repository (this may take a while) ...
Mar 30, 2013 10:00:42 AM oracle.sysman.emcp.EMReposConfig invoke
INFO: Repository successfully created
Enterprise Manager configuration completed successfully
FINISHED EMCA at Mar 30, 2013 10:00:42 AM

 资料库安装完成后我们进行安装控制台:

$ emca -config dbcontrol db
STARTED EMCA at Mar 30, 2013 10:01:47 AM
EM Configuration Assistant, Version 10.2.0.1.0 Production
Copyright (c) 2003, 2005, Oracle. All rights reserved.
Enter the following information:
Database SID: orcl
Listener port number: 1521
Password for SYS user: 
Password for DBSNMP user: 
Password for SYSMAN user: 
Invalid username/password.
Password for SYSMAN user: 
Email address for notifications (optional): 
Outgoing Mail (SMTP) server for notifications (optional): 
-----------------------------------------------------------------
You have specified the following settings
Database ORACLE_HOME ................ /u01/app/oracle/10.2.0/db_1
Database hostname ................ hndx
Listener port number ................ 1521
Database SID ................ orcl
Email address for notifications ............... 
Outgoing Mail (SMTP) server for notifications ............... 
-----------------------------------------------------------------
Do you wish to continue? [yes(Y)/no(N)]: Y
Mar 30, 2013 10:02:42 AM oracle.sysman.emcp.EMConfig perform
INFO: This operation is being logged at /u01/app/oracle/10.2.0/db_1/cfgtoollogs/emca/orcl/emca_2013-03-30_10-01-4-AM.log.
Mar 30, 2013 10:02:48 AM oracle.sysman.emcp.util.DBControlUtil startOMS
INFO: Starting Database Control (this may take a while) ...
Mar 30, 2013 10:04:24 AM oracle.sysman.emcp.EMDBPostConfig performConfiguration
INFO: Database Control started successfully
Mar 30, 2013 10:04:24 AM oracle.sysman.emcp.EMDBPostConfig performConfiguration
INFO: >>>>>>>>>>> The Database Control URL is http://hndx:1158/em <<<<<<<<<<<
Enterprise Manager configuration completed successfully
FINISHED EMCA at Mar 30, 2013 10:04:24 AM

 马上就大功告成了
$ firefox http://hndx:1158/em    --如果报错:用户名密码错误,请先创建口令文件:
 创建口令文件:

orapwd file=$ORACLE_HOME/dbs/orapworcl password=xxxxx---用户名自己定义

 是不是看到火狐浏览器的界面很亲切呢。这里估计还会有错误,就是要添加证书,进入后添加点击下面的添加就好了。


    
相关技术文章:
    ▪Oracle 表三种连接方式使用介绍(sql优化)

     1. NESTED LOOP 对于被连接的数据子集较小的情况,nested loop连接是个较好的选择。nested loop就是扫描一个表,每读到一条记录,就根据索引去另一个表里面查找,没有索引一般就不会是 nested loops。一般在nested loop中, 驱动表满足条件结果集不大,被驱动表的连接字段要有索引,这样就走nstedloop。如果驱动表返回记录太多,就不适合nested loops了。如果连接字段没有索引,则适合走hash join,因为不需要索引。 可用ordered提示来改变CBO默认的驱动表,可用USE_NL(table_name1 table_name2)提示来强制使用nested loop。 要点如下: 1)对于被连接的数据......


    ▪oracle复习笔记之PL/SQL程序所要了解的知识点

     复习内容: PL/SQL的基本语法、记录类型、流程控制、游标的使用、 异常处理机制、存储函数/存储过程、触发器。 为方便大家跟着我的笔记练习,为此提供数据库表文件给大家下载:点我下载 ......


    ▪向Oracle数据库的CLOB属性插入数据报字符串过长错误

     今天在项目中向数据库的CLOB属性插入一段篇文章(1000~2000)字就会报一个字符串过长的错误。 网上说用流来处理,没有这么做。这像是一个Bug,只要把插入的数据,默认扩充到2000以上就ok了。 下面是这段代码: if((temp.length()>=1000)&&(temp.length()<=2000)){ temp=StringUtils.rightPad(temp, 2008); } 使用StringUtils的rightPad方法使没超过2000的部分,在右边自动填充0,直到2008长度。 (一个半角字符一个字节,一个全角字符两个字节,所以汉字1000-2000,而英文2000-4000) Don't hurry say have no choice, perhaps, next inter......


 
最新技术文章:
    ▪Oracle 系统变量函数介绍

     Oracle函数多种多样,系统变量函数就是其中之一,下面就为您介绍三种最常见的系统变量函数,希望对您学习Oracle能有所帮助。 Oracle系统变量函数: (1)SYSDATE 该函数返回当前的日期和时间。返回的是Oracle服务器的当前日期和时间。 select sysdate from dual; insert into purchase values (‘Small Widget','SH',sysdate, 10); insert into purchase values (‘Meduem Wodget','SH',sysdate-15, 15); 查看最近30天的所有销售记录,使用如下命令: select * from purchase where purchase_date between (sysdate-30) and sysdate; (2)USER ......


    ▪oracle trunc()函数的使用方法

     oracle trunc()函数是最常用的函数之一,下面就为您介绍oracle trunc()函数的用法,供您参考,希望可以让您对oracle trunc()函数有更深的认识。 1.TRUNC(for dates) TRUNC函数为指定元素而截去的日期值。 其具体的语法格式如下: TRUNC(date[,fmt]) 其中: date一个日期值 fmt        日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去 下面是该函数的使用情况: TRUNC(TO_DATE('24-Nov-1999 08:00 pm','dd-mon-yyyy hh:mi am'))         ='24-Nov-1999 12:00:00 am' TRUNC(TO_DATE('24-Nov-1999 08:37 pm','dd-mon-yyyy hh:mi am'......


    ▪ORACLE学习笔记-新建用户及建表篇

     一、用户相关SQL语句 /*新建用户*/ create user SA identified by 2013; 说明:SA用户名,2013密码 /*授权connect,resource给用户sa*/ grant connect,resource to sa; 说明:CONNECT角色: --是授予最终用户的典型权利,最基本的 。         ESOURCE 角色: --是授予开发人员的 /*查询所有的用户*/ select * from all_users; /*将表STU查询权限授予SA*/ GRANT SELECT ON STU TO SA /*将表STU添加......


 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2017,169IT.COM,E-mail:www_169it_com#163.com(请将#改为@)

浙ICP备11055608号