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

2009年2月17日星期二

宝宝取名及名字评分

何睿宣 90
何夏天 85
何叶紫 76
何江晨 90
何顺顺 81
何静孜 96
何谕辛
何岳萱 99.5

2009年2月12日星期四

NFS /etc/exports

Nfs服务器的配置,配置文件/etc/exports:
Exports文件中一些选项的含义
选项 说明
Ro 该主机对该共享目录有只读权限
Rw 该主机对该共享目录有读写权限
Root_squash 客户机用root用户访问该共享文件夹时,将root用户映射成匿名用户
No_root_squash 客户机用root访问该共享文件夹时,不映射root用户
All_squash 客户机上的任何用户访问该共享目录时都映射成匿名用户
Anonuid 将客户机上的用户映射成指定的本地用户ID的用户
Anongid 将客户机上的用户映射成属于指定的本地用户组ID
Sync 资料同步写入到内存与硬盘中
Async 资料会先暂存于内存中,而非直接写入硬盘
Insecure 允许从这台机器过来的非授权访问
例/ zhang (rw) wang (rw,no_root_squash) 表示共享服务器上的根目录(/)只有zhang和wang两台主机可以访问,且有读写权限;zhang主机用root用户身份访问时,将客户机的root用户映射成服务器上的匿名用户(root_squash,该参数为缺省参数),相当于在服务器使用nobody用户访问目录;wang主机用root用户身份访问该共享目录时,不映射root用户(no_root_squash),即相当于在服务器上用root身份访问该目录
/root/share/ 192.168.1.20 (rw,insecure,sync,all_squash) 表示共享服务器上的/root/share/目录只有192.168.1.20主机可以访问,且有读写权限;此主机用任何身份访问时,将客户机的用户都映射成服务器上的匿名用户(all_squash),相当于在服务器上用nobody用户访问该目录(若客户机要在该共享目录上保存文件(即写操作),则服务器上的nobody用户对该目录必须有写的权限)
/home/ljm/ *.gdfs.edu.cn (rw,insecure,sync,all_squash) 表示共享/home/ljm/目录,*.gdfs.edu.cn域中所有的主机都可以访问该目录,且有读写权限
/home/share/ .gdfs.edu.cn (ro,sync,all_squash,anonuid=student,anongid=math) 表示共享目录/home/share/,*.gdfs.edu.cn域中的所有主机都可以访问,但只有只读的权限,所有用户都映射成服务器上的uid为student、gid为math的用户
启动nfs后又修改了/etc/exports,不用重启该服务,使用exports命令即可:
Exports [-aruv]
-a 全部mount或umount文件/etc/exports中的内容
-r 重新mount文件/etc/exports中的共享内容
-u umount目录
-v 在export的时候,将详细的信息输出到屏幕上
例[root@localhost ~]#exports –rv 全部重新export一次
[root@localhost ~]#exports –au 全部卸载
Nfs客户端的配置:
若是临时使用可直接执行mount命令:mount servername(or IP): 共享目录 本地挂载目录
若客户机启动就自动挂载服务器的共享目录,则需修改客户机上的/etc/fstab文件
/etc/fstab格式:(192.168.233.139:/share /mnt nfs defaults 0 2)
Fs_spec fs_file fs_type fs_options fs_dump fs_pass
Fs_spec:定义希望加载的文件系统所在的设备或远程文件系统,对于nfs则设为IP:/共享目录
Fs_file:本地挂载点
Fs_type:挂载类型
Fs_options:挂载参数
Fs_dump:该选项被“dump”命令使用来检查一个文件系统该以多快频率进行转储,若不需转储即为0
Fs_pass:该字段被fsck命令使用来决定在启动时需要被扫描的文件系统的顺序,根文件系统“/”对应该字段值为1,其他文件系统为2,若该文件系统无需在启动时被扫描则为0
安全提醒:确保网络安全,使用nfs时结合tcp_wrappers来限制使用范围(如只想192.168.5.123主机可挂载nfs服务器上的共享目录),另外还可结合iptables来加强安全性。
[root@localhost ~]#vi /etc/hosts.allow
Portmap:192.168.5.123:allow
[root@localhost ~]#vi /etc/hosts.deny
Portmap:ALL:deny
关机时若nfs server上有client联机时,先关掉portmap与nfs两个系统服务。若无法正确将此2项服务关掉,用netstat –utlp找出PID,然后用kill杀掉进程才关机
Nfsstat查看NFS的运行状态,调整NFS运行大有帮助
Rpcinfo查看rpc执行信息,用于检测rpc运行情况
挂载格式:mount –t nfs hostname(or IP):/directory /mount point
卸载:umount /本地挂载目录(本地client卸载方法,但用exports –au为server卸载)
Showmount –e IP(查看NFS服务器上共享了那些目录)Showmount –a IP(用于nfs server上,显示已经mount上本机NFS服务器的client(客户机))

2009年2月11日星期三

Sybase中bcp的用法

  BCP是SYBASE公司提供专门用于数据库表一级数据备份的工具。

  一般存放在所安装的ASE或者Open Client 的BIN目录中。

  12版本以前的ASE,bcp存放目录为 $SYBASE/bin

  12版本(含12版本)以后存放目录为 $SYBASE/OCS-12_x/bin

  其中$SYBASE为SYBASE安装目录,12_x代表12.0、12.5版本,显示为12_0或者12_5

  可执行文件名称为bcp.EXE

  参数列表如下:(可用 bcp – 得到)

  usage: bcp [[database_name.]owner.]table_name[:slice_number] {in | out} datafile

  [-m maxerrors] [-f formatfile] [-e errfile]

  [-F firstrow] [-L lastrow] [-b batchsize]

  [-n] [-c] [-t field_terminator] [-r row_terminator]

  [-U username] [-P password] [-I interfaces_file] [-S server]

  [-a display_charset] [-q datafile_charset] [-z language] [-v]

  [-A packet size] [-J client character set]

  [-T text or image size] [-E] [-g id_start_value] [-N] [-X]

  [-M LabelName LabelValue] [-labeled]

  [-K keytab_file] [-R remote_server_principal]

  [-V [security_options]] [-Z security_mechanism] [-Q]

  常用数据备份格式为:

  bcp dbname..tablename out c:\temp\filename -Usa -Ppassword –Sservername –c

  即可。

  其中 –U后为SYBASE登录名称,–P后为SYBASE登录口令,–S后为SYBASE服务名称,–c代表使用可见文本方式导出数据

  如果为数据恢复只需要将out 替换为 in 即可。

  可用如下方法生成一个可以一次导出一个数据库中所有表的数据的执行脚本。

  编辑一个如下文本文件 文件名称例为 bcpscript:

  use dbname 选中将要导出数据的数据库

  go

  select 'bcp dbname..' + name + ' out c:\temp\' + name + ' -Usa -P -Ssybcdsrv -c' from sysobjects where type = 'U' 在sysobjects系统表中type为U的表为用户表,系统表为S。

  go

  用如下格式执行:

  isql –Usa –Ppassword –Sservername –i bcpscript –o bcpout.bat

  i参数后为输入文件,o参数后文件为输入文件执行后得到的输出文件。

  执行后可以得到一个后缀名为 BAT 的批处理文件(在unix下则生成一个shell文件并更改相应的执行权限),可直接执行。即在指定的目录下导出了相应的数据文件。一个表的数据为一个文件。如在UNIX下则可不用BAT后缀。

  备份得到的数据文件如果需要重新往数据库中恢复,只需要将上面操作步骤中BCP命令中的out 参数换为in参数即可。

  注意:在对正式数据做操作前最好先作一些测试。

  另外,如果牵涉到使用bcp进行字符集的更改,可以采用 –J charset 参数进行

  关于BCP等工具的具体使用指南,请参见SYBASE相关文档。

  针对系统移植所需做的工作,应该有如下几个步骤:

  1. 安装新环境的硬件环境,包括网络,硬盘状况;

  2. 安装新环境的操作系统,包括Service Pack;

  3. 安装相同版本的SYBASE数据库产品,包括补丁;

  4. 添加数据库用户,设备等相关信息,应与老系统中一致

  5. 创建新系统数据库;

  6. 利用你所拥有的表脚本或者通过SYBASE CENTRAL中的生成DDL功能,将老系统中的建表脚本导出,生成数据库中的表.最好将建表脚本与建立表上约束(主键,外键等)的脚本分开,先在表上不建约束,在数据导入后,再加上.;

  7. BCP OUT 老系统中数据,根据上面提到的方法;

  8. 运行建立其他对象的脚本,包括索引,主键,外键及存储过程,触发器,缺省等;

  9. 在新系统中对需要更改的表结构做更改,或者添加新表;

  10. 测试应用系统是否工作正常.

2009年1月8日星期四

各个银行卡异地取款手续费

牡丹灵通卡 中国工商银行
异地ATM取款:异地本行ATM跨行取款每笔取款金额的1%,最低1元,最高50元;异地跨行ATM取款每笔手续费为2元+取款金额的1%,1%部分最低1元,最高50元;
异地存款手续费:按存款金额的0.5%收取手续费,最低1元,最高50元。
异地取款手续费:按取款金额的0.5%收取手续费,最低1元,最高50元。

金穗借记卡 中国农业银行
异地ATM取款:异地本行ATM跨行取款每笔取款金额的1%,最低1元;异地跨行ATM取款每笔手续费为2元+取款金额的1%;
异地存款手续费:省内异地柜台:交易金额的0.5%,最低1元,最高50元;跨省异地柜台:交易金额的0.5%,最低1元,最高100元。
异地取款手续费:省内异地柜台:交易金额的1%,最低1元,最高50元;跨省异地柜台:交易金额的1%,最低1元,最高100元。

长城电子借记卡 中国银行
异地ATM取款:异地本行ATM跨行取款每笔10元;异地跨行ATM取款每笔手续费为12元;
异地存款手续费:异地本行存款只能办理汇款按当地电汇标准收取
异地取款手续费:只能在异地ATM机上取款

龙卡储蓄卡 中国建设银行
异地ATM取款:异地本行ATM跨行取款每笔取款金额的1%,最低2元;异地跨行ATM取款每笔手续费为2元+取款金额的1%,1%部分最低2元;
异地存款手续费:按存款金额的0.5%收取手续费,最低2元,最高50元。
异地取款手续费:按取款金额的0.5%收取手续费,最低2元,不设上限。

一卡通 招商银行
异地ATM取款:异地本行ATM跨行取款每笔取款金额的0.5%;异地跨行ATM取款每笔手续费为2元+取款金额的0.5%;
异地存款手续费:按存款金额的0.5%收取手续费。
异地取款手续费:按取款金额的0.5%收取手续费。

太平洋借记卡 交通银行
异地ATM取款:异地本行ATM跨行取款每笔取款金额的0.8%;异地跨行ATM取款每笔手续费为2元+取款金额的0.8%;
异地存款手续费:存款金额的万分之五,最低10元,最高50元
异地取款手续费:取款金额的1%,最低10元,最高100元

华夏卡 华夏银行
异地ATM取款:异地本行ATM机取款每笔收取手续费1元;异地跨行ATM机取款每笔收取手续费2元;
异地存款手续费:按存款金额的0.1%收取手续费,最高10元。
异地取款手续费:按取款金额的0.5%收取手续费。

东方借记卡 上海浦东发展银行
异地ATM取款:0元
异地存款手续费:0元
异地取款手续费:0元

阳光卡 中国光大银行
异地ATM取款:异地本行和跨行取款一律收取0.5%的手续费,最低5元,最高50元
异地存款手续费:按交易金额的0.5%收取手续费,最低2元,最高20元
异地取款手续费:按交易金额的0.5%收取手续费,最低5元,最高50元

民生借记卡 中国民生银行
异地ATM取款:5元/笔
异地存款手续费:0元
异地取款手续费:交易金额0.3%,最低5元

中信借记卡 中信实业银行
异地ATM取款:异地跨行收款0.5%的手续费
异地存款手续费:按交易金额的0.5%收取手续费,最高10元
异地取款手续费:按交易金额的0.5%收取手续费,最高200元

兴业卡 兴业银行
异地ATM取款:同城跨行ATM机取款前三笔免收手续费,第四笔开始每笔2元;异地本行ATM机取款免收手续费;异地跨行ATM机取款厦门、深圳、南京不收手续费,其他城市前三笔不收手续费从第四笔开始每笔收取手续费2元;
异地存款手续费:存款金额的0.1%收取手续费,最低1元,最高20元。
异地取款手续费:取款金额的0.3%收取手续费,最高500元。

理财通卡 广东发展银行
异地ATM取款:异地跨行收款1%的手续费
异地存款手续费:存款金额的万分之五,最高20元
异地取款手续费:取款金额的1%,最高10元

PAUL2SMOON 的共享项目