Solaris9下安装Oracle9操作指南精品资料.doc

上传人:封****n 文档编号:96699062 上传时间:2024-03-10 格式:DOC 页数:45 大小:737KB
返回 下载 相关 举报
Solaris9下安装Oracle9操作指南精品资料.doc_第1页
第1页 / 共45页
Solaris9下安装Oracle9操作指南精品资料.doc_第2页
第2页 / 共45页
点击查看更多>>
资源描述

《Solaris9下安装Oracle9操作指南精品资料.doc》由会员分享,可在线阅读,更多相关《Solaris9下安装Oracle9操作指南精品资料.doc(45页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、Solaris9下安装Oracle9操作指南从Oracle提供的安装手册看,在所有的Unix操作系统中(包括AIX,HP,Linux,Solaris和Tru64)安装Oracle 9i都是一样的道理,只是命令有所变化。下面是俺在Solaris 9下安装Oracle 9.2的经验总结,这个方法同样适用于Solaris 8和Oracle 9.0。希望能给大家提供帮助。二参考资料有很多人不知道如何安装、管理和调整Oracle,其实在 下有大量PDF文件讲解Oracle的基本操作。当然,Oracle 9.2在Unix操作系统(包括AIX,HP,Linux,Solaris和Tru64)的安装手册也包括在

2、里面,文件名是a96167.pdf。(当然是English,幸好俺们村开过扫盲班,俺们都认得。俺认为Oracle有雇佣童工的嫌疑,不然单词量怎么只相当于俺们的高中英文)。Oracle真够大公无私的吧!俺就喜欢这样的公司!但是,Oracle提供的操作手册实在是太详细了,详细得把俺们农民搞糊涂了:有太多Requirements,Patches,Packages,Recommend之类的(俺好歹也进城了,翠花说俺就是因为实在,不懂时不时需要从牙缝里挤出几个单词,才没被Oracle看上。俺得改改这个毛病)。其实,人家Solaris也是大公司,早就装好这些东东了。所以,听俺的,俺都已经替你检查过了,步骤

3、都精减过了,不必翻那本200多页的手册了。俺的一些经验,它还没讲呢!什么?俺们农民你都不信?好吧,俺再友情赠送你检验的步骤。好了,开始!三X-Windows的使用根据有些参考书的指示,可以在服务器本机上安装Oracle,但俺在Linux和Solaris上的经验告诉俺:有些人是蒙事的,俺从来没试成过!所以,别浪费时间了,直接通过远程终端装Oracle吧。在远程终端安装Oracle需要使用虚拟X-Windows方式什么?你不会用虚拟X-Windows?俺刚开始也不会用,考虑到俺当时的难处,俺就再附送一份教材吧!虚拟X-Windows在MS Windows下有许多程序,比较出名的是Hummingbi

4、rd Exceed和X-Win32,Exceed太大了,而且很难找到。推荐使用X-Win32。俺下载X-Win32后,按照网上提供的注册码输入,无效!(城里人怎么都这样?)好在X-Win32的试用版每次运行都可以使用2小时,俺手快,70分钟可以全部装完Oracle,所以下载X-Win32 5.1,在工作站的MS Windows 操作系统中装好后,运行X-Config,进行基本的配置,如图1和图2。其中服务器的IP地址是10.11.31.4,工作站的IP地址是10.11.31.70。 图1配置X-Win32的会话 图2容许服务器在远程终端中显示设置完成后,测试X-Win32是否能运行:在MS D

5、OS窗口中,键入:telnet 10.11.31.4,输入用户和帐号,接着键入图1 中的Command命令:/usr/openwin/bin/xterm ls display 工作站的IP地址:0,OK!看到图3的结果了吧!不同的服务器端的操作系统,启动X-Windows的命令会有所不同,请注意! 图3使用X-Win32 来源四配置各种参数从俺的几次安装经验来看,最重要的就是要正确配置参数。回想几次不成功的安装,问题都集中在俺一时犯迷糊,设错了参数。以下的操作除了特别声明外,都是以root身份进行的。 1硬件配置要求安装Oracle 9i要求的最低硬件配置如下:Memory:512MBSwap

6、 space:1GDisk space: Database software:3.5G;seed database:1GTemporary disk space:400MB in /tmp 2设置Swap space设置Swap space的基本命令是 swap,-a是增加,-l是列表,-s是显示状态,-d是删除。为达到1G的Swap space要求,创建临时交换空间,命令如下:mkfile1000m/tmpswapswapa/tmpswapswap-l注意:重新启动后,临时交换空间不会自动加载,需要再次执行swapa命令。安装完毕后,可以用swapd/tmpswap;rm/tmpswap命令

7、删除交换空间和临时文件。 3设置临时目录如果 /tmp 目录下没有400MB的容量,可以设置临时目录:mkdir/tmpchmod1777/tmpsetTEMP=/tmp; exportTEMPsetTMPDIR=/tmp; exportTMPDIR安装完毕后,键入命令:unsetTEMP;unsetTMPDIR 即可取消临时目录。 4检查包文件和补丁程序在a96167.pdf文件中,有需要安装的包文件和补丁程序的详细清单,此处不再列出。比较重要的有:JRE 1.1.8_15,JDK1.3.1_02等,不过这些文件和程序在安装Solaris 9 时已经安装,或者在安装Oracle 9时会安装。

8、所以不用管它,除非你有特殊要求。你不信俺,也可以打开a96167.pdf文件,对照清单,用如下命令一一检查:pkginfo-ipackage_name或 showrev-p5设置用户和组Oracle在安装和使用中需要用特定用户,不能用 root用户来安装和运行Oracle 9i。推荐使用oracle 帐号。另外,安装Oracle HTTP Server时,需要一个apache的管理员,推荐使用apache帐号。操作步骤如下:groupadddbagroupaddoinstalluseradd-d/export/home/oracle-goinstall-Gdbamoraclepasswdora

9、clegroupaddapchadmuseradd-d/export/home/apache-goinstall-Gapchadmmapachepasswdapache6设置内核参数(Kernel Parameter)Oracle 9i使用Solaris的共享内存、交换区等资源进行工作,因而内核参数的是Oracle 9i能否正常安装和运行的关键,我的两次失误都是出现在此。Solaris的内核参数保存在 /etc/system 文件内。用vi之类的文件编辑器打开 /etc/system 。按照Oracle 9i的要求,设置如下:set semsys:seminfo_semmni=100set s

10、emsys:seminfo_semmns=1024set semsys:seminfo_semmsl=256set shmsys:shminfo_shmmax=4294967295set shmsys:shminfo_shmmin=1set shmsys:shminfo_shmmni=100set shmsys:shminfo_shmseg=10设置完毕后,保存,重新启动后设置生效。 7设置安装目录oracle9i的典型安装需要至少两个安装点:一个安装基本的运行程序;一个为存放数据库,为简便,我将它们放在了同一个目录下,分别是/u01/oracle和/u01/oracle/product/9.

11、2.0。mkdir/u01/oraclemkdir/u01/oracle/productmkdir/u01/oracle/product/9.2.0chown-Roracle:oinstall/u01/oracle8设置oracle用户的环境变量oracle用户的环境变量文件是 $HOME/.profile,用vi之类的文件编辑工具打开。我的设置如下:DISPLAY=10.11.31.70:0.0; export DISPLAYORACLE_BASE=/u01/oracle; export ORACLE_BASEORACLE_HOME=/u01/oracle/product/9.2.0; ex

12、port ORACLE_HOMEORACLE_SID=orclsol; export ORACLE_SIDORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data; export ORA_NLS33LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:usr/lib:$LD_LIBRARY_PATHexport LD_LIBRARY_PATHNLS_LANG=american_america.ZHS16GBK; export NLS_LANGPATH=$ORACLE_HOME/bin:/usr/bin:/usr/ucb:/etc:/usr

13、/openwin/bin:/usr/ccs/bin其中,DISPLAY是远程终端的IP地址,按照某些参考资料的说明,可以在服务器本机上安装Oracle 9i。但我试了几次都没成功,所以推荐在远程终端安装的方式。9下载安装文件可以从 网站下载Oracle 9i for Solaris的文件,不过你可要遵守它的License,以免产生版权问题。俺可不主张使用盗版!下载的3个文件如下:solaris64_9.2.0.1.0.disk1.cpio,solaris64_9.2.0.1.0.disk3.cpio,solaris64_9.2.0.1.0.disk2.cpio。将其放到临时目录,例如/file

14、s,更改文件属主:chownoracle:oinstallsolaris64_9.2.0.1.0.disk1.cpio.gzchownoracle:oinstallsolaris64_9.2.0.1.0.disk2.cpio.gzchownoracle:oinstallsolaris64_9.2.0.1.0.disk3.cpio.gz将上述3个文件解压,命令如下:zcat solaris64_9.2.0.1.0.disk1.cpio.gz | cpio -idmvzcat solaris64_9.2.0.1.0.disk2.cpio.gz | cpio -idmvzcat solaris64_

15、9.2.0.1.0.disk3.cpio.gz | cpio -idmv解压后,在临时目录下形成 disk1,disk2,disk3等3个目录。可以用这些目录安装Oracle 9i。也可以将这3个目录刻到光盘上,用光盘安装。五安装Oracle在远程终端启动X-Win32,不必让它登录到主机,处于等待状态就可以了。在服务器端,转换到oracle身份:su oracle如果用硬盘中的安装文件,运行安装命令:cd /files(存放Oracle 9i安装文件的临时目录)disk1/runInstaller如果是用光盘安装,运行安装命令:/cdrom/cdrom/ runInstaller在远程终端可

16、以见到Oracle 欢迎logo,学名是OUI安装程序,如图4: 图4Oracle 安装欢迎界面选择“Next”,在“Name:”填个名字,“Path:”处填ORACLE_HOME的路径。在安装过程中,系统会提示你以root的身份在另一个窗口执行一些命令,照做就行了。 图5存放文件的位置 来源:考图6选择数据库服务器的版本 图7选择数据库服务器的类型 图8选择数据库服务器的字符集进入字符集的选项,不用默认的,而选ZHS16GBK。在图6时曾出现过“Product Language”的选项,那是安装界面的语言选项,与数据库的语言选项无关,可以不理睬。然后,进入正式的安装过程,如图9所示,到后半段

17、,就是开始连接数据库时,运行得非常慢,经常几分钟都没有动静。耐心等待就行了。 图9安装过程 来安装完毕后,进入图10所示的安装配置工具的界面。俺认为,数据库实际上是在“Oracle Database Configuration Assistant”阶段创建的,参见图11的过程描述。所以此过程并不是提示所说的是可选的工具。俺有一次就是在这个阶段因为内存不足而停止了。结果根本无法创建数据库!图10安装配置工具 图11安装“Oracle Database Configuration Assistant”度过了这个阶段,就可以看到光明了!如图12。 图12安装完毕 来六测试安装完毕后,可以进行测试了:

18、以oracle用户登录,键入命令:sqlplus/nologSQLconnect / as sysdbaSQLstartup数据库启动的结果应当如下:ORACLE instance started.Total System Global Area320308312 bytesFixed Size 730200 bytesVariable Size 285212672 bytesDatabase Buffers 33554432 bytesRedo Buffers 811008 bytesDatabase mounted.Database opened.键入命令,启动监听程序:lsnrctl结果

19、应当如下:LSNRCTL for Solaris: Version 9.2.0.1.0 - Production on 04-SEP-2002 21:48:10Copyright (c) 1991, 2002, Oracle Corporation.All rights reserved.Welcome to LSNRCTL, type help for information.输入start,启动:LSNRCTL startStarting /u01/oracle/product/9.2.0/bin/tnslsnr: please wait.TNSLSNR for Solaris: Vers

20、ion 9.2.0.1.0 - ProductionSystem parameter file is /u01/oracle/product/9.2.0/network/admin/listener.oraLog messages written to /u01/oracle/product/9.2.0/network/log/listener.logListening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC)Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=mint

21、-practice)(PORT=1521)Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC)STATUS of the LISTENER-Alias LISTENERVersion TNSLSNR for Solaris: Version 9.2.0.1.0 - ProductionStart Date04-SEP-2002 21:50:48Uptime0 days 0 hr. 0 min. 0 secTrace Level offSecurityOFFSNMPOFFListener Parameter File /u

22、01/oracle/product/9.2.0/network/admin/listener.oraListener Log File /u01/oracle/product/9.2.0/network/log/listener.logListening Endpoints Summary.(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC)(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=mint-practice)(PORT=1521)Services Summary.Service PLSExtProc ha

23、s 1 instance(s).Instance PLSExtProc, status UNKNOWN, has 1 handler(s) for this service.Service orclsol has 1 instance(s).Instance orclsol, status UNKNOWN, has 1 handler(s) for this service.The command completed successfully启动Oracle Web Servercd $ORACLE_HOME/Apache/Apache/bin./startJServ.sh/u01/oracl

24、e/product/9.2.0/Apache/Apache/bin/apachectl start: httpd started启动Oracle Web Server后默认的端口号是7777在客户端浏览器地址栏输入http:/xxx.xx.xxx.xxx:7777/如果浏览器出现图13的界面,则表示Oracle Web Server运行正常。 图13Oracle Web Server 附录资料:不需要的可以自行删除 libxml2应用实例Libxml2 是一个xml的c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支

25、持c+、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。二、 Libxml2安装:一般如果在安装系统的时候选中了所有开发库和开发工具的话(Fedora Core系列下),应该不用安装,下面介绍一下手动安装: 1) 从xmlsoft站点或ftp(ftp.xmlsoft.org)站点下载libxml压缩包(libxml2-xxxx.tar.gz)2) 对压缩包进行解压缩 tar xvzf libxml2-xxxx.tar.gz3) 进入解压缩后的文件夹中运行 ./co

26、nfigure -prefix /home/user/myxml/xmlinst(此处为待安装的路径)或者直接使用 ./configure make make install 4) 添加路径 export PATH=/home/user/myxml/xmlinst/bin:$PATH 说明:为了结构清晰,最好将libxml2不安装在解压目录中。安装完成后就可以使用简单的代码解析XML文件,包括本地和远程的文件,但是在编码上有一些问题。Libxml默认只支持UTF8的编码,无论输入输出都是UTF-8,所以如果你解析完一个XML得到的结果都是UTF8的,如果需要输出GB2312或者其它编码,需要I

27、CONV来做转码(生成UTF8编码的文件也可以用它做),如果系统中没有安装iconv的话,需要安装libiconv。 1) 下载libiconv压缩包(例如libiconv-1.11.tar.gz) 2) 对压缩包进行解压缩tar xvzf libiconv-1.11.tar.gz 3) 进入解压缩后的文件夹中运行 ./configure make make install三、关于XML:在开始研究 Libxml2 库之前,先了解一下XML的相关基础。XML 是一种基于文本的格式,它可用来创建能够通过各种语言和平台访问的结构化数据。它包括一系列类似 HTML 的标记,并以树型结构来对这些标记进

28、行排列。例如,可参见清单 1 中介绍的简单文档。为了更清楚地显示 XML 的一般概念,下面是一个简化的XML文件。清单 1. 一个简单的 XML 文件 root delete 10清单 1 中的第一行是 XML 声明,它告诉负责处理 XML 的应用程序,即解析器,将要处理的 XML 的版本。大部分的文件使用版本 1.0 编写,但也有少量的版本 1.1 的文件。它还定义了所使用的编码。大部分文件使用 UTF-8,但是,XML 设计用来集成各种语言中的数据,包括那些不使用英语字母的语言。接下来出现的是元素。一个元素以开始标记 开始(如 ),并以结束标记 结束(如 ),其中使用斜线 (/) 来区别于

29、开始标记。元素是 Node 的一种类型。XML 文档对象模型 (DOM) 定义了几种不同的 Nodes 类型,包括:Elements(如 files 或者 age)Attributes(如 units)Text(如 root 或者 10)元素可以具有子节点。例如,age 元素有一个子元素,即文本节点 10。XML 解析器可以利用这种父子结构来遍历文档,甚至修改文档的结构或内容。LibXML2 是这样的解析器中的其中一种,并且文中的示例应用程序正是使用这种结构来实现该目的。对于各种不同的环境,有许多不同的解析器和库。LibXML2 是用于 UNIX 环境的解析器和库中最好的一种,并且经过扩展,它

30、提供了对几种脚本语言的支持,如 Perl 和 Python。四、Libxml2中的数据类型和函数一个函数库中可能有几百种数据类型以及几千个函数,但是记住大师的话,90%的功能都是由30%的内容提供的。对于libxml2,我认为搞懂以下的数据类型和函数就足够了。1)内部字符类型xmlCharxmlChar是Libxml2中的字符类型,库中所有字符、字符串都是基于这个数据类型。事实上它的定义是:xmlstring.htypedef unsigned char xmlChar;使用unsigned char作为内部字符格式是考虑到它能很好适应UTF-8编码,而UTF-8编码正是libxml2的内部编

31、码,其它格式的编码要转换为这个编码才能在libxml2中使用。还经常可以看到使用xmlChar*作为字符串类型,很多函数会返回一个动态分配内存的xmlChar*变量,使用这样的函数时记得要手动删除内存。2) xmlChar相关函数如同标准c中的char类型一样,xmlChar也有动态内存分配、字符串操作等相关函数。例如xmlMalloc是动态分配内存的函数;xmlFree是配套的释放内存函数;xmlStrcmp是字符串比较函数等等。基本上xmlChar字符串相关函数都在xmlstring.h中定义;而动态内存分配函数在xmlmemory.h中定义。3)xmlChar*与其它类型之间的转换另外要

32、注意,因为总是要在xmlChar*和char*之间进行类型转换,所以定义了一个宏BAD_CAST,其定义如下:xmlstring.h#define BAD_CAST (xmlChar *)原则上来说,unsigned char和char之间进行强制类型转换是没有问题的。4)文档类型xmlDoc、指针xmlDocPtrxmlDoc是一个struct,保存了一个xml的相关信息,例如文件名、文档类型、子节点等等;xmlDocPtr等于xmlDoc*,它搞成这个样子总让人以为是智能指针,其实不是,要手动删除的。xmlNewDoc函数创建一个新的文档指针。xmlParseFile函数以默认方式读入一个

33、UTF-8格式的文档,并返回文档指针。xmlReadFile函数读入一个带有某种编码的xml文档,并返回文档指针;细节见libxml2参考手册。xmlFreeDoc释放文档指针。特别注意,当你调用xmlFreeDoc时,该文档所有包含的节点内存都被释放,所以一般来说不需要手动调用xmlFreeNode或者xmlFreeNodeList来释放动态分配的节点内存,除非你把该节点从文档中移除了。一般来说,一个文档中所有节点都应该动态分配,然后加入文档,最后调用xmlFreeDoc一次释放所有节点申请的动态内存,这也是为什么我们很少看见xmlNodeFree的原因。xmlSaveFile将文档以默认方

34、式存入一个文件。xmlSaveFormatFileEnc可将文档以某种编码/格式存入一个文件中。5)节点类型xmlNode、指针xmlNodePtr节点应该是xml中最重要的元素了,xmlNode代表了xml文档中的一个节点,实现为一个struct,内容很丰富:tree.htypedef struct _xmlNode xmlNode;typedef xmlNode *xmlNodePtr;struct _xmlNode void *_private;/* application data */ xmlElementType type; /* type number, must be seco

35、nd ! */ const xmlChar *name; /* the name of the node, or the entity */ struct _xmlNode *children;/* parent-childs link */ struct _xmlNode *last; /* last child link */ struct _xmlNode *parent;/* child-parent link */ struct _xmlNode *next; /* next sibling link*/ struct _xmlNode *prev; /* previous sibl

36、ing link*/ struct _xmlDoc*doc;/* the containing document */ /* End of common part */ xmlNs *ns; /* pointer to the associated namespace */ xmlChar *content; /* the content */ struct _xmlAttr *properties;/* properties list */ xmlNs *nsDef; /* namespace definitions on this node */ void *psvi;/* for typ

37、e/PSVI informations */ unsigned short line; /* line number */ unsigned short extra;/* extra data for XPath/XSLT */;可以看到,节点之间是以链表和树两种方式同时组织起来的,next和prev指针可以组成链表,而parent和children可以组织为树。同时还有以下重要元素:l节点中的文字内容:content;l节点所属文档:doc;l节点名字:name;l节点的namespace:ns;l节点属性列表:properties;Xml文档的操作其根本原理就是在节点之间移动、查询节点的各

38、项信息,并进行增加、删除、修改的操作。xmlDocSetRootElement函数可以将一个节点设置为某个文档的根节点,这是将文档与节点连接起来的重要手段,当有了根结点以后,所有子节点就可以依次连接上根节点,从而组织成为一个xml树。6)节点集合类型xmlNodeSet、指针xmlNodeSetPtr节点集合代表一个由节点组成的变量,节点集合只作为Xpath的查询结果而出现(XPATH的介绍见后面),因此被定义在xpath.h中,其定义如下:/* A node-set (an unordered collection of nodes without duplicates).*/typedef

39、 struct _xmlNodeSet xmlNodeSet;typedef xmlNodeSet *xmlNodeSetPtr;struct _xmlNodeSet int nodeNr; /* number of nodes in the set */ int nodeMax; /* size of the array as allocated */ xmlNodePtr *nodeTab;/* array of nodes in no particular order */ /* with_ns to check wether namespace nodes should be look

40、ed at */;可以看出,节点集合有三个成员,分别是节点集合的节点数、最大可容纳的节点数,以及节点数组头指针。对节点集合中各个节点的访问方式很简单,如下:xmlNodeSetPtr nodeset = XPATH查询结果;for (int i = 0; i nodeNr; i+)nodeset-nodeTabi;注意,libxml2是一个c函数库,因此其函数和数据类型都使用c语言的方式来处理。如果是c+,我想我宁愿用STL中的vector来表示一个节点集合更好,而且没有内存泄漏或者溢出的担忧。五、使用Libxml2项目中要实现一个管理XML文件的后台程序,需要对XML文件进行创建,解析,修改

41、,查找等操作,下面介绍如何利用libxml2提供的库来实现上述功能。1、创建XML文档:我们使用xmlNewDoc()来创建XML文档,然后使用xmlNewNode(),xmlNewChild(),xmlNewProp(),xmlNewText()等函数向XML文件中添加节点及子节点,设置元素和属性,创建完毕后用xmlSaveFormatFileEnc()来保存XML文件到磁盘(该函数可以设置保存XML文件时的编码格式)。示例1: #include #include #include int main(int argc, char *argv) xmlDocPtr doc = NULL; /* document pointer */ xmlNodePtr root_node = NULL, node = NULL, node1 = NULL;/* node pointers */ / Creates a new document, a node and set it as a root node doc = xmlNewDoc(BAD_CAST 1.0); root_node = xmlNewNo

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 期刊短文 > 互联网

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁