LIULIANG

JAVA编译为EXE的几种方法(转)

将Java应用程序本地编译为EXE的几种方法(推荐使用JOVE和JET) 
  1. 从www.towerj.com获得一个TowerJ编译器,该编译器可以将你的CLASS文件编译成EXE文件。
 
  2. 利用微软的SDK-Java 4.0所提供的jexegen.exe创建EXE文件,这个软件可以从微软的网站免费下载,地址如下:http://www.microsoft.com/java/download/dl_sdk40.htm 
  jexegen的语法如下: 

jexegen /OUT:exe_file_name 
/MAIN:main_class_name main_class_file_name.class 
[and other classes]

 
  3. Visual Cafe提供了一个能够创建EXE文件的本地编译器。你需要安装该光盘上提供的EXE组件。
 
  4. 使用InstallAnywhere创建安装盘。 

  5. 使用IBM AlphaWorks提供的一个高性能Java编译器,该编译器可以从下面的地址获得: 
  http://www.alphaworks.ibm.com/tech/hpc
 
  6. JET是一个优秀的Java语言本地编译器。该编译器可以从这个网站获得一个测试版本: 
  http://www.excelsior-usa.com/jet.html
 
  7. Instantiations公司的JOVE
  http://www.instantiations.com/jove/...ejovesystem.htm 
  JOVE公司合并了以前的SuperCede,一个优秀的本地编译器,现在SuperCede已经不复存在了。
 
  8. JToEXE 
  Bravo Zulu Consulting, Inc开发的一款本地编译器,本来可以从该公司的网页上免费下载的,不过目前在该公司的主页上找不到了。

posted @ 2012-08-11 22:53 BIG森林 阅读(277) | 评论 (0)编辑 收藏

java打包-exe文件-最终以setup形式发布(转)

首先,将编译好的程序打包成jar文件,然后做出exe,这样代码就不可见了;但是exe文件在没有安装jre的电脑上不能运行,如果要求客户再去安装jre 设置环境变量 就不雅了。我们需要将jre打包。

这几步操作网上介绍的插件和方法很多,但有的好用有的不好用,而且有的还需要注册。经过尝试比较,在“千里冰封”的博客上得到了很大的帮助。整理一下。使用这几个工具,您也可以顺利的发布您的java程序!

1 打包成双击可执行的jar文件。
推荐插件:fatJar(Eclipse使用)
下载地址 http://sourceforge.net/project/showfiles.php?group_id=115990&package_id=125924

我用的是Eclipse,它自带的打包方法在打包一些图片等资源时不是很爽。可以使用这个插件。
安装方法解压后将plugins文件夹下的net.sf.fjep.fatjar_0.0.24文件夹拷到eclipse安装目录的plugins 下。
用此工具可以方便的将eclipse中的工程打包成jar文件。如果是要打成可执行的jar请注意选取主类。
你的项目=〉Export..=>向导里有fat jar =>...

 

2 将jar文件转换成exe文件。
推荐工具:exe4j

用exe4j把java打包成exe
http://www.blogjava.net/hadeslee/archive/2007/10/12/152228.html
在我们写程序的时候,有时会有一种需求,那就是希望我们的程序是一个可执行文件,而不是一个jar文件,其实大部份时候,可执行的jar文件都可以满足要求,但是如果我们的程序是需要保护的,那么打包成jar文件就不太安全了,因为jar文件就是一个解压缩文件,一解压就什么都能看到了,当然也可以选择混淆,但是混淆了以后排错就没那么容易了,因为混淆的时候,把一些类的信息都混淆了。如何既保证代码的安全又容易排错呢?那么打包成exe就是一种很好的办法了,其实我今天介绍这个方法并不是希望大家去打包成exe文件,因为exe文件毕竟不是跨平台的,用了exe的格式就失去了java的初衷了。

exe4j可以打包成各种格式的exe,可以把jar打包进exe,也可以引用一个外部的jar文件,还可以打包成windows服务的程序,并且可以设置最低jre的版本,还可以设定启动画面,虽然java6.0已经实现了这一点,但是还是没有exe4j生成的启动画面快。


3 将exe文件并jre打包成安装文件 可以在没有安装java虚拟机的电脑上运行
推荐工具:install4j

Install4j介绍
http://www.blogjava.net/hadeslee/archive/2007/10/15/152855.html
install4j是一个功能强大的,多平台Java安装文件生成工具,用于生成Java应用程序本地化的安装及应用程序发布。 install4j 的优异性在于它易于使用,紧密的集成到目标平台,以及灵活的JRE 管理与部署选项。

创建发布树
install4j的图形用户界面允许你:

    * 完全自定义发布树
      在发布树的每一个目录中,你能设置整个目录内容或是磁盘上任何目录的单个文件。定义的视图与结果视图让你能完全控制安装程序将发布的文件。
       
    * 处理特定平台的差异
      install4j提供方便的“包含/排除”机制,使其适应平台方式来进行发布。
       
    * 针对Unix, Linux 及Mac OS X所定义的文件权限
      对发布树的每一个元素,当其安装在类似于Unix这样的平台上时,你能自定义用户访问的权限。
       
    * 定义优良的卸载策略
      对发布树的每一个元素,你能决定在卸载时是否删除它。
       
    * 定义覆盖策略
      对发布树的每一个元素,你能配置不同的覆盖策略,当安装过程中需要覆盖文件时,这些覆盖策略会指示nstall4j进行相应的操作。
       
    * 定义安装的组件
      你能定义文件及目录的分组,形成分离的安装组件,这样你就可提供给用户来选择只安装一定的组件。

其实一个好的应用如果不太好布署,那么别人也只能对它望而兴叹了,现在有了install4j,很多布署的问题几乎全部解决了.我们可以用exe4j打包java应用,然后用install4j发布java应用,以前java程序布署难的问题,现在几乎都解决了.install4j不但用于打包很合适,并且它还提供了一组很强大很实用的与平台相关的api.这些对于扩展我们的程序也是有很大的帮助的.

转自:
http://hi.baidu.com/%C4%CF%BA%BD%CC%EC%CF%C2/blog/item/47a832fa296798d7b48f319b.html

posted @ 2012-08-11 22:51 BIG森林 阅读(335) | 评论 (0)编辑 收藏

在web.xml文件中配置信息,未起作用问题解决

转载至:http://jsf.javaeye.com/blog/141949

http://hi.baidu.com/piaochen/blog/item/ac6f1124936a8a21d4074291.html

 

MyFaces下web.xml配置error_page 500错误转发无效的解决方案(综合编译)
2009-09-22 10:54

网上目前的解决方案如下:

1, IE设定   工具-->Internet选项-->高级--->显示http友好错误信息(取消选择) , 这样就可以了
2, 设置指定错误页页状态为正常,来告诉IE这不是一个服务器错误, 从而不显示IE的自定义错误页
<%
    response.setStatus(200); // 200 = HttpServletResponse.SC_OK
%>
3, 把错误页做大一点,弄个几百K 就可以显示错误页面 (加一个div块,display设为none就可以了),这个问题比较奇怪.

 

对于3,说明下,应该是因为MS的程序员写IE的时候,如果自己设置了错误代码页面的跳转,IE会判断跳转页面的大小,如果小于其设置的值,则不会跳转到你定义的页面,而是跳转到IE默认的错误代码页面。

一下是一些错误代码和其对应的页面最小值:

错误码 ie需要的页面最小值(字节数)

400 512
403 256
404 512
405 256
406 512
408 512
409 512
410 256
500 512
501 512
505 512
可见,如果你定义的404错误页面大小<512 则ie会返回自己默认的404错误页面。

郁闷吧。

如果想加大页面的大小,可以像3说的那样写一个div display=none 也可以写一段话,然后注释掉,关键是注释的问题,不能采用<%-- --%>注释,只能用<-- -->注释,否则一样没用。

在MyFaces环境下一一实验后,发现无效。还是无法转发。实验N次后,
http://wiki.apache.org/myfaces/Handling_Server_Errors中发现了解决方案。原来MyFaces自己有一套处理Error的机制。我们要跳转到自己的页面,得把MyFaces的Error处理机制给停掉。这样才能使Web.xml的500错误的配置起作用。
方案如下:
在web.xml文件中加入:
<!-- if you want to disable the behaviour completely -->
<context-param>
    <param-name>org.apache.myfaces.ERROR_HANDLING</param-name>
    <param-value>false</param-value>
</context-param>
<!-- if you are using myfaces + facelets don't forget to do this -->
<context-param>
    <param-name>facelets.DEVELOPMENT</param-name>
    <param-value>false</param-value>
</context-param>

<!-- if you want to use a different resource template file than
       "META-INF/rsc/myfaces-dev-error.xml" this param let you configure
       it. (since 1.2.4-SNAPSHOT and 1.1.6-SNAPSHOT)-->
<context-param>
    <param-name>org.apache.myfaces.ERROR_TEMPLATE_RESOURCE</param-name>
    <param-value>META-INF/rsc/custom-dev-error.xml</param-value>
</context-param>

<!-- if you want to choose a different class for handling the exception - the error-handler needs to include a method handleException(FacesContext fc, Exception ex)-->
<context-param>
    <param-name>org.apache.myfaces.ERROR_HANDLER</param-name>
    <param-value>my.project.ErrorHandler</param-value>
</context-param>
这样再设置
<error-page>
<error-code>500</error-code>
<location>/500error.jsp</location>
</error-page>
就可以了。
这样配置完了以后,在FireFox下是可以转发的,但是在IE下就不行了。修改IE的配置肯定不可行,将500error.jsp增大到几百k,性能上说不过去。那只能采取在500error.jsp中加入
<%
    response.setStatus(200); // 200 = HttpServletResponse.SC_OK
%>
的方案。
试验后,发现可行。
(本文引用了http://javeye.javaeye.com/blog/441513http://jsf.javaeye.com/blog/141949的资料。)

posted @ 2012-08-10 20:53 BIG森林 阅读(444) | 评论 (0)编辑 收藏

在jdk中Xalan解析器引用

Xalan处理器是Apache XML工程下的一个子工程,它实现了W3C XSLT1.0 XPath1.0规范,是一个开放源代码的XSLT处理器,Xalan提供了javaC++版本。

Xalan既可以作为一个XSLT工具以命令行的方式使用,也可以作为一个模块在其他应用程序中使用,我们可以在http://www.fayea.com/apache-mirror/xml/xalan-j/上下载最新版本的Xalan处理器,下载解压后的目录中有一个xalan.jar,该xalan.jar就是Xalan解析器,也是实现XSLTXPath规范的类库,如果我们想使用Xalan解析器的话,
需要应用xalan.jar和serializer.jar这两个
jar包,如果只用用xalan.jar,就会报出:

D:\XML\test>java org.apache.xalan.xslt.Process -PARAM oddline-color #FFOOOO

-IN em.xml -XSL em.xsl -OUT em.out

 

(错误位置未知)XSLT 错误 (java.lang.NoClassDefFoundError): org/apache/xml/seriali

zer/ExtendedContentHandler

Exception in thread "main" java.lang.RuntimeException: org/apache/xml/serializer

/ExtendedContentHandler

        at org.apache.xalan.xslt.Process.doExit(Process.java:1155)

        at org.apache.xalan.xslt.Process.main(Process.java:1128)

 

D:\XML\test>

  

posted @ 2012-08-04 22:54 BIG森林 阅读(851) | 评论 (0)编辑 收藏

Jdk在引用组件的方法

Jdk在引用组件时,可以有两种方法

方法一:

将组件的jar包放到classpath环境变量中就行了,但是这里的classpath是用户变量中的,不是系统变量中的,你可以在命令行中使用set classpath来查看环境变量classpath的值(同样我们也可以使用这种方法测试我们设置的环境变量是否已经生效)。

 

 

注意:我们可以使用DOS窗口中用set classpath查看我们设置的CLASSPATH环境变量的值是否已经生效了。

 

方法二:

我们可以直接将组件的jar包放到jdk安装路径下的jre\jre\lib\ext下面,这种方法准行。

posted @ 2012-08-03 17:15 BIG森林 阅读(230) | 评论 (0)编辑 收藏

jdk1.6 环境变量设置

JAVA_HOME指明JDK安装路径,就是刚才安装时所选择的路径(假设安装在D:\jdk1.4),此路径下包括lib,bin,jre等文件夹(此变量最好设置,因为以后运行tomcat,Eclipse等都需要依靠此变量)。

Path使得系统可以在任何路径下识别java命令,设为:%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin

CLASSPATH为java加载类(class or lib)路径,只有类在classpath中,java命令才能识别,设为:.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar (要加.表示当前路径)

特别注意:

◆环境变量值的结尾没有任何符号,不同值之间用;隔开(unix中用:)。

◆CLASSPATH变量值中的.表示当前目录。

四、JDK1.6安装的最后检验

呵呵,基本上就大功告成了,如果不放心,可以检验下。在命令行窗口下,键入java -version命令可以查看到安装的JDK版本信息;键入java命令,可以看到此命令的帮助信息;键入javac命令可以看到此命令的帮助信息。如果都如愿看到,呵呵,检验完毕!

posted @ 2012-08-03 16:17 BIG森林 阅读(179) | 评论 (0)编辑 收藏

java中引入Xerces解析器

   在jdk1.4版本或更高的版本中已经包含了xml的解析器,但是这些解析器的功可能不是太完美,所以我们可以主动去指定xml解析器(覆盖默认的解析器或指定新的解析器),在网上找了一些资料,但是好像都不行,不是道是什么原因,但是别人又好像弄成功了,所以我认为这些资料还是有帮助的,这里给出这些资料,以备以后使用:     
                  [java语言]XML api折射出sun与IBM的恩仇
引自:http://www.w3china.org/blog/more.asp?name=hongrui&id=23698

最初的xml解析器是sun的Crimson和IBM的Xerces,这两个开源项目都捐给了apache组织,后来Xerces发展很快,Crimon基本没有人使用。
1.4 版本起,用于 XML 处理的 Java API 就已经加入了Java 2 平台中。 利用该 API,可通过一系列标准的 Java 平台 API 来处理 XML 文档。
 因此,也就无需另外添加 XML 处理包了。sun的JDK1.4使用Crimson,IBM的JDK使用Xerces。
如果打算把sun 的jdk程序移植到IBM的JDK下,注意解析器不同,XML处理会出问题。这就说明了java不是“一次编译,到处运行”,而是“一次编译,到处调试”。
如果你把IBM的JDK移植到SUN的JDK下,即使把Xerces包引入CLASSPATH,JDK还是使用Crimson,不信你运行java -verbose试一试。
解决的办法就是在在JRE\lib\目录下,建立一个jaxp.properties的文件,
内容如下:
    javax.xml.parsers.DocumentBuilderFactory=org.apache.xerces.jaxp.DocumentBuilderFactoryImpl
    javax.xml.parsers.SAXParserFactory=org.apache.xerces.jaxp.SAXParserFactoryImpl
就可以使用Xerces。
或者使用命令行
# Add the XML parser jars and set the JAXP factory names
# Crimson parser JAXP setup(default)
CLASSPATH=$CLASSPATH:../lib/crimson.jar
JAXP=-Djavax.xml.parsers.DocumentBuilderFactory=org.apache.crimson.jaxp.DocumentBuilderFactoryImpl
JAXP="$JAXP -Djavax.xml.parsers.SAXParserFactory=org.apache.crimson.jaxp.SAXParserFactoryImpl"

# Add the XML parser jars and set the JAXP factory names
# Xerces parser JAXP setup
CLASSPATH=$CLASSPATH:../lib/xerces.jar
JAXP=-Djavax.xml.parsers.DocumentBuilderFactory=org.apache.xerces.jaxp.DocumentBuilderFactoryImpl
JAXP="$JAXP -Djavax.xml.parsers.SAXParserFactory=org.apache.xerces.jaxp.SAXParserFactoryImpl"
最终sun还是指定JAXP规范,JSR 206 Java API for XML Processing(JAXP) 1.3,他已经由JDK1.5实现。
JAXP实现了XPath,但是xalan的org.apache.xpath.XPathAPI 类已经移植到了 JRE 1.5 中,重构为com.sun.org.apache.xpath.internal.XPathAPI。 
如果在以前的JDK中,使用含 XPathAPI 类的 jar,例如 xalan-2.4.1.jar。 将该 jar 加入到 CLASSPATH(类路径)。

W3C的DOM标准API非常难用,于是有人开发 Java专用的XML API,这就是jdom=java+DOM。其中一部分人,去开发dom4j,这个不是非常标准,但是速度很快。
使用JDOM隐含服务器风险,因为JBoss和Webphere都是基于JDOM开发的,在这两个服务器下使用JDOM,必须进行相应的设置,而且你的JDOM版本必须与服务器使用的相近,
因为JVM只加载一份相同的类,服务器优先加载自己使用的JDOM,你开发用的JDOM不会被加载,你的应用就会出错。
使用Dom4J隐含工程问题,主要是hibernate,如果你开发的项目和hibernate合并,Dom4J版本不兼容的话,寻找dom4j相同版本hibernate,或者你改程序适应hibernate的Dom4j。
java没有windows的DLL地狱,但是java的jar地狱有过而无不及啊。

  
                                                     下面给出我自己测试出的结果
这里给出我自己在书中看到的资料:
    在jdk1.4版本之后支持API的替换机制,我们就可以使用这种机制来替换默认的XML解析器(并不是所有的API都可以替换,只有那些被认可的标准API可以替换),我们就用这种机制来是实现我们的目的。为了替换JDK中提供的XML解析器,需要在JRE\lib目录下创建一个endorsed子目录,然后直接将解析器的实现类的jar包复制到该目录下即可,对于Xerces解析器,我们需要将xercesImpl.jar文件复制到该目录下即可。或者,你可以通过系统属性java.endorsed.dirs来指定另外的路径,假设这两个jar包位于D:\xerces-2_11_0目录下,在执行程序时,可采用如下命令:
java -D java.endorsed.dirs=D:\xerces-2_11_0  DOMTest
(DOMTest为要运行的应用程序的文件名)



posted @ 2012-08-02 21:24 BIG森林 阅读(1707) | 评论 (0)编辑 收藏

Oracle 服务名与实例名

数据库名、实例名、数据库域名、全局数据库名、服务名 ,
这是几个令很多初学者容易混淆的概念。相信很多初学者都与我一样被标题上这些个概念搞得一头雾水。我们现在就来把它们弄个明白。

一、数据库名
什么是数据库名?

数据库名就是一个数据库的标识,就像人的身份证号一样。他用参数DB_NAME表示,如果一台机器上装了多全数据库,那么每一个数据库都有一个数据库名。在数据库安装或创建完成之后,参数DB_NAME被写入参数文件之中。格式如下:
DB_NAME=myorcl
...
在创建数据库时就应考虑好数据库名,并且在创建完数据库之后,数据库名不宜修改,即使要修改也会很麻烦。因为,数据库名还被写入控制文件中,控制文件是以 二进制型式存储的,用户无法修改控制文件的内容。假设用户修改了参数文件中的数据库名,即修改DB_NAME的值。但是在Oracle启动时,由于参数文 件中的DB_NAME与控制文件中的数据库名不一致,导致数据库启动失败,将返回ORA-01103错误。

数据库名的作用
数据库名是在安装数据库、创建新的数据库、创建数据库控制文件、修改数据结构、备份与恢复数据库时都需要使用到的。
有很多Oracle安装文件目录是与数据库名相关的,如:
winnt: d:/oracle/product/10.1.0/oradata/DB_NAME/...
Unix: /home/app/oracle/product/10.1.0/oradata/DB_NAME/...
pfile:
winnt: d:/oracle/product/10.1.0/admin/DB_NAME/pfile/ini.ora
Unix: /home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/init$ORACLE_SID.ora
跟踪文件目录:
winnt: /home/app/oracle/product/10.1.0/admin/DB_NAME/bdump/...
另外,在创建数据时,careate database命令中的数据库名也要与参数文件中DB_NAME参数的值一致,否则将产生错误。
同样,修改数据库结构的语句alter database, 当然也要指出要修改的数据库的名称。
如果控制文件损坏或丢失,数据库将不能加载,这时要重新创建控制文件,方法是以nomount方式启动实例,然后以create controlfile命令创建控制文件,当然这个命令中也是指指DB_NAME。
还有在备份或恢复数据库时,都需要用到数据库名。
总之,数据库名很重要,要准确理解它的作用。

查询当前数据名
方法一:select name from v$database;
方法二:show parameter db
方法三:查看参数文件。

修改数据库名
前面建议:应在创建数据库时就确定好数据库名,数据库名不应作修改,因为修改数据库名是一件比较复杂的事情。那么现在就来说明一下,如何在已创建数据之后,修改数据库名。步骤如下:
1.关闭数据库。
2.修改数据库参数文件中的DB_NAME参数的值为新的数据库名。
3.以NOMOUNT方式启动实例,修建控制文件(有关创建控制文件的命令语法,请参考oracle文档)

二、数据库实例名
什么是数据库实例名?
数据库实例名是用于和操作系统进行联系的标识,就是说数据库和操作系统之间的交互用的是数据库实例名。实例名也被写入参数文件中,该参数为instance_name,在winnt平台中,实例名同时也被写入注册表。
数据库名和实例名可以相同也可以不同。
在一般情况下,数据库名和实例名是一对一的关系,但如果在oracle并行服务器架构(即oracle实时应用集群)中,数据库名和实例名是一对多的关系。这一点在第一篇中已有图例说明。

查询当前数据库实例名
方法一:select instance_name from v$instance;
方法二:show parameter instance
方法三:在参数文件中查询。

数据库实例名与ORACLE_SID
虽然两者都表是oracle实例,但两者是有区别的。instance_name是oracle数据库参数。而ORACLE_SID是操作系统的环境变 量。 ORACLD_SID用于与操作系统交互,也就是说,从操作系统的角度访问实例名,必须通过ORACLE_SID。在winnt不台, ORACLE_SID还需存在于注册表中。
且ORACLE_SID必须与instance_name的值一致,否则,你将会收到一个错误,在unix平台,是“ORACLE not available”,在winnt平台,是“TNS:协议适配器错误”。

数据库实例名与网络连接
数据库实例名除了与操作系统交互外,还用于网络连接的oracle服务器标识。当你配置oracle主机连接串的时候,就需要指定实例名。当然8i以后版本的网络组件要求使用的是服务名SERVICE_NAME。这个概念接下来说明 。

三、数据库域名
什么是数据库域名?

在分布工数据库系统中,不同版本的数据库服务器之间,不论运行的操作系统是unix或是windows,各服务器之间都可以通过数据库链路进行远程复制,数据库域名主要用于oracle分布式环境中的复制。举例说明如:
全国交通运政系统的分布式数据库,其中:
福建节点: fj.jtyz
福建厦门节点: xm.fj.jtyz
江西: jx.jtyz
江西上饶:sr.jx.jtyz
这就是数据库域名。
数据库域名在存在于参数文件中,他的参数是db_domain.

查询数据库域名
方法一:select value from v$parameter where name = 'db_domain';
方法二:show parameter domain
方法三:在参数文件中查询。

全局数据库名
全局数据库名=数据库名+数据库域名,如前述福建节点的全局数据库名是:oradb.fj.jtyz

四、数据库服务名
什么是数据库服务名?
从oracle9i版本开始,引入了一个新的参数,即数据库服务名。参数名是SERVICE_NAME。
如果数据库有域名,则数据库服务名就是全局数据库名;否则,数据库服务名与数据库名相同。

查询数据库服务名
方法一:select value from v$parameter where name = 'service_name';
方法二:show parameter service_name
方法三:在参数文件中查询。

数据库服务名与网络连接
从oracle8i开如的oracle网络组件,数据库与客户端的连接主机串使用数据库服务名。之前用的是ORACLE_SID,即数据库实例名

创建Oracle数据库(以Oracle10g为例)

有两种创建数据库的方式,一种是以命令行脚本方式,即手动方式创建;另一种是利用Oracle提供的数据库配置向导来创建。本篇主要介绍在Unix和Windows下以命令行脚本方式创建Oracle数据库。

        一个完整的数据库系统,应包括一个物理结构、一个逻辑结构、一个内存结构和一个进程结构,如果要创建一个新的数据库,则这些结构都必须完整的建立起来。

一、在Unix下创建数据库
1.确定数据库名、数据库实例名和服务名
关于数据库名、数据库实例名和服务名,我之前有专门用一篇来详细介绍。这里就不再说明了。

2.创建参数文件
     参数文件很确定了数据库的总体结构。Oracle10g有两种参数文件,一个是文本参数文件,一种是服务器参数文件。在创建数据库时先创建文本参数文件, 在数据库创建后,可以由文件参数文件创建服务器参数文件。文本参数文件的取名方式为initORACLE_SID.ora,其中,ORACLE_SID是 数据库实例名。其名称及路径为:
/home/app/oracle/product/10.1.0/admin/DB_NAME/pfile/initORACLE_SID.ora
其中,DB_NAME为数据库名。所以,应创建一个以之命名的目录,并将文本参数文件存放在上述目录中。假设新创建的数据库名为MYORACLE,SID与数据库名一致。则上述目录实际为:
/home/app/oracle/product/10.1.0/admin/MYORACLE/pfile/initMYORACLE.ora
1)参数文件的介绍
参数文件决定着数据库的总体结构,用于设置数据库的近260个系统参数。下面分类别说明一下各参数的作用,关于参数的详细使用说明请参考Oracle官方参考文档。
a.数据库标识类参数
DB_NAME: 数据库名,此参数在创建数据前决定,数据库创建后修改时,必须建控制文件
DB_DOMAIN: 数据库域名,用于区别同名数据库。数据库名与域名一起构成了全局数据库名
INSTANCE_NAME: 数据库实例名,可以与数据库相同
SERVICE_NAMES: 数据库服务名,与全局数据库名相同如果没有域名,则服务名就是数据库名
b.日志管理类参数
LOG_ARCHIVE_START: 是否启动自动归档进程ARCH
LOG_ARCHIVE_DEST: 归档日志文件存储目录
LOG_ARCHIVE_FORMAT: 归档日志文件的默认文件存储格式
LOG_ARCHIVE_DUPLEX_DEST: 归档日志文件镜像存储目录(Oracle8以上)
LOG_ARCHIVE_DEST_n: 归档日志文件存储目录(Oracle8i以上)
LOG_ARCHIVE_DEST_STATE_n: 设置参数LOG_ARCHIVE_DEST_n失效或生效
LOG_ARCHIVE_MAX_PROCESSES: 设置自动归档进程的个数
LOG_ARCHIVE_MIN_SUCCEED_DEST: 设置最少的成功归档日志存储目录的个数
LOG_CHECKPOINT_INTERVAL: 根据日志数量设置检验点频率
LOG_CHECKPOINT_TIMEOUT: 根据时间间隔设置检验点频率
c.内存管理参数
DB_BLOCK_SIZE: 标准数据块大小
DB_nK_CACHE_SIZE: 非标准数据块数据缓冲区大小
SHARED_POOL_SIZE: 共享池大小控制参数,单位为字节
DB_CACHE_SIZE: 标准数据块数据缓冲区大小
DB_BLOCK_BUFFERS: 数据缓冲区大小,9i之后已放弃使用
LOG_BUFFER: 日志缓冲区大小
SORT_AREA_SIZE: 排序区大小
LARGE_POOL_SIZE: 大池大小
JAVA_POOL_SIZE: Java池大小
d.最大许可用户数量限制参数
LICENSE_MAX_SESSIONS:数据库可以连接的最大会话数
LICENSE_MAX_USERS:数据库支持的最大用户数
LICENSE_MAX_WARNING:数据库最大警告会数(会话数据达到这个值时,产生新会话时就会产生警告信息)
e.系统跟踪信息管理参数
USER_DUMP_DEST:用户跟踪文件生成的设置
BACKGROUND_DUMP_DEST:后台进程跟踪文件生成的位置
MAX_DUMPFILE_SIZE:跟踪文件的最大尺寸
f.系统性能优化与动态统计参数
SQL_TRACE:设置SQL跟踪
TIMED_STATICS:设置动态统计
AUDIT_TRAIL:启动数据库审计功能
g.其他系统参数
CONTROL_FILES:控制文件名及路径
Undo_MANAGMENT:Undo空间管理方式
ROLLBACK_SEGMENTS:为这个例程分配的回退段名
OPEN_CURSORS:一个用户一次可以打开的游标的最大值
PROCESSES:最大进程数,包括后台进程与服务器进程
IFILE:另一个参数文件的名字
DB_RECOVERY_FILE_DEST:自动数据库备份目录
DB_RECOVERY_FILE_SIZE:数据库备份文件大小
2)参数文件样式
db_name=myoracle
instance_name=myoracle
db_domain=fangys.xiya.com
service_names=myoracle.fangys.xiya.com
control_files=(/home/app/oracle/product/10.1.0/oradata/myoracle/control01.ctl,
                  /home/app/oracle/product/10.1.0/oradata/myoracle/control02.ctl,
                  /home/app/oracle/product/10.1.0/oradata/myoracle/control03.ctl)
db_block_size=8192
user_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/udump
background_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/bdump
core_dump_dest=/home/app/oracle/product/10.1.0/admin/myoracle/cdump
db_recovery_file_dest=/home/app/oracle/product/10.1.0/flash_recover_area
db_recovery_file_size=100G
...


3.设置操作系统参数
$ORACLE_SID=myoracle
$export ORACLE_SID

4.启动实例并创建数据库
在创建数据库之前,首先要以新的数据库参数启动数据库实例,因为这时数据库的控制文件还没有产生,不能MOUNT或OPEN数据库。启动实例时,Oracle只按照内存参数分配SGA区,启动系统后台进程。
$sqlplus "sys/pass as sysdba"

sql>startup nomount
如果参数文件不在规定的目录中,可以在启动实例时指定参数文件:
sql>startup pfile=/export/home/user/initmyoracle.init nomount
在实例启动后就可以使用CREATE DATABASE命令创建数据。其详细语法请参考Oracle官方SQL参考文档。这里以实例来介绍:
sql>CREATE DATABASE myoracle
       MAXINSTANCE 1
       MAXLOGHISTORY 216
       MAXLOGFILES 50
       MAXLOGMEMBERS 5
DATAFILE '/home1/app/oracle/product/10.1.0/oradata/myoracle/system01.dbf' SIZE 500m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
LOGFILE
       GROUP 1('/home1/app/oracle/product/10.1.0/oradata/myoracle/log1a.log',
               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log1b.log') SIZE 10m,
       GROUP 2('/home1/app/oracle/product/10.1.0/oradata/myoracle/log2a.log',
               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log2b.log') SIZE 10m,
       GROUP 3('/home1/app/oracle/product/10.1.0/oradata/myoracle/log3a.log',
               '/home1/app/oracle/product/10.1.0/oradata/myoracle/log3b.log') SIZE 10m,
Undo TABLESPACE undotbs DATAFILE
'/home1/app/oracle/product/10.1.0/oradata/myoracle/undotbs01.dbf' size 200m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
DEFAULT TEMPORARY TALESPACE temp TEMPFILE
'/home1/app/oracle/product/10.1.0/oradata/myoracle/temp01.dbf' size 325m
AUTOEXTEND ON NEXT 100m MAXSIZE UNLIMITED
DEFAULT TABLESPACE users DATAFILE
'/home1/app/oracle/product/10.1.0/oradata/myoracle/usertbs01.dbf' size 1000m
CHARACTER SET ZHS16GBK;
这里说明一下CREATE DATABASE语句的各个关键字的含义:
DATAFILE:SYSTEM表空间的数据文件定义
LOGFILE:日志文件组的定义
Undo_TABLESPACE:重做表空间的定义
DEFAULT TEMPORTY TABLESPACE:默认临时表空间的定义
DEFAULT TABLESPACE:默认数据表空间的定义。


5.创建数据字典
在数据库创建结束后,数据库自动处于OPEN状态下,这时所有V$××××类数据字典都可以查询。而其它数据字典,如DBA_DATA_FILES、DBA_TABLESPACES等都不存在,必须通过下列骤为系统创建数据字典。
1)加载常用的数据字典包
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/catalog
2)加载PL/SQL程序包
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catproc
3)加载数据复制支持软件
sql>@/home/app/oracle/product/10.1.0/db_1/rdbms/admin/catrep
4)加载Java程序包
sql>@/home/app/oracle/product/10.1.0/db_1/javavm/install/initjvm
5)加载系统环境文件
sql>connect system/pass
sql>@/home/app/oracle/product/10.1.0/db_1/sqlplus/admin/pupbld

二、在Windows下创建数据库
Oracle实例在Windows下表现为操作系统服务。在windows下,使用命令行方式创建数据的方法有所不同,差别在于在Windows下,需要先创建数据库服务和实例。

1.确定数据库名、数据库实例名和服务名并创建目录(DBCA创建的脚本不包含建立目录命令,须自己创建)
建立目录命令(下面以 db_name=eygle为例):

mkdir D:/oracle/ora90/cfgtoollogs/dbca/eygle
mkdir D:/oracle/ora90/database
mkdir d:/oracle/admin/eygle/adump
mkdir d:/oracle/admin/eygle/bdump
mkdir d:/oracle/admin/eygle/cdump
mkdir d:/oracle/admin/eygle/dpdump
mkdir d:/oracle/admin/eygle/pfile
mkdir d:/oracle/admin/eygle/udump
mkdir d:/oracle/flash_recovery_area
mkdir d:/oracle/oradata
mkdir d:/oracle/oradata/eygle

2.创建参数文件
在Windows下的参数文件名称及路径如下:
d:/oracle/product/10.1.0/admin/DB_NAME/pfile/init.ora(oracle10g)
d:/orant/database/iniORACLE_SID.ora(oracle7,oracle8)
参数据文件内容与前述一致。这里不再说明。

3.选择数据库实例
设置环境变量ORACLE_SID
c:/>set ORACLE_SID=数据库实例名

4.创建数据库实例
在Windows中创建数据库实例的命令为Oradim.exe,是一个可执行文件,可以在操作系统符号下直接运行。直接输入oradim显示此命令的帮助。
c:/>Oradim
下面对Oradim命令的参数进行一个说明
-------------------------------
-NEW 表示新建一个实例
-EDIT 表示修改一个实例
-DELETE 表示删除一个实例
-SID sid     指定要启动的实例名称
-SRVC service 指定要启动的服务名称
-INTPWD password 以Internal方式连接数据库时的口令字
-MAXUSERS count 该实例可以连接的最大用户数
-USRPWD password 指定内部用户的口令,如是作为Windows管理登录,不用此参数
-PFILE pfile     该实例所使用的参数文件名及路径
-STARTTYPE srvc|inst|srvc,inst 启动选项(srvc:只启动服务,inst:启动实例,服务必须先启动,srvc,inst:服务和实例同时启动)
-SHUTTYPE srvc|linst|srvc,inst 关闭选项(srvc:只关闭服务,实例必须已关闭,inst:只关闭实例,srvc,inst:服务和实例同时关闭)
-STARTMODE a|m 创建实例所使用的模式(a:自动,即windows启动时自动启动 m:手动)
-SHUTMODE a|i|m 关闭实例时所使用的模式(a:abort异常方式,i:immediate立即方式,n:normal正常方式)
----------------------------
例:创建一个数据库实例
c:/>oradim -NEW -SID myoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"

c:/>oradim -NEW -SRVC OracleServicemyoracle -STARTMODE m -PFILE "d:/fangys/initmyoracle.ora"
例:修改一个数据实例
c:/>oradim -EDIT -SID myoracle -STARTMODE a

c:/>oradim -EDIT -SRVC OracleServicemyoracle -STARTMODE a
例:删除一个实例
c:/>oradim -DELETE -SID myoracle

c:/>oradim -DELETE -SRVC Oracleservicemyoracle
例:启动服务与实例
c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvc,inst
只启动服务
c:/>oradim -STARTUP -SID myoracle -STARTTYPE srvc
启动实例:
c:/>oradim -STARTUP -SID myoracle -STARTTYPE inst
例:关闭服务与实例
c:/>oradim -SHUTDOWN -SID myoracle  
c:/>oradim -SHUTDOWN -SID myoracle -SHUTTYPE srvc,inst

5.启动实例并创建数据库
c:/>oradim -NEW -SID myoracle -INTPWD syspass -STARTMODE a -PFILE d:/fangys/initmyoracle.ora
c:/>set ORACLE_SID=myoracle
c:/>sqlplus sys/syspass as sysdba
sql>startup -pfile=d:/fangys/initmyoracle.ora nomount
sql>CREATE DATABASE myoracle
logfile group...
...

6.创建数据字典
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catalog.sql;
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catproc.sql;
sql>@d:/oracle/product/10.1.0/db_1/rdbms/admin/catrep.sql;
sql>@d:/oracle/product/10.1.0/db_1/javavm/install/initjvm.sql;
sql>@d:/oracle/product/10.1.0/db_1/sqlplus/admin/ppbld.sql;

 

一、启动数据
$sqlplus "sys/pass as sysdba"
sql>startup

二、启动监听器
  数据库启动后,如果未启动监听进程,则客户端无法与数据库连接。监听进程的启动方法为:
$lsnrctl start
在widnows中,可以从服务列表中启动监听器。
监听里程配置文件为listener.ora,位于目录/home/app/oracle/product/10.1.0/db1/network/admin/。
此配置文件分为两部分,一部分为监听程序本身的配置,包括协议,地址,端口号等;另一部分为监听程序所连接的数据库的实例信息,包括:实例名,全局数据库名,oracle主目录等。监听器可以利用oracle net config 向导来配置。
要显示监听器的运行状态:$lsnrctl status;
要停止监听器:$lsnrctl stop。

三、数据库的启动过程
分为三个阶段:
1. 启动实例,包括以下操作:
1) 读取参数文件
2) 分配SGA
3) 启动后台进程
2.装载数据库
装载数据库是将数据库与已启动的实例相联系。数据库装载后,数据库保持关闭状态。
3.打开数据库
此步骤使用数据库可以进行正常的操作的处理。主要是打开控制文件,数据库文件和日志文件。

四、数据库启动参数
1.NOMOUNT:只启动实例,不装载数据库
sql>startup nomount
2.MOUNT:启动实例,并装载数据,但不打开数据库
sql>startup mount
3.READ ONLY:将数据库置为只读
sql>startup mount
sql>alter database open read only
4.READ WRITE:以可读写方式打开数据,这是默认方式
sql>startup mount
sql>alter database open read write
5.OPEN:打开数据库,这是默认方式
sql>startup mount
sql>alter database open;
6.RESTRICT:以受限方式打开,只有具有RESTRICTED SESSION权限的用户才可以连接数据库
sql>startup restrict
7.PFILE:启时指定参数文件
sql>startup pfile=/u02/user/mypfile.ora
8.FORCE:以强制方式启动数据库
sql>startup pfile=/u02/user/mypfile.ora open restrict force

五、数据库的关闭
  与启动过程相对应,关闭包括三个过程
1).关闭数据库
2).卸载数据库
3).关闭数据库实例

1.NORMAL关闭方式
NORMAL关闭方式是正常关闭方式,是默认关闭方式。在这种关机方式下,数据库服务器必须等待所有客户端从Oracle中正常退出时,才可以关闭数据库。
SQL>SHUTDOWN NORMAL
2.IMMEDIATE关闭方式
使用这种方式关闭数据库时,系统将连接到数据库的所有用户尚未提交的事务全部回退,中断连接,然后关闭数据库。
SQL>SHUTDOWN IMMEDIATE
3.ABORT关闭方式
ABORT关闭方式为异常方式,使用这种方式关闭数据库时,系统立即将数据库实例关闭,对事务膛数据完整性不作检查。是最快的关机方式。
sql>shutdown abort;
4.TRANSACTIONAL关闭方式
在这种关机方式中,数据库必须等待所有的客户运行的事务结束,提交或回退。
sql>shutdown transactional

 Oracle数据库的连接结构有三种:
1) 组合用户与服务器结构:在这种连接方式中,客户端与服务器同处一台机器中,对于每一个用户,其库应用程序与服务器程序组合成单个服务器进程。
2) 专用服务器(Dedicated Server)结构:在这种方式中,对于每一个用户,其数据库应用是由用户进程所运行,并有一个专用服务器进程为之服务,执行Oracle服务器代码
3) 多线程服务器(Multithreaded Server)体系结构:在这种方式中,一个或多个客户应用程序共享一组服务器进程,与专用服务器不同的是,客户和服务器进程不是一对一的关系,而是由调度进程对多个服务器进程进行调度,以服务来自客户应用的连接请求。

专用服务器

专用服务器的工作过程:
1) 客户端通过oracle net向监听器发连接请求
2) 监听器收到请求并将此请求导向服务器,服务器向用户返回一个连接成功信息,并为此用户创建一个专用服务器进程
3) 客户直接与该专用服务器进程进行交互,处理SQL,并且服务器在该会话的PGA中建立一个专用SQL区。
如果客户端要求建立专用服务器连接方式,可以修改客户羰的网络配置文件tnsnames.ora或修改连接描述串。增加关键字“Server=DEDICATED”,如:
prod=
       (DESCRIPTION=
         (ADDRESSLIST=
           (ADDRESS=
             (PROTOCOL=TCP)(HOST=192.168.0.3)(PORT=1521)
             (SERVER=DEDICATED)
           )
         )
         (CONNECT_DATA=(SID=PROD)
        )
       )
还必须修改SQLNET.ORA文件,增加“USE_DEDICATED_SERVER=TRUE”

多线程服务器体系结构

专用服务器结构中,一个服务器进程只为一个客户服务。这样的话,如果有一千个客户,就需要有一千个对应的服务器进程,就会耗费大量的系统资源。为了支 持对于可伸缩性的需求,在oracle7中引入了多线程服务器(MTS,也称为共享服务器)。下面说明共享服务器建立连接的过程,以级与建立专用服务器连 接过程的不同:
1) 客户通过网络与监听器联系
2) 监听器检测到请求,基于Oracle net结构来确定是否与多线程服务器连接。监听器将客户请求导向相应的调度程序。
3) 监听器通过使客户与调度程序了解对方的网络地址,从面完成了双方的介绍。
4) 一旦客户与调度程序知道如何找到对方,它们就直接通信,不要需要监听器。客户直接将操作请求发送给高度程序。
5) 调度程序将客户请求放在SGA的请求队列中。
6) 下一个可用的共享服务器进程从请求队列中读取请求,进行相应的工作。
7) 共享服务器进程将结果存放在提交相应请求的调度程序的响应队列中。
8) 调度程序从响应队列中读取数据并将结果送组客户。


  有几个概念在这里作个补充说明:
1) 监听器(Listener):为一个或多个实例“监听”连接请求,它是oracle客户与服务器的中介。监听器不是Oracle实例的一部分,它的作用是将连接的请求导向相应的实例。
2) 调度程序(dispatcher):在MTS体系结构中,监听器与调度程序联系,调度程序负责调度MTS中的各个共享服务器进程。


 多线程服务器的设置参数有:
MTS_SERVICE:多线程服务器名称,一般为数据库名
MTS_DISPATCHERS:初始调度器个数
MTS_MAX_DISPATCHERS:调度器最大个数
MTS_SERVERS:共享服务器个数
MTS_MAX_SERVERS:最大共享服务器个数
多线程服务器的设置是通过对以上各个参数的设置完成的。格式如下:
MTS_SERVICE=RS
MTS_SERVERS=10
MTS_MAX_SERVERS=100
MTS_DISPATCHERS="(PROTOCOL=TCP)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPX)(POOL=YES)(MULT=YES)"
MTS_DISPATCHERS="(PROTOCOL=IPC)(POOL=YES)(MULT=YES)"
MTS_MAX_DISPATCHERS=100


有关多线程服务器的数据字典如下:
V$MTS
V$DISPATCHER
V$SHARED_SERVER
V$CIRCULT
各字典的详细说明请参考Oracle文档。

第八篇 再述oracle数据库体系结构 之四:Oracle实例的进程结构

  这里所讲的里程是指Unix系统中的进程,在Windows中,Oracle是一个操作系统服务。
Oracle实例由内存区域和后台进程组成。
Oracle实例分为单进程实例(一个进程执行全部的Oracle代码,只允许单个用户存取)和多进程实例(由多个进程执行Oracle代码的不同部分,对于每一个连接的用户都有一个进程,允许多个用户同时使用)。
在多进程结构中,除服务器进程(请注意,此“服务器进程”不是指所有的实例中的进程,见下面的说明)外,还有其他后台进程,包括:Dnnn, DBWR, LGWR,ARCH,PMON,SMON,CKPT,RECO等。在数据库启动后,这些进程常驻操作系统。Oracle中所有进程的数量之和不能超过参数 PROCESS设定的值:
sql>show parameter process
     当Oracle客户端应用程序与Oracle实例连接的时候,Oracle会产生一个服务器进程来为这些客户服务,此进程在widnows下表现为线程。 此进程的主要作用有:对于用户发出的SQL语句进行语法分析,编译,执行用户的SQL语句,如是数据块不在数据缓冲区时,则从磁盘数据文件将数据读入到 SGA的共享数据缓冲区中,将SQL语句的执行结果返回组应用程序。下面的语句用来查询数据库中的用户会话信息。
sql>select substr(s.sid,1,3) sid,substr(s.serial#,1,5) ser,spid,substr(schemaname,1,10) schema,substr(type,1,3) typ,substr(decode((consistent_gets+block_gets),0,'None',(100*(consistent_gets+block_gets-physical_reads)/consistent_gets+block_gets))),1,4) "%hit",value cpu,substr(block_changes,1,5) bchng from v$process p,v$sesstat t,v$sess_io i,v$session s where i.sid=s.sid and p.addr=paddr(+) and s.sid=t.sid and t.statistic#=12;
结果中:
sid 表示会话ID号,
ser 表示会话serial#号,serial#与sid组合以唯一表示一个会话,
spid 表示操作系统进程号,
schema 表示数据库用户名,
typ 表示进程类型,use为用户进程,bac为后台进程
%hit 表示数据缓冲区命中率,
cpu 表示使用cpu的时间,
bchng 表示修改了的数据块的个数。

下面介绍各个后台进程。
1. DBWR进程
DBWR(Database Writer)进程将缓冲区中的数据写入数据文件,负责数据缓冲区的管理。
当数据缓冲区中的一个数据被修改后,被标记为“脏”,DBWR进程负责将“脏”数据写入磁盘。
DBWR采用LRU算法来替换数据缓冲区中的数据。
DBWR的作用包括:
1) 管理数据缓冲区,以便服务器进程总能找到空闲缓冲区
2) 将所有修改后的缓冲区中的数据写入数据库文件
3) 使用LRU算法将最近使用过的块保留在内存中
4) 通过延迟写来优化磁盘i/o.
在下列情况下DBWR要将脏数据写入磁盘数据文件:
1) 当一个服务器进程将缓冲数据块移“脏表”,面该脏表达到一定程度进。(该临界长度由参数DB_BLOCK_WRITE_BATCH决定)
2) 当一个服务器进程在LRU表中查找DB_BLOCK_MAX_SCAN_CNT缓冲区时,没有查到空闲的缓冲区
3) 出现超时
4) 检查点发生时
在一个Oracle实例中,允许启动多个DBWR进程,DBWR进程个数由参数DB_WRITE_PROCESSES指定,上限为20,进程名依次自动命名为:DBW0,DBW1,DBW2...DBW19。
sql>show parameter processes

2. LGWR进程
LGWR(Log Writer)进程将日志数据从日志缓冲区中写入磁盘日志文件中。
关于LGWR进程的工作时机可以看我写的第一篇《一次事务过程》。
LGWR的写盘条件是:
1) 发生提交,即commit;
2) 日志缓冲区达到总数的1/3时;
3) 超时;
4) DBWR进程需要为检验点清除缓冲区时。
每一个Oracle实例只有一个LGWR进程。
LGWR将日志信息同步的写入到日志文件组的多个日志成员中,如果组中的一个成员文件被删除或不可使用,LGWR将日志信息继续写到该组的其他文件中,不影响数据库的运行。

3. SMON进程
SMON(System Monitor),系统监控进程,在实例启动时执行实例恢复,并负责清理不再使用的临时段。

4. PMON进程
PMON(Process Monitor),进程监控里程,在服务器进程出现故障时执行进程恢复,负责清理内存内存和释放该进程所使用的资源。

5. ARCH进程
ARCH(Archive Process,归档进程)在日志存满时将日志信息写到磁盘或磁带,用于介质失败时的恢复。
日志信息首先产生于日志缓冲区,再由日志写入进程LGWR将日志数据写入日志文件组,日志切换时,由归档进程ARCH将日志数据从日志文件组中写入归档日志中。
在一个数据库实例中,归档进程最多可以启动10个,进程名依次自动命名为ARC0,ARC1,ARC2...ARC9,设置方法是:在参数文件中增加 参数LOG_ARCHIVE_MAX_PROCESSES。关于如何启用数据库的自动归档,在前面的《物理结构》一篇中已有说明,这里说明一个几个相关的 参数:
1) LOG_ARCHIVE_DEST:用于设置归档日志的文件存储目录
2) LOG_ARCHIVE_DUBLEX_DEST:用于设置归档日志文件的镜像存储目录,此参数在oracle 8及以上的版本中支持
3) LOG_ARCHIVE_DEST_n:用于设置更多的镜像目录,其中,1<=n<=10,该参数有以下三个选项:
(1)MANDATORY:表示必须完成此目录的归档,才可以切换。
(2)REOPEN:归档目录或介质失败后,需等多长时间能重新写入日志,默认时间为300秒。
(3)OPTIONAL:不管是否归档完成都进行切换,这是默认方式
举例如下:
LOG_ARCHIVE_DEST_1='LOCATION=/u01/oracle/archive/
                       MANDATORY
                       REOPEN=500'
LOG_ARCHIVE_DEST_2='LOCATION=/u02/oracle/archive/
                       OPTIONAL'
LOG_ARCHIVE_DEST_n只适用于oracle 8i及以上的版本。
4) LOG_ARCHIVE_DEST_STATE_n:用于对归档日志目录进行失效或生效,该参数与LOG_ARCHIVE_DEST_n一一相对应。如:
LOG_ARCHIVE_DEST_STATE_1=DEFER
LOG_ARCHIVE_DEST_STATE_2=ENABLE
此参数可以在线设置:
sql> ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1=DEFER;
此参数只适用于oracle 10g及以上版本。

6. CKPT进程
CKPT(CheckPoint,检查点)进程出现时,系统对全部数据库文件及控制文件的文件头的同步号进行修改,以保证数据库的同步。
以下两个参数是对CKPT有影响的:
LOG_CHECKPOINT_TIMEOUT:决定产生一个检验点的时间间隔,单位为秋,默认为1800;
LOG_CHECKPOINT_INTERVAL:执行一个检验点需要填充的日志文件块的数目,默认为0,表示不起作用。
系统对于数据库的改变信息用系统改变号SCN表示,SCN也叫检验点号,在日志中用CHECKPOINT_CHANGE#表示,它是数据文件,日志文件,控制文件的同步的同步依据,同时存储在这三个中,在系统改变时,检验点号也会同时改变。
引起CKPT产生的主要时机有:
1)日志切换时
2)达到LOG_CHECKPOINT_TIMEOUT指定的间隔时间
3)达到LOG_CHECKPOINT_INTERVAL指定的日志块数
4)数据库关闭
5)DBA强制产生
6)表空间OFFLINE时

7. RECO进程
RECO(Recover,恢复)进程用于分布式数据库系统,RECO进程自动地解决在分布式数据库中的事务故障。

8. LCKn进程
LCKn(锁进程)用于Oracle并行服务器环境下,用于多个实例间的封锁,该进程最多可以启动10个。

9. Dnnn进程
Dnnn(Despatcher,调度)进程。用于多线程服务器体系结构中。详见下一篇《Oracle连接配置结构》

10. SNP进程
SNP是作业进程,主要用于分布式数据库中,进行数据库之间快照的自动刷新,并同时通达DBMS_JOB程序包自动运行预定的存储过程,SQL,PL/sql程序等。有两个参数用来控制作业进程的计划:
1) JOB_QUEUE_PROCESS:用于设置作业进程个数
2) JOB_QUEUE_INTERVAL:用于设置作业进程被周期性唤醒的时间间隔

后台进程跟踪信息
所有修改数据库结构的命令会自动被后台进程跟踪记录,跟踪信息由oracle后台进程自动存储,跟踪文件的名称为alter_SID。此文件的存储目录由参数BACKGROUND)DUMP_DEST指定。
可以用工具命令TKPROF来格式化跟踪文件,如:
$tkprof oralogfile1.log
除了跟踪后台进程外,还可以启用参数SQL_TRACE对用户的语句进行跟踪。修改参数文件:
TIMED_STATISTICS=TRUE
USER_DUMP_DEST=目录名
MAX_DUMP_FILE_SIZE=5M
SQL_TRACE=TRUE
或者:
SQL>ALTER SESSION SET SQL_TRACE=TRUE对当前会话进行SQL跟踪。

锁等待问题与KILL SESSION
为了保证数据的一致性,系统提供锁机制。有关锁的概念可以参数《数据库系统概论》一书。要了解当前在等待锁资源的用户:
sql>select a.username,a.sid,a,serial#,b.id1 from v$session,v$lock where a.lockwait=b.kaddr;
要了解锁住其它用户的用户进程:
SQL>SELECT A.USERNAME,A.SID,A,SERIAL#,B.ID1 FROM V$SESSION A,V$LOCK B WHERE B.ID1 IN (SELECT DISTINCT E.ID1 FROM V$SESSION D,V$LOCK E WHERE D.LOCKWAIT=E.KADDR) AND A.SID=B.SID AND B.REQUEST=0;

posted @ 2012-08-02 11:13 BIG森林 阅读(269) | 评论 (0)编辑 收藏

Oracle中Instance实例和数据库的区别

 

在实际的开发应用中,关于Oracle数据库,经常听见有人说建立一个数据库,建立一个Instance,启动一个Instance之类的话。 其实问他们什么是数据库,什么是Instance,很可能他们给的答案就是数据库就是Instance,Instance就是数据库啊,没有什么区别。在这里,只能说虽然他们Oracle用了可能有了一定的经验,不过基础的概念还是不太清楚。

什么是数据库,其实很简单,数据库就是存储数据的一种媒介。比如常用的文件就是一种,在Oracle10G中,数据的存储有好几种。第一种是文件形式,也就是在你的磁盘中创建一批文件,然后在这些文件中存储信息。第二种就是磁盘阵列形式,这个是什么意思呢,这个就是说明数据库不是存放为某个文件,而是把一个或者多个磁盘格式化成Oracle的一种格式了,等于整个磁盘就是存放Oracle数据库的,不能作为别的用途。这样的优点是存储性能高,因为不再借助别的文件格式了,而是把整个磁盘都成为Oracle最适应的文件系统格式。当然还可能有别的形式,比如网络什么的。不过我们最常用的还是文件格式的,在文件格式中,数据库指的就是那些数据文件,控制文件以及REDO文件等等一系列文件。

而什么是Instance呢,Instance其实就是指的操作系统中一系列的进程以及为这些进程所分配的内存块。在Oracle中,我们可以新建一个Oracle的Instance,这个时候虽然有了进程还有SGA等一系列的内存快,但是这个时候并没有把数据库文件读取进来。所以只是一个实例,在后来,你可以通过命令手动或者自动地把数据库文件加载进我们的数据库Instance中,这个时候的数据库才可以让我们真正的开始访问操作。

所以说,数据库的应用如果想实现,数据库和数据库Instance是缺一不可的,如果只有数据库的那些文件,那么,只能代表数据在这个文件中,但是我们无法直接进行操作。而如果只有数据库Instance,那么我们虽然可以急性操作,但是也不知道操作哪些数据,操作生成的数据也无法保存等等。所以,当一个Oracle Instance真正Load了一个Oracle Database了以后,数据库才可以被我们使用。

在这里要注意一点的是,Oracle的实例在启动以后,只能load一次数据库,如果想把数据库与Instance断开,然后再重新挂在一个数据库Instance,那么就需要你首先把数据库Instance进程结束,然后重新建立这个instance的一个进程,再load另外一个数据库。否则肯定要抛除ORA-16169错误,说数据库已经被打开。因为一个数据库Instance在其生存期中最多只能load和打开一个instance。(T004)



转自:http://database.ccidnet.com/art/1105/20070130/1013427_1.html

posted @ 2012-08-02 11:12 BIG森林 阅读(279) | 评论 (0)编辑 收藏

ubuntu11.10 搭建nfs

ubuntu11.10 搭建nfs
    1.下载相关软件
    2.建立共享目录
    3.修改该配置文件
    4.重启服务
    5.测试服务器
    6.测试客户端
    7。卸载nfs

    测试系统:Ubuntu11.10

    1.下载相关软件
    使用如下命令,可以在ubuntu下很方便的获取并安装相关软件(经过试验,还是都安装的好)
    #sudo apt-get install protmap nfs-kernel-server nfs-common
    如果是要客户端和服务器端分开,可以使用如下命令
     服务器端:
    #sudo apt-get install portmap nfs-kernel-server
     客户机端:
    #sudo apt-get install portmap nfs-common

    2.建立共享目录  (这一步我当时配置时没有用到)
        #sudo mkdir /nfsboot
       #sudo chmod 777 /nfsboot

    3.修改该配置文件
    刚安装完配置文件只有一些说明,其路径是:/etc/exports
        #gedit /etc/exports
     在文档末尾加:
        /nfsboot   *(rw,async,no_subtree_check,no_root_squash)
    说明:
    /nfsboot是要共享的目录
    *代表允许所有的网络段访问(也可一制定特定网段,如192.168.11.*)
    rw是可读写权限
    sync是资料同步写入内存和硬盘
    no_root_squash是NFS客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限

    最后重新扫描配置文件,使用户修改/etc/exports配置文件不必重启NFS服务(这一不好像也没有用到)
    #sudo exportfs -ra
    4.重启服务
    使用如下命令重启一下服务
    #sudo /etc/init.d/portmap restart
    #sudo /etc/init.d/nfs-kernel-server restart

    5.测试服务器
    查看服务目录和权限
    #showmount -e
    我得到的结果是:
    Export list for ubuntu:
    /nfsboot *

    6.测试客户端
    在/nfsboot里新建文件,主要是作测使用
    #touch /nfsboot/testfile
    在其他分区挂载nfs文件系统,记得该目录要先存在才行
    #sudo mount -t nfs 127.0.0.1:/nfsboot /mnt(注意:nfsboot与/mnt之间有空格,当时试验了n次都不对就是因为这一个问题)
    查看一下:(其中代表本主机)
    #ls /mnt
    testfile
    如何关闭还未试验成功


    7.卸载nfs
    sudo umount /mnt/12
     说明:/mnt/12  表示:本地挂在的路径



参考:
http://blog.sina.com.cn/s/blog_6cc8508101011dq9.html
http://blog.csdn.net/youhaipeng/article/details/6940901

posted @ 2012-07-13 16:49 BIG森林 阅读(321) | 评论 (0)编辑 收藏

仅列出标题
共9页: 1 2 3 4 5 6 7 8 9 
<2012年10月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

导航

统计

常用链接

留言簿(2)

随笔分类

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜