发布新日志

  • SoapUI接口测试指南(原创)

    2010-11-12 23:10:32Top 1 Digest 1

    最近通过继续学习使用SOAPUI,整理出了一套完整的使用SOAPUI进行自动化接口测试方法,适合各种分布式系统和SOA系统的接口测试,下载的同学可以提提意见,欢迎大家多多交流,让我可以不断地完善它。
    声明:转载须注明出处和作者oolong。

    详见附件

    其实很早就出到第二版了,不过第二版和公司比较有关系,所以没传上来
  • jmeter性能测试指南(原创)

    2013-05-08 14:43:24

    又给大家带福利了,jmeter第一版,写了一阵子,一直没时间放上来
    声明:转载须注明出处和作者oolong。
  • [论坛] soapui使用手册(原创)

    2010-02-02 10:15:01

    在测试ws服务时,使用了SoapUI这个工具,根据使用过程,写了个简单的附图的使用说明,内容包括: SoapUI的使用过程:1、创建/导入工程                               2、创建测试用例                               3、创建负载测试 最后与LoadRunner的Webservice协议录制的脚本进行性能测试对比。 由于内容比较多,因此做成PDF形式,供大家下载。 里面某些地方用语可能比较口语化,方便理解,还请大家多多指教。
  • 在XP home上安装rational rose

    2010-01-09 14:18:08

    我在笔记本上安装Rational Rose 2003时,系统提示:操作系统不支持安装。我笔记本用的是Windows XP home版操作系统。我去Rational官方网站上查找发现Rational Rose 2003 不支持XP home版操作系统。经过一番研究,给出了如下解决方案:
    安装时让Rational Rose 2003不对操作系统版本进行检测。
    步骤如下:
    1、去
    http://www.newhua.com/cfan/200510/orca.rar下载Microsoft Orca,Orca数据库编辑器是 Windows Installer SDK 中提供的表编辑工具,可以用于编辑 .msi 文件。(也可以去http://www.microsoft.com/downloads/details.aspx?FamilyId=A55B6B43-E24F-4EA3-A93E-40C0EC4F68E5&displaylang=en下载)
    2、双击\bin 文件夹中的 Orca.msi 文件,安装 Orca 编辑器。
    3、用Orca打开Rational Enterprise 2003.06.13\DISK1\SETUP\wsbuEnterprise.msi,查找"xph",会定位到该行:
    (VersionNT AND (NOT RSWINXPHOME))OR (DISABLE_PLATFORM_BLOCKS = 1)|You are attempting to install on an...
    4、用Table/drop row删除该行,保存该文件,退出
    5、安装Rational Rose 2003,成功!
    mandwuyee转载
  • 使用LoadRunner8.1的java Vuser协议调用jar文件(转载)

    2009-11-11 10:46:53

    今天我需要用loadrunner测试一个远程的java服务应用,在测试过程中controller加载脚本时总是报错:ClassLoader error,后来问题解决。
     
    我首先把这个java服务应用的客户端jar包拷贝到loadrunner脚本的目录下,这些jar包是定义服务接口的。然后编写脚本代码、调试。到此为止一切正常。然后我使用controller把这个脚本run起来,这时开始报错,错误信息主要是:GENERIC_FAILURE和ClassLoader error。
     
    为什么在Vuser Gen里面调试正常,在controller里运行却不正常,经过分析发现是ClassLoader的问题,很可能是,在controller的运行进程中,线程的ContextClassLoader没有被正确赋值,因此我们增加以下一句代码:
     
    Thread.currentThread().setContextClassLoader(ClassLoader.getSystemClassLoader());
     
    然后再run脚本,问题解决。如果大家使用loadrunner遇到类似问题,试试这个方法。
  • 使用py2exe生成可执行文件(转载)

    2009-09-27 11:04:46

    要使用py2exe,首先要编写一个编译脚本,然后通过Python运行编译脚本即可将其他的脚本编译成可执行文件。以下实例是将要编译成可执行文件的脚本。

        

    #file: MessageBox.py
    import win32api
    import win32con
    win32api.MessageBox(0, 'hi!', 'Python', win32con.MB_OK)

    以下实例是编译脚本。

        

    #file: setup.py
    import distutils
    import py2exe
    distutils.core.setup(windows=['MessageBox.py'])

    在Windows的cmd窗口中输入“setup.py  py2exe”,将得到如下输出:

        

    running py2exe
    *** searching for required modules ***
    *** parsing results ***
    creating python loader for extension 'win32api'
    creating python loader for extension 'unicodedata'
    creating python loader for extension 'bz2'
    *** finding dlls needed ***
    *** create binaries ***
    *** byte compile python files ***
    ************************************************************
    部分输出省略
    ************************************************************
    byte-compiling E:\book\code\py2exe\build\bdist.
    win32\winexe\temp\unicodedata.py
    to unicodedata.pyc
    byte-compiling E:\book\code\py2exe\build\bdist.
    win32\winexe\temp\win32api.py to
    win32api.pyc
    *** copy extensions ***
    *** copy dlls ***
    copying D:\Python25\lib\site-packages\py2exe\run_w.exe ->
    E:\book\code\py2exe\di
    st\MessageBox.exe

    *** binary dependencies ***
    Your executable(s) also depend on these dlls which are
    not included,
    you may or may not need to distribute them.

    Make sure you have the license if you distribute
    any of them, and
    make sure you don't distribute files belonging to the
    operating system.

    OLEAUT32.dll - C:\WINDOWS\system32\OLEAUT32.dll
    USER32.dll - C:\WINDOWS\system32\USER32.dll
    SHELL32.dll - C:\WINDOWS\system32\SHELL32.dll
    ole32.dll - C:\WINDOWS\system32\ole32.dll
    ADVAPI32.dll - C:\WINDOWS\system32\ADVAPI32.dll
    VERSION.dll - C:\WINDOWS\system32\VERSION.dll
    KERNEL32.dll - C:\WINDOWS\system32\KERNEL32.dll

    运行完编译脚本以后会在当前文件夹下生成dist和build两个目录。其中dist目录中就是编译生成的文件。如果要在其他未安装Python的 机器上运行编译好的程序,只要将dist目录复制到其他机器上即可。双击运行MessageBox.exe,如图10-4所示。

    在setup.py中除了导入必需的模块以外,只有一条语句。

    distutils.core.setup(windows=['MessageBox.py'])

    方括号中就是要编译的脚本名,前边的windows表示将其编译成GUI程序。如果要编译命令行界面的可执行文件,只要将windows改为 console。重新编译MessageBox.py后,双击运行,如图10-5所示。可以看到运行程序后多了一个命令行窗口。另外,如果需要将脚本编译 成Windows服务,则可以使用service选项。

  • mysqldumpslow使用

    2009-09-17 16:54:27

    在安装好的MYSQL配置文件中加入以下二行参数,配置文件位置在MYSQL目录下,与bin文件同级,文件名为my.ini:
    log-slow-queries=D:\Test\slowquery.log
    long_query_time=3
    表示超过3秒的操作就会被当作为慢查询而写入日志,可以根据实际情况进行修改。
    然后重启MYSQL,接下来会在D盘下生成一个名为Test slowquery.log的日志文件,可能因为操作系统的原因吧,这个工具一般是用在LINUX下的,没有在Test的文件夹下产生这个日志文件。
    windows下安装的MYSQL没有带mysqldumpslow,所以无法在windows下分析生成的log文件。
    但可以把产生的日志文件放到LINUX下的MYSQL进行分析,可在命令行下用如下命令(进入到mysql/bin目录下,把windows下产生的日志文件Test slowquery.log重命名为slowquery.log,放至mysql/bin目录下):
    mysqldumpslow slowquery.log
    则可以看到分析的内容。
  • QTP使用小记

    2009-09-17 09:26:21

    可以通过安装visual studio.net 2008来增强QTP调试能力,也可以不安装,仅仅把其中一个名为PDM.DLL的文件拷贝到“C:\Program Files\Common Files\Microsoft Shared\VS7DEBUG”目录中,然后注册一下即可,注册方法是在命令行中输入“RegSVR32 "C:\Program Files\Common Files\Microsoft Shared\VS7DEBUG\PDM.DLL"”。
  • 一款开源的监控MYSQL性能的工具—INNOTOP(转载)

    2009-08-19 11:28:50

    INNOTOP是一个通过文本模式显示MySQL和InnoDB的监测工具。它有很多特点,快速的配置的,易于使用等。它吸取了MYTOP的精华这使它变得更加强大。INNOTOP是用PERL语言写成的,这是它能更加灵活的使用在各种操作平台之上,它能详细的的监控出当前MYSQL和INNODB运行的状态,以便维护人员根据结果合理的优化MYSQL,让MYSQL更稳定更高效的运行。

    安装INNOTOP工具非常的简单,既然是由PERL写的,当然需要PERL环境和相关的工具包。

    在安装之前先要确定你的系统安装了Time::HiRes,Term::ReadKey,DBI,DBD::mysql这四个包。安装可以把包下载下来通过编译安装完成也可以用PERL模块安装方式来完成。

    安装Time::HiRes,Term::ReadKey,DBI,DBD::mysql库文件

    通过PERL模块来安装

    [root@web1477 local]# perl -MCPAN -eshell

    CPAN> install Time::HiRes

    CPAN> install Term::ReadKey

    CPAN> install DBI

    CPAN> install DBD::mysql

    通过编译来安装

    [root@web1477 tmp]# tar zxvf Time-HiRes-01.20.tar

    [root@web1477 tmp]# cd Time-HiRes-01.20

    [root@web1477 Time-HiRes-01.20]# perl Makefile.PL

    [root@web1477 Time-HiRes-01.20]# make

    [root@web1477 Time-HiRes-01.20]# make install

    其他三个库文件也如法炮制。环境安装好了就可以开始安装INNOTOP软件了。

    [root@web1477 local]# tar zxvf innotop-1.6.0.tar.gz

    [root@web1477 local]# ln -s innotop-1.6.0/ innotop

    [root@web1477 local]# cd innotop

    [root@web1477 innotop]# perl Makefile.PL

    Checking if your kit is complete…

    Looks good

    Writing Makefile for innotop

    [root@web1477 innotop]# make

    cp InnoDBParser.pm blib/lib/InnoDBParser.pm

    cp innotop blib/script/innotop

    /usr/bin/perl “-MExtUtils::MY” -e “MY->fixin(shift)” blib/script/innotop

    Manifying blib/man1/innotop.1

    Manifying blib/man3/InnoDBParser.3

    [root@web1477 innotop]# make install

    Installing /usr/lib/perl5/5.8.8/html/site/lib/InnoDBParser.html

    Installing /usr/lib/perl5/5.8.8/html/bin/innotop.html

    Installing /usr/lib/perl5/5.8.8/site/lib/InnoDBParser.pm

    Installing /usr/lib/perl5/5.8.8/site/man/man1/innotop.1

    Installing /usr/lib/perl5/5.8.8/site/man/man3/InnoDBParser.3

    Installing /usr/lib/perl5/5.8.8/site/bin/innotop

    Appending installation info to /usr/lib/perl5/5.8.8/lib/perllocal.pod

    [root@web1477 innotop]#

    安装完成了,下面就是要开始设置它

    [root@web1477 innotop]# ./innotp

    You have not defined any database connections.

    Choose a name for the connection.  It cannot contain whitespace, colons or semicolons.

    Enter a name: localhost

    Typical DSN strings look like

       DBI:mysql:;host=hostname;port=port

    The db and port are optional and can usually be omitted.

    If you specify ‘mysql_read_default_group=mysql’ many options can be read

    from your mysql options files (~/.my.cnf, /etc/my.cnf).

    Enter a DSN string: DBI:mysql:;mysql_read_default_group=mysql;host=localhost

      Optional: enter a table (must not exist) to use when resetting InnoDB deadlock information: test.innotop_dl 

      Do you want to specify a username for localhost?: y

      Do you want to specify a password for localhost?: y

      Enter username for localhost: root

    Enter password for ‘root’ on localhost:

    Save password in plain text in the config file?: y

    完成这些INNOTOP就可以开始工作了。

    # ./innotop

    uery List (? for help)                                                         localhost, 23+12:35:18, 0.30 QPS, 22 thd, 5.0.45-log

     

    CXN        When   Load  QPS     Slow    QCacheHit  KCacheHit  BpsIn   BpsOut

    localhost  Now    0.73    0.30   0          0.00%    100.00%    9.47    1.41k

    localhost  Total  0.00  329.49  11.50k     67.13%     99.86%  486.35  774.07

     

    CXN     Cmd    ID      User   Host           DB      Time   Query

    INNOTOP查看各种监控状态的命令

    Switch to a different mode:

       B  InnoDB Buffers    I  InnoDB I/O Info     Q  Query List

       C  Command Summary   L  Locks               R  InnoDB Row Ops

       D  InnoDB Deadlocks  M  Replication Status  S  Variables & Status

       F  InnoDB FK Err     O  Open Tables         T  InnoDB Txns

    Actions:

       d  Change refresh interval            p  Pause innotop

       i  Toggle incremental status display  q  Quit innotop

       n  Switch to the next connection     

    Other:

     TAB  Switch to the next server group   /  Quickly filter what you see

       !  Show license and warranty         =  Toggle aggregation

       #  Select/create server groups       @  Select/create server connections

       $  Edit configuration settings       \  Clear quick-filters

    Press any key to continue

    如何获得INNOTOP软件呢?

    你可以到http://innotop.sourceforge.net/去下载,因为GW屏蔽了国外某些站点,但是可以通过其他的代理连接上去下载。另外你可以通过

    wget http://nchc.dl.sourceforge.net/sourceforge/innotop/innotop-1.6.0.tar.gz直接下载该软件。

  • Oracle 10g遇到的问题及查找的解决方法

    2009-07-03 14:34:59

    问题一:*****连接Oracle 10g时ORA-12514: TNS: 监听进程不能解析在连接描述符中给出的 SERVICE_NAME 错误的解决

    解决方法:
    1. 打开<OracleHome>/network/admin/listener.ora文件,找到:

    SID_LIST_LISTENER =
    (SID_LIST =
    (SID_DESC =
    (SID_NAME = PLSExtProc)
    (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
    (PROGRAM = extproc)
    )
    )
    2. 添加:
    (SID_DESC =
    (GLOBAL_DBNAME = ORACLE)
    (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
    (SID_NAME = ORACLE)
    )
    3. 最后变成:
    SID_LIST_LISTENER =
    (SID_LIST =
    (SID_DESC =
    (SID_NAME = PLSExtProc)
    (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
    (PROGRAM = extproc)
    )
    (SID_DESC =
    (GLOBAL_DBNAME = ORACLE)
    (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
    (SID_NAME = ORACLE)
    )------------因为数据库上创建了多个实例,为了使监听能够访问到每个实例,所以此处要进行添加。
    )
    4. 保存文件,重启服务中的TNSListener,OK!

    参考文档:http://www.blogjava.net/usherlight/archive/2007/02/12/99566.html

    问题二:ORA-01078 与 LRM-00109 could not open parameter file initxxx.ora
    错误信息:

      SQL> startup

    -------------initrawdb.ora该文件找不到,所以无法启动。
      ORA-01078: failure in processing system parameters

      LRM-00109: could not open parameter file '/opt/oracle/products/10.1.0.3/db_1/dbs/initrawdb.ora'

      解决办法:
    -------------直接把$ORACLE_BASE/admin/$ORACLE_SID/pfile/init.ora复制到上面启动时需要读取的配置文件的文件夹下。
      cp $ORACLE_BASE/admin/$ORACLE_SID/pfile/init.ora /opt/oracle/products/10.1.0.3/db_1/dbs/initrawdb.ora

      >sqlplus /nolog

      SQL*Plus: Release 10.1.0.3.0 - Production on Thu Jun 8 13:16:00 2006

      Copyright (c) 1982, 2004, Oracle. All rights reserved.

      SQL> conn / as sysdba

      Connected to an idle instance.

      SQL> startup

      ORACLE instance started.

      Total System Global Area 167772160 bytes

      Fixed Size 778212 bytes

      Variable Size 57679900 bytes

      Database Buffers 109051904 bytes

      Redo Buffers 262144 bytes

      Database mounted.

      Database opened.

      SQL>

      问题解决!
    参考文档:http://www.cnscn.org/htm_data/585/0812/19230.html

    三、创建pfile
    SQL> create pfile='/oracle/product/dbs/pfileora10g.ora' from spfile='/oracle/product/dbs/spfileora10g.ora';
    SQL> startup pfile='/oracle/product/dbs/pfileora10g.ora';
    ORACLE instance started.

    Total System Global Area 603979776 bytes
    Fixed Size 1268872 bytes
    Variable Size 163578744 bytes
    Database Buffers 432013312 bytes
    Redo Buffers 7118848 bytes
    Database mounted.
    Database opened.
  • LOB的存储过程

    2009-07-02 10:48:34

       读书笔记喽~~
       LOB分为内部LOB和外部LOB,内部LOB包括CLOB,BLOB,NCLOB三种类型,它们的数据被存储在数据库中,并且支持事务操作(提交、回退、保存点);外部LOB只有BFILE一种类型,被存储在操作系统文件中,且不支持事务操作。CLOB/NCLOB用于存储大批量字符数据,BLOB用于存储大批量二进制数据,BFILE存储着指向OS文件的指针。
    编写PL/SQL应用程序时,可以使用临时LOB,临时LOB相当于局部变量,与数据库表无关,并且只能由当前应用程序建立和使用。注意:当在SQL语句中使用临时LOB时,它们只能作为输入宿主变量使用,可在WHERE子句,VALUES子句和SET 子句中使用临时LOB,而不能在INTO子句中使用临时LOB。
     
    append:该过程用于将源LOB变量的内容添加到目标LOB变量的尾部。只适用于内部LOB类型(BLOB/CLOB),不适用于BFILE类型。
    declare
       dest_lob clob;
       src_lob clob;
    begin
       src_lob := 'china'
       dest_lob := 'hello, '
       dbms_lob.append(dest_lob,src_lob);
       dbms_output.put_line(dest_lob);
    end;
    ------------hello, china
    CLOSE过程用于关闭已经打开的LOB:
    dbms_lob.close(lob_loc  in out nocopy blob/clob/bfile);
    COMPARE用于比较同类型的LOB
    COPY将源LOB变量的部分或全部内容复制到目标LOB变量中,只适用于内部LOB类型。
    dbms_lob.createtemporary会将临时LOB建立在用户的临时表究空间。
    dbms_lob.createtemporary(lob_loc in out nocopy blob/clob/nclob, cache in boolean,dur in pls_integer := 10);
    lob_loc用于指定LOB定位符,CACHE用于指定是否要将LOB读取到缓冲区,DUR用于指定何时清除临时LOB(10:会话结束清除临时LOB,12:调用结束清除临时LOB)。
    erase用于删除LOB变量的全部内容或部分内容,只适用于内部LOB类型。
    FILECLOSE:用于关闭已经打开的BFILE定位符所指向的OS文件。
    filecloseall用于关闭当前会话已经打开的所有BFILE文件。
    fileexists用于确定BFILE定位符所指向的OS文件是否存在。若存在返回1,不存在返回0.
    filegetname:用于取得BFILE定位符所对应的目录别名和文件名。
    fileisopen用于确定BFILE所对应的OS文件是否已经打开。打开返回1 ,没有打开返回0.
    FILEOPEN用于打开BFILE所对应的OS文件。打开时可以指定文件的打开模式。OS文件只能以只读方式打开。
    FREETEMPORARY:用于释放在转为临时表空间中的临时LOB。
    GETCHUNKSIZE使用该函数,可以取得CHUNK参数所对应的值。
    GETLENGTH用于取得LOB数据的实际长度。
    instr用于返回特定样式数据在LOB中从某偏移位置开始第N次出现时的具体位置。既适用于BLOB和CLOB也适用于BFILE。
    ISOPEN用于确定LOB是否已经被打开,既适用于BLOB和CLOB也适用于BFILE。
    ISTEMPORARY用于确定LOB定位符是否为临时LOB。是则返回1,否则返回0.
    LOADFROMFILE用于将BFILE的部分或者全部内容复制到目标LOB变量(CLOB或BLOB)中
    LOADBLOBFROMFILE用于将BFILE数据装载到BLOB中,并且在装载后可以取得新的偏移位置。
    LOADCLOBFROMFILE用于将BFILE数据装载到CLOB中,当使用该过程装载数据到CLOB中时,可以指定字符集ID号,并进行字符集转换。
    open用于在打开LOB时指定LOB的读写模式。只读(dbms_lob.lob_readonly),读写(dbms_lob.lob_readwrite),既适用于BLOB和CLOB也适用于BFILE。
    read:将LOB数据读取到缓冲区中,既适用于BLOB和CLOB也适用于BFILE。
    SUSTR用于返回LOB中从指定位置开始的部分内容,既适用于BLOB和CLOB也适用于BFILE。
    TRIM:用于截断LOB内容到指定长度,只适用于BLOBB,CLOB,不适用于BFILE。
    WRITE用于将缓冲区数据写入到LOB中的特定位置,只适用于BLOBB,CLOB,不适用于BFILE。
    WRITEAPPEND:将缓冲区数据写入到LOB尾部,只适用于BLOBB,CLOB,不适用于BFILE。
  • LONG,LONG RAW与LOB的区别

    2009-07-02 10:47:27

    LONG,LONG RAW                                               LOB
    一个表只能有一个LONG或LONG RAW列                  一个表可以有多个LOB列
    数据最大长度2G字节                                数据最大长度4G字节
    SELECT返回数据                                   SELECT返回LOB定位符
    数据存储:行内                                    数据存储:行内或行外
    不支持对象类型                                    支持对象类型
    数据访问:顺序访问                                数据访问:随机访问
    使用LONG/LONG RAW列时,其数据与其他列的数据相邻存放,而使用LOB列时,如果数据小于4000字节,则与其它例相邻存放(行内),如果数据大于4000字节,则数据被存放到专门的LOB段中(行外)。
  • Tomcat 项目迁移至weblogic 10笔记(转)

    2009-06-29 15:38:35

    这几天在WEBLOGIC上部署应用程序发现了不少问题,找了下面的这个帖子感觉不错,记录一下~~~

    OS:Windows XP

    WebApp Server:Tomat5.5 WebLogic  server 10 (中文版)

    IDE:Bea workshop for weblogic platform。
    一.IDE注意事项

    创建动态web项目,选择是否共享j2ee库,如果共享,则需要域的共享库里面包含项目所需的库,比如beeHive netUi;
    不共享,则将所需的库拷贝到WEB-INF/lib目录,并自动创建相关配置文件于WEB-INF下

    如果访问页面时出现如下错误:
    index.jsp:2:4: 使用该 URI 无法找到标记库。可能是因为 URI 不正确或解析 .tld 文件时出错。
    <%@taglib uri="http://beehive.apache.org/netui/tags-html-1.0" prefix="netui"%>

    请删除多余的配置文件,或者重新建立一个工程,在向导第二页选择好正确的配置。

    二.WebLogic基础知识

    一个域可以包括多个服务器,应用程序依赖于某个服务器,通过部署-〉某应用程序-〉目标 来配置
    wl_server是weblogic默认域,通过开始菜单-〉Bea products->tools->Weblogic Server来启动
    要创建自己的域,则可以通过开始菜单-〉Bea products->tools->Configuration wizard来创建
    登录地址:http://localhost:7001/console/login/LoginForm.jsp
    登录用户密码:weblogic/weblogic
    1.部署war之后,测试时发生错误:
    Error   503--Service   Unavailable   
    From   RFC   2068   Hypertext   Transfer   Protocol   --   HTTP/1.1: 
    .....
    解决办法:一般是在刚刚激活更改后,就进行测试,还需要将该应用程序启动,状态为“活动”之后再测试就可以了。

     

    2.连接池测试时出错:

    Warning! Connectivity to backend database not verified. This is either because required connection pool attribute "TestConnectionsOnReserve" has not been enabled, or an invalid value has been specified for attribute "TestTableName". Please check the server log for more details..

    配置连接缓冲池,在“高级”中选中“保留时测试连接”即可。此时需要先激活更改再进行测试。否则还会报错。

    3.jdbc jndi错误:
    javax.naming.NameNotFoundException: Unable to resolve 'jdbc_fbysss. Resolved ''; remaining name 'jdbc_fbysss'

    首先要在控制台中点击左边的控制栏中的服务->JDBC新建一个数据源,数据源名称无所谓,jndi name一定要注意,比如取名叫jdbc_fbysss,而且,jdbc源必须依赖于一个server。否则无法启动。

    对于Spring项目,修改applicationContext.xml的dataSource,(Tomcat的连接池在这里就不需要了)。

      <!-- 数据源缓冲池 -->  <bean id="dataSource"   class="org.springframework.jndi.JndiObjectFactoryBean">    
            <property name="jndiName" value="jdbc_fbysss"/><!--两者要一样-->
            <property name="resourceRef"> 
              <value>false</value>
            </property>   
            </bean>

     

    4.xml校验错误

    (1)hbm.xml

    org.dom4j.DocumentException: unknown protocol: platform. Nested exception: unknown protocol: platform 
    这个经检查是workshop导出时 ,hbm.xml文件生成错误。修改过来就好了

     

    (2)struts-config.xml

    正式部署时出现异常:
    ERROR Digester        []: Parse Error at line 2 column
     15: Document root element "struts-config", must match DOCTYPE root "null".
    org.xml.sax.SAXParseException: Document root element "struts-config", must match
     DOCTYPE root "null".
    需要在struts-config.xml中第二行加入<!DOCTYPE   struts-config   PUBLIC   "-//Apache   Software   Foundation//DTD   Struts   Configuration   1.2//EN"   "http://struts.apache.org/dtds/struts-config_1_2.dtd">

     

    5.ServletApi实现不一致情况

    发现一个奇怪的现象,tomcat中,一个servlet的子类,如果没有声明init方法,会自动执行父类的init方法,而weblogic不会。
    解决办法是显式声明init,super.init();

    6.莫名其妙空指针错误

    完整错误信息:
    java.io.FileNotFoundException: F:\bea\wlserver_10.0\samples\domains\workshop\servers\cgServer\tmp\_WL_user\prj_fbysss\mlh5uz\war (拒绝访问。)
            at java.io.FileInputStream.open(Ljava.lang.String;)V(Native Method)
            at java.io.FileInputStream.<init>(FileInputStream.java:106)
            at workshop.util.filesystem.file.WlFileSystem.getInputStream(WlFileSyste
    m.java:148)
            at workshop.util.filesystem.FS.getInputStream(FS.java:262)
            at javelin.jsp.JspParser.readStaticInclude(JspParser.java:3261)
            at javelin.jsp.JspParser.parseStaticInclude(JspParser.java:3198)
            at javelin.jsp.JspParser.processImplicitIncludes(JspParser.java:3289)
            at javelin.jsp.JspParser.jspParse(JspParser.java:703)
            at javelin.jsp.JspParser._parse(JspParser.java:504)
            at javelin.jsp.JspParser.parse(JspParser.java:497)
            at javelin.jsp.JspAnalyzer.parseFile(JspAnalyzer.java:113)
            at javelin.jsp.JspAnalyzer.parse(JspAnalyzer.java:101)
            at javelin.ProxySourceFile.parse(ProxySourceFile.java:117)
            at javelin.SourceFile.getAst(SourceFile.java:542)
            at javelin.SourceFile.getAst(SourceFile.java:516)
            at javelin.ProxySourceFile.codeGen(ProxySourceFile.java:215)
            at javelin.SourceFile.codeGen(SourceFile.java:310)
            at javelin.client.ClientUtilsImpl$CodeGenJob.run(ClientUtilsImpl.java:11
    05)
            at javelin.client.Job.performJob(Job.java:81)
            at javelin.client.ThreadPool$WorkerThread.run(ThreadPool.java:215)
    <2008-8-23 下午07时15分11秒 CST> <Error> <HTTP> <BEA-101017> <[weblogic.servlet.
    internal.WebAppServletContext@36b25e - appName: prj_fbysss, name: 'prj_fbysss', context-path: '/prj_fbysss] Root cause of ServletException.
    java.lang.NullPointerException
            at javelin.jsp.JspAnalyzer.parse(JspAnalyzer.java:104)
            at javelin.ProxySourceFile.parse(ProxySourceFile.java:117)
            at javelin.SourceFile.getAst(SourceFile.java:542)
            at javelin.SourceFile.getAst(SourceFile.java:516)
            at javelin.ProxySourceFile.codeGen(ProxySourceFile.java:215)
            Truncated. see log file for complete stacktrace
    >

    最后发现是web.xml中<include-coda/>一句不对,去掉就好了,很怪异。
      <taglib>
      <taglib-uri>http://www.sss.com/select</taglib-uri>
      <taglib-location>/WEB-INF/tlds/select.tld</taglib-location> 
         </taglib>
      <taglib>
      <taglib-uri>http://www.sss.com/tree</taglib-uri>
      <taglib-location>/WEB-INF/tlds/tree.tld</taglib-location> 
         </taglib>     
      <!--web 项目配置-->
      <jsp-property-group>
       <description>
        WEB项目配置
       </description>
       <display-name>JSPConfiguration</display-name>
       <url-pattern>*.jsp</url-pattern>
       <el-ignored>false</el-ignored>
       <page-encoding>gbk</page-encoding>
       <scripting-invalid>false</scripting-invalid>
       <!--这句居然引起webloic错误!!!! include-coda/-->
      </jsp-property-group>
     </jsp-config>

     

     

    7.类冲突问题
    (1)JSTL解析失败

    index.jsp:1:1: validator 类 "org.apache.taglibs.standard.tlv.JstlCoreTLV" 失败,出现如下异常: "java.lang.ClassCastException: weblogic.xml.jaxp.RegistrySAXParserFactory"。
    <%@page contentType="text/html;charset=gbk" language="java"%>

    项目属性-〉项目构面中的设置将记录在.setting/org.eclipse.wst.common.project.facet.core.xml文件中。
    最后是把prefer-web-inf-classes设置为false就可以了。

    (2)HQL语句执行失败

    org.springframework.orm.hibernate3.HibernateQueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken 
    这种情况是包版本冲突,必须设置prefer-web-inf-classes设置为true。

    这样一来,有的包需要true,有的需要false,怎么办?Weblogic的确够恶心的。JSTL的包都已经放webapp下了,设置prefer-web-inf-classes设置为ture还不行,只好采取以下稍显麻烦的方法:

    在workshop开发环境下,启动的服务器目录是
    F:\bea\wlserver_10.0\samples\domains\workshop\bin
    修改启动脚本startWebLogic.cmd
    找到set CLASSPATH=%SAVE_CLASSPATH%,在后面加入
    @REM sss added 
    set PRE_CLASSPATH=%WL_HOME%\server\lib\antlr-2.7.6rc1.jar;
    set CLASSPATH=%PRE_CLASSPATH%;%CLASSPATH%

    其中,antlr-2.7.6rc1.jar包需要拷贝到F:\bea\wlserver_10.0\server\lib下。
    正式发布的时候,需要修改对应域目录下的启动脚本
    比如f:\bea\user_projects\domains\fbysssDomain\bin\startWebLogic.cmd

     

    8.部署问题
    部署时出现如下错误:
    <2008-8-23 下午07时37分42秒 CST> <Warning> <Deployer> <BEA-149124> <

    Failures were detected while initiating redeploy task for application 'prj_fbysss'. Error is: '
    [Deployer:149163]The domain edit lock is owned by another session in non-exclusi
    ve mode - this deployment operation requires exclusive access to the edit lock a
    nd hence cannot proceed.'>
    解决:进入http://localhost:7001/console,释放配置,再次部署即可。

     

    注:更新war:必须在删除该应用,并激活更改之后才能覆盖。
    但是用war方式,获取资源路径的方法和tomcat不同,存在臭名昭著的getRealPath等问题,移植困难,所以用目录方式部署比较好。

    具体方法:先把war解压,然后在weblogic控制台里面选择目录部署。

  • DBMS_LOB包使用和维护[转]

    2009-06-26 17:26:00

    遇到BLOB的一个问题,上网找到此文档,转过来以供学习。
     
        摘要:本文通过实例介绍了在ORACLE数据库中通过DBMS_LOB包使用和维护LOB数据类型的基本方法。

        关键词:ORACLEDBMS_LOBLOB维护

        中图分类号:TP31
     
    1、引言 

        随着社会的发展,在现代信息系统的开发中,需要存储的已不仅仅是简单的文字信息,同时还包括一些图片和音像资料或者是超长的文本。比如开发一套旅游信息系统,每一个景点都有丰富的图片、音像资料和大量的文字介绍。这就要求后台数据库要有存储这些数据的能力。ORACLE公司在其Oracle8i中通过提供LOB字段实现了该功能。   

        为了便于读者的理解,我们先介绍一些基本的概念:

        在ORACLE数据库中,LOB(Large Objects —— 大对象)是用来存储大量的二进制和文本数据的一种数据类型(一个LOB字段可存储可多达4GB的数据)。目前,它又分为两种类型:内部LOB和外部LOB。内部LOB将数据以字节流的形式存储在数据库的内部。因而,内部LOB的许多操作都可以参与事务,也可以像处理普通数据一样对其进行备份和恢复操作。Oracle8i支持三种类型的内部LOB:BLOB(二进制数据)、CLOB(单字节字符数据)、NCLOB(多字节国家字符数据)。其中CLOB和NCLOB类型适用于存储超长的文本数据,BLOB字段适用于存储大量的二进制数据,如图像、视频、音频等。目前,Oracle8i只支持一种外部LOB类型,即BFILE类型。在数据库内,该类型仅存储数据在操作系统中的位置信息,而数据的实体以外部文件的形式存在于操作系统的文件系统中。因而,该类型所表示的数据是只读的,不参与事务。该类型可帮助用户管理大量的由外部程序访问的文件。

        为了方便下文的叙述,我们假定使用如下语句在数据库中创建了一张表。

        CREATE   TABLE   view_sites_info
        (site_id     NUMBER(3),
         audio       BLOBDEFAULT empty_blob(),
         document    CLOBDEFAULT empty_clob(),
         video_file  BFILEDEFAULT NULL,
         constraint  PK_TAB_view_sites_info primary key (site_id)
        );

    2、LOB的使用和维护

        ORACL提供了多种使用和维护LOB的方式,如使用PL/SQL DBMS_LOB包、调用OCI(Oracle Call Interface)、使用Proc*C/C++、使用JDBC等。其中最为方便有效的是使用PL/SQL调用DBMS_LOB包,本文就将介绍该方法。

        在Oracle中,存储在LOB中数据称为LOB的值,如使用Select 对某一LOB字段进行选择,则返回的不是LOB的值,而是该LOB字段的定位器(可以理解为指向LOB值的指针)。如执行如下的SQL语句:

        DELCARE
           AUDIO_INFOBLOB;
        BENGIN
           SELECT audio INTO AUDIO_INFO FROM view_sites_info
            WHERE site_id=100;
        END;
        /

        存储在AUDIO_INFO变量中的就是LOB定位器,而不是LOB的值。而要对某一LOB的值进行访问和维护操作,必需通过其定位器来进行。DBMS_LOB包中提供的所有函数和过程都以LOB定位器作为参数。

        2.1内部LOB

        DBMS_LOB包中主要提供了以下几个过程供用户对内部LOB字段进行维护。

        APPEND()将源LOB中的内容加到目的LOB中
        COPY()从源LOB中复制数据到目的LOB
        ERASE()删除LOB中全部或部分内容
        TRIM()将LOB值减少到指定的长度
        WRITE()向LOB中写入数据
        COMPARE()比较两个同种数据类型的LOB的部分或全部值是否相同
        GETLENGTH()获取LOB的长度
        READ()从LOB中读出数据

        下面我们以最为常用的读和写为例详细介绍这些过程的用法。

        首先介绍一下写过程。该过程的语法为:

        PROCEDURE WRITE(lob_locIN OUTBLOB,
                         amount  INBINARY_INTEGER, 
                         offset  ININTEGER,
                         buffer  INRAW);
     
        PROCEDURE WRITE (lob_locIN OUTCLOBCHARACTER SETANY_CS,     
                         amount  INBINARY_INTEGER,     
                         offset  ININTEGER,     
                         buffer  INVARCHAR2CHARACTER SET lob_loc%CHARSET);    

        各参数的含义为:

        lob_loc:要写入的LOB定位器
        amount:写入LOB中的字节数
        offset:指定开始操作的偏移量
        buffer:指定写操作的缓冲区

        下面的代码就是运用该过程向LOB字段写入数据的示例。

        DECLARE
           lobloc CLOB;
           buffer VARCHAR2(2000);
           amount NUMBER := 20;
           offset NUMBER := 1;
        BEGIN
           --初始化要写入的数据
           buffer := 'This is a writing example';
           amount := length(buffer);
           SELECT document INTO lobloc--获取定位器并锁定行
             FROMview_sites_info
            WHERE site_id = 100 FOR UPDATE;

           dbms_lob.write(lobloc,amount,1,buffer);
           COMMIT;
        END;
        /

        需要特别指出的是:
        I.在调用写过程前一定要使用SELECT语句检索到定位器且用FOR UPDATE 子句锁定行,否则不能更新LOB
        II.写过程从offset指定的位置开始,向LOB中写入长度为amount的数据,原LOB中在这个范围内的任何数据都将被覆盖。
        III.缓冲区的最大容量为32767字节,因此在写入大量数据时需多次调用该过程。

        下面再来介绍一下读过程:

        该过程的语法为:

        PROCEDURE READ(lob_locINBLOB,
                        amount  IN OUTBINARY_INTEGER,
                        offset  ININTEGER,
                        buffer  OUTRAW);

        PROCEDURE READ (lob_loc INCLOBCHARACTER SET ANY_CS,
                        amount  IN OUTBINARY_INTEGER,
                        offset  ININTEGER,
                        buffer  OUTVARCHAR2 CHARACTER SET lob_loc%CHARSET);
        
        各参数的含义为:   
        
        lob_loc:要读取的LOB定位器   
        amount:要读取的字节数   
        offset:开始读取操作的偏移量   
        buffer:存储读操作结果的缓冲区   
        
        下面的代码演示了如何使用该过程读取LOB字段中的数据:   
        
        DECLARE     
           lobloc CLOB;     
           buffer VARCHAR2(2000);     
           amount NUMBER := 2;     
           offset NUMBER := 6;     
        BEGIN     
           SELECT document INTO lobloc--获取定位器   
             FROM lob_store     
            WHERE lob_id = 100;     
           dbms_lob.read(lobloc,amount,offset,buffer);--读取数据到缓冲区   
           dbms_output.put_line(buffer);--显示缓冲区中的数据   
           COMMIT;     
        END;     
        /   
  • statspack报告

    2008-10-15 20:09:39

        今天成功地在公司装完statspack,没有任何错误,不像在宿舍会遇到前面说的问题,接下来开始研究报告所体现的意义。我测试了一下,生成了一个报告,我把报告贴上来,之后若有研究出东西再上来更新。


    STATSPACK report for

    Load Profile ~~~~~~~~~~~~                            Per Second       Per Transaction                                    ---------------       ---------------
                      Redo size:              1,511.85             32,371.29
                  Logical reads:                 13.69                293.06
                  Block changes:                  3.87                 82.94
                 Physical reads:                  2.67                 57.12
                Physical writes:                  2.67                 57.12
                     User calls:                  1.98                 42.35
                         Parses:                  0.69                 14.76
                    Hard parses:                  0.05                  1.06
                          Sorts:                  0.43                  9.29
                         Logons:                  0.00                  0.00
                       Executes:                  1.29                 27.71
                   Transactions:                  0.05

      % Blocks changed per Read:   28.30    Recursive Call %:    60.59
     Rollback per transaction %:    0.00       Rows per Sort:   164.76

    Instance Efficiency Percentages (Target 100%)      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                Buffer Nowait %:  100.00       Redo NoWait %:  100.00
                Buffer  Hit   %:   99.90    In-memory Sort %:   98.73
                Library Hit   %:   93.72        Soft Parse %:   92.83
             Execute to Parse %:   46.71         Latch Hit %:   99.99
    Parse CPU to Parse Elapsd %:   87.50     % Non-Parse CPU:   88.89

     Shared Pool Statistics        Begin   End                                                  ------  ------
                 Memory Usage %:   71.80   72.75
        % SQL with executions>1:   96.18   96.63
      % Memory for SQL w/exec>1:   84.77   88.58

    Top 5 Timed Events
    ~~~~~~~~~~~~~~~~~~                                                     % Total
    Event                                               Waits    Time (s) Ela Time
    -------------------------------------------- ------------ ----------- --------
    CPU time                                                            1    61.83
    control file parallel write                           118           0    13.03
    direct path read                                       68           0    11.12
    db file sequential read                                 5           0     3.68
    log file parallel write                               115           0     2.91
                                                                                                                            -------------------------------------------------------------
    Wait Events for DB: AAAAA  Instance: AAAAA  Snaps: 1 -2
    -> s  - second
    -> cs - centisecond -     100th of a second
    -> ms - millisecond -    1000th of a second
    -> us - microsecond - 1000000th of a second
    -> ordered by wait time desc, waits desc (idle events last)

    还是贴比较重点的部分出来~~~

  • 关于LR的too many local variables错误

    2008-10-13 20:05:37

        记得在3ATESTING里看过一个视频,里面介绍了出现too many local variables的原因及解决的方法,下面将相应的内容贴出来,让路过的人都可以学习一下,程序如下:

    Action()

    {

     //若在此处加上:char bp[100000];则编译的时候就会出现too many local variables这个错误

     if (条件1){}

     else{}

     return 0;

    }

        为什么加上char bp[100000];就会有那个错误呢,原因其实是因为Action能分配的内存不多,所以若要直接使用占用内存大的变量,则建议将其定义成全局变量,或者是在Action里面使用malloc函数来进行分配。

        这是从3ATESTING那边学习来的,感谢~~~

       

  • statspack

    2008-10-05 21:37:17

        最近在学习使用Statspack工具来监控数据库的性能,已经学习了大半,但在一个环节中出了点小问题,不知道怎么解决~~~

        主要是以下二个问题,在执行spreport.sql这个脚本时,总会提示:

               'DB: ' db_name  '  Instance: ' inst_name '  '-
               'Snaps: ' format 999999 begin_snap ' -' format 999999 end_snap -
           skip 2
     
    ORA-00900: 无效 SQL 语句

    不知道是为什么~~~


    还有使用命令:set trimout on会有如下返回:Cannot SET TRIMOUT
    使用命令:set trimspool on会有如下返回:Cannot SET TRIMSPOOL

    上网找不到相应的解决方法,也不清楚是为什么,研究中,希望路过清楚的同志们伸出援助之手~~~

     

  • 录制ORACLE协议

    2008-09-26 17:26:38

         今天学习录制ORACLE协议的脚本,发现录制完成时,INIT/ACTION中东西都很多,上网查找了些资源,最终在原有录制脚本的环境下,修改了下脚本,简化了很多.

    #include "lrd.h"

    vuser_init()

    {

    //初始化数据库部分

    lrd_init(&InitInfo, DBTypeVersion);

    lrd_initialize_db(LRD_DBTYPE_ORACLE, 2, 0);

    lrd_env_init(LRD_DBTYPE_ORACLE, &OraEnv1, 0, 0);

    lrd_ora8_handle_alloc(OraEnv1, SVCCTX, &OraSvc1, 0);

    lrd_ora8_handle_alloc(OraEnv1, SERVER, &OraSrv1, 0);

    lrd_ora8_handle_alloc(OraEnv1, SESSION, &OraSes1, 0);

     

    //连接数据库

    lrd_server_attach(OraSrv1, "oolong", -1, 0, 0);

    lrd_ora8_attr_set_from_handle(OraSvc1, SERVER, OraSrv1, 0, 0);

     

    //设定数据库密码

    lrd_ora8_attr_set(OraSes1, USERNAME, "scott", -1, 0);

    lrd_ora8_attr_set(OraSes1, PASSWORD, "tiger", -1, 0);

     

    //初始化连接session

    lrd_ora8_attr_set_from_handle(OraSvc1, SESSION, OraSes1, 0, 0);

     

    //开始连接数据库

    lrd_session_begin(OraSvc1, OraSes1, 1, 0, 0);

    return 0;

    }

     

    Action()

    {

    static LRD_VAR_DESC  NUM =

       {LRD_VAR_DESC_EYECAT, 15, 23, LRD_DBTYPE_ORACLE, {1, 1, 0},DT_NUMERIC};

    lrd_ora8_handle_alloc(OraEnv1, STMT, &OraStm1, 0);

     

    //设定查询语句

    lrd_ora8_stmt(OraStm1, "select count(*) NUM from test_scott t\n", 1, 0, 0);

    lrd_ora8_attr_set(OraStm1, PREFETCH_ROWS, "0", -1, 0);

    lrd_ora8_attr_set(OraStm1, PREFETCH_MEMORY, "0", -1, 0);

     

    //执行查询语句

    lrd_ora8_exec(OraSvc1, OraStm1, 0, 0, &uliRowsProcessed, 0, 0, 0, 0,

            0);

    lrd_ora8_bind_col(OraStm1, &OraDef25, 1, &NUM, 0, 0);

              lrd_ora8_save_col (OraStm1, 1, 1, 0, "ROW");  

    lrd_ora8_fetch(OraStm1, 1, 1, &uliFetchedRows, 0, 2, 0, 0);

     

    lr_output_message("value : %s",  lr_eval_string("The  count is: {ROW}"));

    return 0;

    }

     

    vuser_end()

    {

     

    lrd_session_end(OraSvc1, OraSes1, 0, 0);

    lrd_server_detach(OraSrv1, 0, 0);

    lrd_handle_free(&OraSrv1, 0);

    lrd_handle_free(&OraSvc1, 0);

    lrd_handle_free(&OraSes1, 0);

    lrd_handle_free(&OraEnv1, 0);

    return 0;

    }

     

         ORACLE协议还有很多东西可以深究,比如在监控一个库时,我们一般要注意哪几个点,这个问题我还是不太明白,再研究吧~~~

Open Toolbar