`
yanghuidang
  • 浏览: 950482 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

UNIX和WINDOWS2000上的ORACLE的差异 PartII

阅读更多

Ian Adam ,SAIC Ltd
David Stien,SAIC Ltd

翻译:Fenng
PartII

数据库启动与关闭

在Windows 2000上数据库可以通过启动相关的服务打开。通过控制面板的服务选项或者是通过命令行模式,如:

net start OracleServiceatei就可以打开相关服务。这依赖于一些注册表参数,我们在后面讨论。停止相关的服务,例如:net stop OracleServiceatei可以关闭一个数据库。

在所有的平台上,ORACLE8i实例都可以从服务管理器(或者SQL*Plus!)中通过startup命令启动。在Unix中,这个命令启动后台进程并且打开数据库。它还生成了一个Unix特定文件,叫做$ORACLE_HOME/dbs/lk<DBNAME>,这是个MOUNT锁文件[6 Metalink, 2000]。这会阻止两个实例mount在同一数据库上,当不使用并行服务器的模式下,要使用不同的ORACLE_SID。原来这是个0长度文件,不过现在包含文本'DO NOT DELETE THIS FILE!'。不要试图通过查看这个文件来得知是否数据库是可用的,它不是很准确的。在Windows 2000中,startup命令并不启动ORACLE服务,不过,如果服务已经运行的话,这将打开数据库。

类似的,服务管理器Server Manager的shutdown命令在任何平台上都会关掉数据库,不过在Windows 2000上它并不停掉服务。很有可能的情况就是ORACLE服务被启动但是数据库却关掉了。


UNIX上的数据库的自动启动与关闭

在 Unix上,ORACLE 提供了dbstart和dbshut 脚本以供使用。在Linux
中ORACLE检测文件/etc/oratab 来决定哪个数据库自动的启动/关闭。在 Solaris (和一些其他版本的Unix)中,检查/var/opt/oracle/oratab文件。要注意:8.1.6 版本的dbstart有个bug,在8.1.7中已经被修复,察看[7 Metalink, 2000]有详细说明。

在Linux上,作为root用户,在/etc/rc.d/init.d目录中创建一个一个名为dbora的文件。这个文件将会检查参数是否是 'start' 或者 'stop' 并且适当的执行 dbstart/dbshut;通常也从这个脚本启动listener 。再生成两个符号联接
/etc/rc.d/rc2.d/S99dbora 和
/etc/rc.d/rc0.d/K10dbora。数据库在运行级2(多用户)时通过/etc/rc.d/rc2.d/S99dbora
启动,在系统关闭到运行级0的时候通过/etc/rc.d/rc0.d/K10dbora关闭数据库
。在Solaris上,这个脚本的在/etc/init.d中而不是在/etc/rc.d/init.d.

要注意默认的dbshut执行了一个正常(normal)的关闭操作。在Unix 中可以通过编辑$ORACLE_HOME/bin/dbshut中的这一行来改变数据库的关闭模式。


shutdown
修改成
shutdown immediate

如果启动一个已经运行的实例,dbstart 还会执行一个 shutdown abort 。在dbstart script脚本的顶部警告说 'It should ONLY be executed as part of the system boot procedure'。这个脚本要常被复制、修改,这样在其它的时候使用才能足够安全。


WINDOWS 2000上的数据库自动的启动与关闭

在以前的版本(8i)中,当oracle的启动被一个额外的服务ORACLEStartSID处理,服务器的启动和关闭的时候ORACLE不能被自动的干净的关掉。从ORACLE8i开始,stop/start功能成为了主要的ORACLE服务,并通过注册表控制。注意当ORADIM用于创建或者修改实例的时候,自动的在注册表中设定这些值。这些设置在HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOMEID键值下。

ID 号从0开始,每有一个额外的ORACLE home递增。

-----------------------------------------------------------------
参数 描述
-----------------------------------------------------------------
ORA_SID_AUTOSTART 设定为TRUE的时候
             (默认值),ORACLEServiceSID启动的时候启动数据
              库。
ORA_SID_PFILE 设定INIT.ORA参数文件的全路径。
ORA_SHUTDOWN 当设定为TRUE的时候,在当前任何ORACLE
              home下的任何数据库将shutdown。
ORA_SID_SHUTDOWN 设定为TRUE的时候,关闭标记SID值的ORACLE8i数据库。
-----------------------------------------------------------------
如果
SHUTDOWN参数设定为FALSE,停掉ORACLEServiceSID将会abort的方式关闭实例,下次启动的
时候要进行实例恢复。


下面的可选参数可以在注册表中设为合适的值

-----------------------------------------------------------------
参数 描述
-----------------------------------------------------------------ORA_SID_SHUTDOWNTYPE 指明数据库关闭模式Aabort),

I (immediate), N (normal)。
如果你不设定这个参数的话,
                默认的模式是 I (immediate)。
ORA_SID_SHUTDOWN_TIMEOUT 在一个SID停止前等待的最大时间。
-----------------------------------------------------------------

操作系统认证

OS认证在两个平台间是相似的,参数文件中设定os_authent_prefix
参数,创建用户都标记为externally。在Windows2000中创建用户要指定大写的域名并且用户名要在 "" 中,否则不起作用。如果你在注册表中把 OSAUTH_PREFIX_DOMAIN 设定成FALSE的话,你可以忽略掉域。客户机和服务器的机器还需要在sqlnet.ora中包含sql net.authentication_services=(nts)这一行。

在 Windows 2000 中,可以允许一个域用户登陆到一个远程pc上,无需提供额外的密码就可以连接到数据库中。参见[2 K elly III,2000]可以得到详细内容。


LISTENER

在 Windows 2000上面 listener作为一个服务实现的,所以listener可以通过启动 ORACLETNSListener 服务来启动。两种平台上listener都可以从lsnrctl命令控制。在Unix上lsnrctl start启动 listener 进程;在 Windows
2000启动 ORACLETNSListener 服务就可以。 如果listener第一次启动的时候没有ORACLETNSListener服务将创建它。如果从你的计算机中删除ORACLE的话,listener 服务要手工从注册表中删除。

在两个平台上的listener都可以监听不同版本的数据库。在win2000中,
在LISTENER.ORA中不需要ORACLE_HOME参数(在UNIX中要使用到的),因为每个SID在SERVER中是唯一的。listener可以从注册表中得到正确的ORACLE_HOME。

ORACLE8i 有个特性叫服务器注册,pmon自动对listener注册信息。这意味着Net8 listener可以无需在listener.ora文件中设置就可以监听一个数据库。不过这样做的话,Enterprise Manager要直到启动后才可以连接到数据库。所以这个例子不能用来启动一个远程的实例。通常最好在listener.ora中设置所有的实例以避免冲突,尤其在一个有多位DBA的站点中,,可以避免我们提到的 Enterprise Manager 问题。


加长的SID名字

Windows NT上的ORACLE 7 实例名字有着4个字符长的限制,这可能会产生很晦涩的实例名--庆幸的是在8i中SID名字已经加长了。不过在包括命名服务的几个场合中使用太长的实例名字也不总是很有用。在Windows 2000上面有个bug,限制了实例名字最长15个字符。

----------------------------------------------------------------
     Unix NT
----------------------------------------------------------------
   数据库名 实例名    数据库名 实例名
----------------------------------------------------------------
ORACLE7 8 8      8 4
ORACLE8 8 8      8    4
ORACLE8i 8 64      8   64
----------------------------------------------------------------


数据库的创建

当你在安装过程中的时候选择创建ORACLE 8i数据库,数据库生成助手就会通过ORACLE Universal Installer
自动运行。在安装后它也可以作为一个单独的工具手工运行。用它还可以手工的输入SID代替默认的ORCL,默认的情况下,不在ORACLE_HOME下面创建数据库,完全遵循OFA的意图。

建议你运行Database Creation Assistant,不过在最后一页选择Save information to a batch file(保存信息到一个批处理文件中),再点击"完成"按钮。这会产生几个脚本。从不同的平台对比它们的内容很有趣的。在Unix 和
Windows上的内容很相似,除了windows上对oradim的调用不同。第一次对它的调用产生了一个与ORACLE 数据库相关联的ORACLE服务:

D:\ORACLE\Ora817\bin\oradim -new -sid ATEI -intpwd man -startmode manual -pfile
"D:\ORACLE\admin\atei\pfile\initatei.ora"

第二次对oradim的调用把服务更改为自动启动:

D:\ORACLE\Ora817\bin\oradim -edit -sid atei -startmode auto

可以用这些文件作为创建其它数据库的模版。若你不使用上面建议的方式创建数据库的话,Database Creation Assistant 生成的这些文件和目录没什么大用处。在使用这些脚本创建额外的数据库之前,这些文件和目录不得实现创建。特别注明一下,脚本假定一个密码文件已经存在,密码文件可以用orapwd命令预创建[2 H Kelly III, 2000]。


Database Creation Assistant创建的目录:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

Windows 2000

ORACLE_BASE = D:\oracle

Unix

ORACLE_BASE = /db01/app/oracle

ORACLE_BASE\oradata\atei

$ORACLE_BASE/oradata/eighti

ORACLE_BASE\oradata\atei\archive

$ORACLE_BASE/oradata/eighti/archive

ORACLE_BASE\admin\atei

$ORACLE_BASE/admin/eighti

还有这些子文件夹

sadhoc bdump cdump create exp pfile udump


通过Database Creation Assistant创建/改动的文件:

Windows 2000

ORACLE_HOME = D:\oracle\ora817

Unix

ORACLE_HOME = /db01/app/oracle/product/8.1.7

ORACLE_HOME\database\PWDatei.ora

$ORACLE_HOME/dbs/orapweighti.ora

ORACLE_BASE\admin\atei\pfile\initatei.ora

$ORACLE_BASE/admin/eighti/pfile/initeighti.ora

ORACLE_HOME\database\initatei.ora

包含一行

IFILE='d:\oracle\admin\atei\pfile\initatei.ora‘

$ORACLE_HOME/dbs/initeighti.ora

符号链接到:

/db01/app/oracle/admin/eighti/pfile/initeighti.ora

添加到 tnsnames.ora的条目

添加到 tnsnames.ora的条目

添加到 listener.ora的条目

添加到 listener.ora的条目

windows没有相关的操作

添加项目到oratab

通过Database Creation Assistant创建的脚本:

Windows 2000

Unix

注释

atei.bat

eighti

调用其它脚本,Windows上还可以调用ORADIM

ateirun.sql

eightirun.sh

包含创建数据库的语句

ateirun1.sql

eightirun1.sh

创建表空间/ 创建回滚段

不创建系统中的第二个回滚段

N/a

eightirun2.sh

额外的脚本(如,catproc,
这些在Windows上从ateirun1.sql中运行

ateisqlplus.sql

eightisqlplus.sh

添加 SQL*Plus 帮助

@c:\oracle\ora817\sqlplus\admin\help\helpbld.sql helpus.sql

ateialterTablespace.sql

eightialterTablespace.sh

SYSTEM用户更改默认的和临时的表空间

ateireplicate.sql

ateijava.sql

ateiordinst.sql

ateiiMedia.sql

ateidrsys.sql

ateicontext.sql

ateispatial1.sql

ateitimeseries.sql

ateivirage.sql

eightireplicate.sh

eightijava.sh

eightiordinst.sh

eightiiMedia.sh

eightidrsys.sh

eighticontext.sh

eightispatial1.sh

eightitimeseries.sh

eightivirage.sh

各种脚本,只有在你选择相应的选项的时候才会生成。


远程挂接的文件系统,如UNIX上的NFS和Windows 2000上UNC,在两个平台上都不支持。

分享到:
评论

相关推荐

    WPFGameTutorial_PartII.rar

    标题中的"WPFGameTutorial_PartII.rar"表明这是一个关于Windows Presentation Foundation (WPF) 游戏开发的教程第二部分。WPF是.NET Framework中用于构建桌面应用程序的一个强大的图形子系统,它提供了丰富的用户...

    C#编程深度探索_PartII

    《C#编程深度探索_PartII》是一份专为.NET 2.0框架下C#编程爱好者和专业人士设计的深入学习资料。这份PDF文档涵盖了C#语言的高级特性和实际应用,旨在帮助读者全面掌握C#的精髓,提升编程技能。 在.NET 2.0框架下,...

    Pricing and Promotion(PartII)

    以下是对" Pricing and Promotion(PartII)"主题的详细解析。 1. **定价策略**: - 成本加成法:这是最基础的定价策略,企业首先计算产品的生产成本,然后加上期望的利润百分比。 - 市场导向定价:企业会研究市场...

    WebSphere Business Integration Message Broker循序渐进PartII.doc

    在《WebSphere Business Integration Message Broker循序渐进PartII》中,我们深入探讨了Message Broker在企业级消息处理和集成中的应用,特别是其在消息流开发和消息格式定制方面的核心技术与实践。本文将详细阐述...

    MICCAI 2018论文PartII

    综上所述,《MICCAI 2018论文Part II》不仅是一本重要的学术资料,也是该领域科研人员进行交流和合作的重要桥梁。对于那些希望深入了解医学图像计算与计算机辅助干预领域的读者来说,这本论文集无疑是不可或缺的资源...

    tw393-partii-archive-refs-heads-master.zip

    标题“tw393-partii-archive-refs-heads-master.zip”和描述中的信息看似与Git仓库有关,因为“refs-heads”通常与Git仓库的分支引用相关。然而,标签“matlab”暗示了这个压缩包可能包含的是与MATLAB编程相关的资源...

    第5讲结构化程序设计(PartII).pptx

    第5讲结构化程序设计(PartII).pptx

    CISSP认证考试指南(英文版)第7版 PartII

    CISSP认证考试指南(英文版)第7版 PartII

    java web 整合开发 完全自学手册 光盘资料 源代码partII

    光盘资料中的源代码partII涵盖了书中各个章节的实例代码,这将帮助你更好地理解和应用所学知识。文件名称C24、C16、C21、C23、C22可能对应着不同的章节或案例,你可以根据书中的指导逐步运行和调试这些代码,以此...

    corejava_partII.ppt

    - **FlowLayout**:按照从左到右,然后从上到下的顺序放置组件。 - **GridLayout**:创建一个固定大小的网格,每个单元格可容纳一个组件。 - **GridBagLayout**:最灵活的布局管理器,允许精确控制每个组件的位置...

    Logic and Computer Design Fundamentals 逻辑与计算机设计基础 第三版 PartII

    Mano,Kime - Logic and Computer Design Fundamentals 3e 逻辑与计算机设计基础 第三版 PartII

    成为JavaGC专家PartII-如何监控Java垃圾回收

    本篇将深入探讨如何监控Java的垃圾回收,帮助开发者提升应用性能和稳定性。 Java GC的主要目标是识别并清理不再被程序引用的对象,以便有效地利用内存资源。它分为多个阶段,包括标记、扫描、整理等,以确保内存的...

    javaweb整合开发 完全自学手册 技术文档partII

    VB(Visual Basic)是Microsoft推出的可视化编程工具,适合快速开发Windows桌面应用。VB与SQL Server的结合使得开发者可以构建基于数据库的应用系统。VB提供了ADO.NET(ActiveX Data Objects .NET)框架,方便地进行...

    Computer Vision ECCV2018 Workshop partII

    Computer Vision – ECCV 2018 Workshops,Munich, Germany, September 8-14, 2018, Proceedings, Part II。 计算机视觉国际顶级期刊,2018年,第二部分。

    PartII.pdf

    3. Robin边界条件:结合了Dirichlet和Neumann条件,即函数值和导数的线性组合在边界上是已知的。 通过理解这些边界条件,并结合PDE,我们可以构建和求解复杂的物理或工程问题,如热传导、流体动力学等领域的模型。 ...

    MICCAI 2018论文集PartII.pdf

    MICCAI 2018的论文集,这是第二部分。 21st International Conference, Granada, Spain, September 16-20, 2018, Proceedings, Part II

    精通.Net核心技术高级特性partII

    .net学习的好资料,本套书由两本书组成:《精通.Net核心技术原理与构架》和《精通.Net核心技术高级特性》,每本书由三个压缩包组成。每本书必须完整下载三部分内容才可以解压。本套书覆盖了.net框架的核心技术。绝对...

    计算机数值方法教学课件第一章线性代数方程组数值解法-partii.ppt

    "计算机数值方法教学课件第一章线性代数方程组数值解法-partii.ppt" 本资源为计算机数值方法教学课件的第一章,主要讲解线性代数方程组的数值解法。下面是对该资源的详细解读。 一、迭代法(Iterative Methods for...

    精通.Net核心技术原理与构架PartII

    .net学习的好资料,本套书由两本书组成:《精通.Net核心技术原理与构架》和《精通.Net核心技术高级特性》,每本书由三个压缩包组成。每本书必须完整下载三部分内容才可以解压。本套书覆盖了.net框架的核心技术。绝对...

    ASP.NET程序开发范例宝典_PartII

    学习用 共115M 分16部分上传.希望能给大家一些帮助. 格式 PDG 每部分50页. VS2005 + SQL2005

Global site tag (gtag.js) - Google Analytics