2009年3月31日星期二

FINDSTR正则表达式的基本用法

1.findstr . 2.txt 或 Findstr "." 2.txt
从文件2.txt中查找任意字符,不包括空字符或空行
====================

2.findstr .* 2.txt 或 findstr ".*" 2.txt
从文件2.txt中查找任意字符包括空行和空字符
====================

3.findstr "[0-9]" 2.txt
从文件2.txt中查找包括数字0-9的字符串或行
====================

4.findstr "[a-zA-Z]" 2.txt
从文件2.txt中查找包括任意字符的字符串或行
====================

5.findstr "[abcezy]" 2.txt
从文件2.txt中查找包括a b c e z y字母的字符串或行
====================

6.findstr "[a-fl-z]" 2.txt
从文件2.txt中查找小写字符a-f l-z的字符串,但不包含g h I j k这几个字母。
====================

7.findstr "M[abc][hig]Y" 2.txt
从文件2.txt中可以匹配 MahY , MbiY, MahY等…..
====================

8. ^和$符号的应用
^ 表示行首,"^step"仅匹配 "step hello world"中的第一个单词
$ 表示行尾,"step<# WebPartBody #>quot;仅匹配 "hello world step"中最后一个单词
====================

9.finstr "[^0-9]" 2.txt
如果是纯数字的字符串或者行便过滤掉,例如2323423423 这样的字符串,如果是345hh888这样的形式就不成了。
====================

10.findstr "[^a-z]" 2.txt
同上,如果是纯字母的字符串或者行便过滤掉,例如 sdlfjlkjlksjdklfjlskdf这样的字符,如果是sdfksjdkf99999这样的形式,掺杂着数字就不成了
====================

11.*号的作用
前面已经说过了 ".*"表示搜索的条件是任意字符,*号在正则表达式中的作用不是任何字符,而是表示左侧字符或者表达式的重复次数,*号表示重复的次数为零次或者多次。
====================

12.findstr "^[0-9]*$" 2.txt
这个是匹配找到的纯数字,例如 234234234234,如果是2133234kkjl234就被过滤掉了。
Findstr "^[a-z]*$" 2.txt
这个是匹配找到的纯字母,例如 sdfsdfsdfsdf,如果是213sldjfkljsdlk就被过滤掉了
如果在搜索条件里没有*号,也就是说不重复左侧的搜索条件,也就是[0-9] [a-z]那只能匹配字符串的第一个字符也只有这一个字符,因为有行首和行尾的限制,"^[0-9]<# WebPartBody #>quot;第一个字符如果是数字就匹配,如果不是就过滤掉,如果字符串是 9 就匹配,如果是98或者9j之类的就不可以了。
=====================

13. "\<…\>"这个表达式的作用
这个表示精确查找一个字符串,\表示字的结束位置
echo hello world computer|findstr "\"这样的形式
echo hello worldcomputer|findstr "\" 这样的形式就不成了,他要找的是 "computer"这个字符串,所以不可以。
echo hello worldcomputer|findstr ".*computer\>"这样就可以匹配了

2009年3月29日星期日

window下如何配置sybase使用最大内存

在32位的操作系统如win2K上,操作系统能管理的内存为4GB,sybase使用的总内存有2G限制。目前大多数unix服务器都能为数据库配上4G物理内存甚至更多,但无论你为系统配置多大的物理内存,正常情况下都不能使sybase使用超过2G的内存,从而造成系统资源浪费。那么,有没有什么办法能使运行在windows系统上的sybase使用超过2G的内存呢?windows 提供了一种叫4GT(4G Tuning)的技术,使得sybase使用超过2G(不超过3G)的内存成为可能。而为了让应用程序使用更大的内存,还有一种PSE36的技术,可以让sybase使用超过3G的内存。这里,介绍如何使用4GT特性让sybase使用超过2G的内存。

1。打开操作系统的3G开关
首先修改boot.ini文件,在C盘根目录下。加入/3G参数:
[boot loader]
timeout=8
default=multi(0)disk(0)rdisk(0)partition(1)
[operating systems]
multi(0)disk(0)rdisk(0)partition(1)="Microsoft Windows 2000 Advanced Server” /3G /fastdetect
然后从起机器,使/3G参数生效

2。将NT的虚拟内存调整到3G以上。
这一步不用多说了,右键单击我的电脑选属性。


3。打开sybase使用超过2G内存的开关
进入/ASE-12_5/bin下,备份sqlsrvr.exe。
在/ASE-12_5/bin目录下执行:imagecfg sqlsrvr
imagecfg.exe可以从网上下载,我就是在google上搜索的,http://www.robpol86.com/tutorial ... g的安装和使用方法。
执行后如果显示下面的内容则说明2G开关未打开
sqlsrvr.exe contains the following configuration information:
Subsystem Version of 4.0
Stack Reserve Size: 0x20000
Stack Commit Size: 0x4
如果2G开关未打开,则执行:imagecfg -l sqlsrvr.exe
再执行imagecfg sqlsrvr.exe,应显示下面内容:
sqlsrvr.exe updated with the following configuration information:
Subsystem Version of 4.0
Image can handle large (>;2GB) addresses
Stack Reserve Size: 0x20000
Stack Commit Size: 0x4
此时sybase的2G开关已经被打开。

4。配置数据库参数
打开数据库配置文件,修改total memory到2.2G。
修改shared memory starting address参数到23662592(十进制的数)
重启数据库。

以上是配置的全过程。下面解释一下为什么配置totol memory到2.2G和23662592的来源。
shared memory starting address 参数并不是大小,而是一个地址,它指定sybase从什么地方开始使用内存。在NT操作系统可以管理的4G内存中,0到7fffffff是供应用程序使用的,80000000到FFFFFFFF是保留给操作系统使用的。如果3G开关打开,0到BFFFFFFF提供给应用程序使用,C0000000到FFFFFFFF保留给操作系统。
应用程序使用内存是从0开始的,0到FFF提供给guard page,至于什么叫guard page本人也不是很清楚,从字面理解吧。
sqlsrvr.exe从400000开始占用内存,很多lib文件,比如libct、libsrv被装载在400000的上下,那么从400000以上的某个地方起,我们边得到一个整块的空间用于应用程序。
默认情况下(shared memory starting address 参数为default时),sybase的total memory从20000000开始使用内存,那么从20000000到7FFFFFFF就有1.5G空间,如果打开3G参数则是从20000000到BFFFFFFF,即2.5G空间。这就是为什么在nt上的sybase的total memory无法配过1.5的原因所在。
但实时上,这1.5或2.5的空间并不能完全由sybase支配,系统会在内存顶端,也就是从7FFFFFFF开始向下装载一些dll文件,因此sybase在shared memory starting address 参数为default时可用空间在20000000到某个比7FFFFFFF小的值,也就是1.4G左右吧。
可见7FFFFFFF一段是个死的限制,如果想让sybase使用更多的内存只有打破shared memory starting address 参数从20000000开始的限制。配置shared memory starting address 参数的目的就在于此。
配置shared memory starting address 参数等于23662592的目的就在于使sybase从地址低于20000000的地方开始使用内存,23662592转换成16进制为1691000,配置这个参数后,sybase可用空间就变为从1691000到7FFFFFFF,也就是1.9G,如果打开了3G参数,则是从1691000到BFFFFFFF,也就是2.9G。
那么为什么推荐23662592呢?这是sybase公司的经验值,如果这个值太低则会引起操作系统在分配内存时的错误,因为空间都被压缩的很小了嘛。

2009年3月23日星期一

关于TOMCAT的优化配置设置(转自网络)

1.精简Tomcat和配置文件

1.删除不需要的管理应用和帮助应用,提高tomcat安全性。

# 删除webapps下所有文件

# rm –fr $CATALINA_HOME/webapps/*

# 删除server/wenapps下所有文件

# rm –fr $CATALINA_HOME/server/webapps/*

2.精简sever.xml配置文件

使用tomcat发布版本中的最小配置文件,提高性能,如果有功能上的需求,在逐个的加入功能配置。

# 备份原来的server.xmlserver.xml_bak

# mv server.xml server.xml_bak

# 复制server-minimal.xmlserver.xml

# cp server-minimal.xml server.xml

2.连接器优化

$CATALINA_HOME/conf/server.xml配置文件中的Connetctor节点,和连接数相关的参数配置和优化。

maxThreads

Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200 可以根据机器的时期性能和内存大小调整,一般可以在400-500。最大可以在800左右。

acceptCount

  指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10

minSpareThreads
Tomcat初始化时创建的线程数。默认值4

maxSpareThreads
一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50

enableLookups

是否反查域名,默认值为true。为了提高处理能力,应设置为false

connnectionTimeout

网络连接超时,默认值20000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。(本系统由于与后台系统接口超时时间较长,使用设置为60000)

maxKeepAliveRequests

保持请求数量,默认值100

bufferSize
输入流缓冲大小,默认值2048 bytes


compression

压缩传输,取值on/off/force,默认值off

其中和最大连接数相关的参数为maxThreadsacceptCount。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows2000个左右,Linux1000个左右。

Tomcat中如何禁止和允许列目录下的文件

$CATALINA_HOME/conf/web.xml中,把listings参数设置成false即可,如下:


    listings
    false

    ...

具体操作

# vi $CATALINA_HOME/conf/server.xml

修改用于AJP的连接:

为:

maxTreads="500" minSpareThreads="10" maxSpareThreads="50"

acceptCount="50" connectionTimeout="60000"

enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />

修改通用连接:

为:

maxTreads="500" minSpareThreads="10" maxSpareThreads="50"

acceptCount="50" connectionTimeout="60000"

enableLookups="false" redirectPort="8443" protocol="AJP/1.3"

compression="on"

compressionMinSize="2048"

noCompressionUserAgents="gozilla, traviata"

compressableMimeType="text/html,text/xml"/>

修改主机和应用配置:

为:

unpackWARs="true" autoDeploy="true"

xmlValidation="false" xmlNamespaceAware="false">

3.优化JDK

Tomcat默认可以使用的内存为128MB,Windows,在文件{tomcat_home}/bin/catalina.batUnix下,在文件$CATALINA_HOME/bin/catalina.sh的前面,增加如下设置:

JAVA_OPTS='$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存]

设置环境变量:export JAVA_OPTS=”$JAVA_OPTS -Xms[初始化内存大小] -Xmx[可以使用的最大内存]”

一般说来,你应该使用物理内存的 80% 作为堆大小。如果本机上有Apache服务器,可以先折算Apache需要的内存,然后修改堆大小。建议设置为70%;建议设置[[初始化内存大小]等于[可以使用的最大内存],这样可以减少平凡分配堆而降低性能。

本例使用加入环境变量的方式:

# vi /etc/profile

加入:export JAVA_OPTS=”$JAVA_OPTS -Xms700 –Xmx700

# source /etc/profile

PAUL2SMOON 的共享项目