vickzhu

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  151 随笔 :: 0 文章 :: 34 评论 :: 0 Trackbacks

2009年11月4日 #

##通用查询日志:记录建立的客户端连接和执行的语句
##慢查询日志:记录所有执行时间超过long_query_time值的所有查询或者不使用索引的查询
##查看数据库版本
SHOW VARIABLES LIKE '%version%';
##查看通用查询日志
SHOW VARIABLES LIKE '%general%';
##设置通用查询日志为开启
SET GLOBAL general_log=ON;
##设置通用查询日志为关闭
SET GLOBAL general_log=OFF;
##查看当前慢查询日志输出的格式,可以是FILE(存储在数数据库的数据文件中的hostname.log),也可以是TABLE(存储在数据库中的mysql.general_log)
SHOW VARIABLES LIKE '%log_output%';
##设置查询日志输出到文件
SET GLOBAL log_output='file';
##设置慢查询日志保存的文件
SET GLOBAL slow_query_log_file="/var/lib/mysql/localhost-slow.log";
##查看慢查询相关设置
SHOW VARIABLES LIKE '%slow_query%';
##设置慢查询阈值为1,默认为10
SET GLOBAL long_query_time=1;
##设置慢查询阈值为10,默认为10
SET GLOBAL long_query_time=10;
##查看慢查询的阈值
SHOW GLOBAL VARIABLES LIKE '%long_query_time%';
##查看有多少慢查询
SHOW GLOBAL STATUS LIKE '%Slow_queries%';
##睡眠11秒,测试慢查询
##select SLEEP(11);
posted @ 2018-10-09 16:59 筱 筱 阅读(174) | 评论 (0)编辑 收藏

velocity properties加载时是放在HashMap中的,首先会加载configLocation中指定文件的内容,然后加载VelocityConfigurer中通过velocityProperties配置的属性,
因此,在VelocityConfigurer中配置的属性会覆盖configLocation指定文件中的属性
posted @ 2014-08-22 11:03 筱 筱 阅读(5884) | 评论 (0)编辑 收藏

1、达到默认最大buffer size
2、调用HttpServletResponse.flushBuffer()
3、调用HttpServletResponse.getOutputStream().flush()或者HttpServletResponse.getWriter().flush()
4、调用HttpServletResponse.sendError()或者HttpServletResponse.sendRedirect()
posted @ 2014-07-23 13:11 筱 筱 阅读(5888) | 评论 (0)编辑 收藏

<plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
          <source>1.7</source>
          <target>1.7</target>
          <encoding>UTF-8</encoding>
          <compilerArguments>
            <extdirs>WebContent/WEB-INF/lib</extdirs>
          </compilerArguments>
          </configuration>
        </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-war-plugin</artifactId>
        <configuration>
          <webXml>WebContent/WEB-INF/web.xml</webXml>
          <warSourceDirectory>WebContent</warSourceDirectory>
        </configuration>
      </plugin>
    </plugins>
posted @ 2013-11-01 17:03 筱 筱 阅读(6443) | 评论 (1)编辑 收藏

在onPrepareDialog()中添加如下代码:
AlertDialog syncDialog = (AlertDialog) dialog;
Button button = syncDialog.getButton(AlertDialog.BUTTON_POSITIVE);
button.setText("确定");
button.setVisibility(View.VISIBLE);
button.setOnClickListener(new OnClickListener() {
    @Override
    public void onClick(View v) {

    }
});
posted @ 2013-03-01 12:51 筱 筱 阅读(7026) | 评论 (0)编辑 收藏

uml
  1. 类图之间的关系
  2. 依赖和关联关系:
    依赖:是类与类之间的连接,表示一个类依赖于另一个类的定义。例如如果A依赖于B,则B体现为局部变量,方法的参数、或静态方法的调用。 
    关联:类与类之间的联接,它使一个类知道另一个类的属性和方法, 具体表现为类的成员变量中包含某个对象 

    组合和聚合:
    在有整体和部分关系是才有组合和聚合的概念,属于关联关系
    组合:部分离开整体不能存在
    聚合:部分可以离开整体而存在

  3. 用例图之间的关系:
  4. 包含、泛化、扩展
    包含:当两个或多个用例中共用一组相同的动作,这时可以将这组相同的动作抽出来作为一个独立的子用例,供多个基用例所共享。因为子用例被抽出,基用例并非一个完整的用例,所以include关系中的基用例必须和子用例一起使用才够完整,子用例也必然被执行 
    泛化:继承关系,子用例将继承基用例的所有行为 ,也就是说在任何使用基用例的地方都可以用子用例来代替。领导拥有审批的权限,而请假申请审批、加班申请审批都是审批的子类
    扩展:对基用例的扩展,基用例是一个完整的用例,即使没有子用例的参与,也可以完成一个完整的功能。 

posted @ 2012-06-29 11:42 筱 筱 阅读(5758) | 评论 (0)编辑 收藏

学习osworkflow
http://my.so-net.net.tw/idealist/OSWorkflow/
 

wfentry表中的state字段来自于接口WorkflowEntry,有如下几个值:
    public static final int CREATED = 0;
    public static final int ACTIVATED = 1;
    public static final int SUSPENDED = 2;
    public static final int KILLED = 3;
    public static final int COMPLETED = 4;
    public static final int UNKNOWN = -1;


Workflow接口相当于我们service层的接口,而WorkflowStore接口相当于我们DAO层的接口,
我们知道osworkflow提供的Workflow实现(如:BasicWorkflow)有时并不能满足业务的需要,因此我们可以实现自己的Workflow,具体可以参照BasicWorkflow 
继承AbstractWorkflow,接着加入自己想要的方法。同理,我们可以通过继承相应的WorkflowStore(如:HibernateWorkflowStore)来编写自己的方法
posted @ 2012-06-26 14:49 筱 筱 阅读(5720) | 评论 (0)编辑 收藏

1、日期格式化:
    DateFormat
    SimplateDateFormat

2、数字格式化
    NumberFormat
    DecimalFormat

3、字符串格式化:
    MessageFormat 以{0},{1}作为占位符,如果你的pattern中有两个以上的{0},在format时都会用第一个参数替换
    String.format 以%s作为占位符,按传入的参数一一匹配
    
posted @ 2011-09-01 17:39 筱 筱 阅读(3133) | 评论 (0)编辑 收藏

文字:openfire
语音/视频:FMS,red5
posted @ 2011-08-29 13:58 筱 筱 阅读(2748) | 评论 (1)编辑 收藏

在使用svn add 时提示:
A  (bin)  templates/translate/screen/selectTransLang.vm
请看官方文档的解释:

当你第一次添加或者导入文件到Subversion中时,Subversion会检测该文件是否是二进制文件。目前,Subversion的策略是只检测文件的前1024个字节;如果所有字节都是0,或者超过15%都是非ASCII码输出字符的话,那么Subversion就认定该文件是二进制文件。
如果Subversion认定文件是二进制文件,那么这个文件就会自动添加svn:mime-type属性,并设置为“application/octet-stream”。(你随时可以使用auto-props特性来重写这样的行为,或者使用svn propset手动设置属性。)
Subversion对以下的文件做普通文本处理:
1、没有设置svn:mime-type属性的文件
2、文件的svn:mime-type属性值以“text/”开头
3、文件的svn:mime-type属性值等于“image/x-xbitmap”
4、文件的svn:mime-type属性值等于“image/x-xpixmap”

所有其他文件都将被视为二进制文件处理,这意味着Subversion:
1、不会尝试在svn update或者svn merge操作时将远程修改合并到本地中
2、在svn diff中不会显示出不同
3、在svn blame不会每行显示版本和作者信息

在其他方面,Subversion将二进制文件和其他文本文件一样对待
需要注意,不管是不是二进制文件,都不会影响版本库中用来存储文件变更的空间大小,也不会影响客户端和服务端之间的通讯量。出于存储和传输考虑,Subversion使用的是对二进制文件和普通文本文件一致处理的diffing方法;这和‘svn diff’使用的diffing方法完全不相关。

好了,我们来看看刚才加的文件是否为二进制:
进入.svn/props 发现生成文件:selectTransLang.vm.svn-work
内容如下:
K 13
svn:mime-type
V 24
application/octet-stream
END
或者用如下方法
svn propget svn:mime-type selectTransLang.vm
输出:application/octet-stream

解决方法,直接编辑去掉这个属性
svn propedit svn:mime-type selectTransLang.vm
或者删除.svn/props/selectTransLang.vm.svn-work

看看网上其他牛人的解决方法:
修改~/.subversion/config
找到最后一个section,在最后加上如下一行话:
*.txt = svn:mime-type=text/plain;svn:eol-style=native
光这个还不够,向上搜索到这么一行
# enable-auto-props = yes
把前面用来注释这行的那个#和其后的空格去掉

如果用的是TortoiseSVN,开始菜单 -> TortoiseSVN -> Settings -> General,此时右侧有一个名为Edit的按钮,点击之后就可以编辑config了

posted @ 2011-08-04 21:51 筱 筱 阅读(4020) | 评论 (0)编辑 收藏

gson:java对象和json之间相互转换
xsteam:java对象和xml之间相互转换
posted @ 2011-07-15 16:55 筱 筱 阅读(2322) | 评论 (0)编辑 收藏

在页面中显示某字段时,字段值过长会导致页面样式错乱,这时候我们需要对值进行截取,当截取值时会碰到以下问题:
1、如果按字符截取会导致中英文显示的长度不一
2、如果按字节截取可能会导致最后一个中文截成两部分
以下代码是在网上获取并经过改造而成,能够很好的解决上面两个问题
    /**
     * 根据指定字节数截取字符串,当指定处为中文第一个字节时少截取一个字符,当长度大于指定截取长度时,截取后在字符串末尾追加指定字符串<br/>
     * 这里添加了字符串的编码,因为页面的编码不同,字符串所占字节也不同
     *
     * @param str 待截取字符串,如果为null或者"",则立即返回str
     * @param length 需要截取的长度
     * @param endStr 截取后末尾追加的字符串
     * @param charset 待截取字符串的编码
     * @return
     */
    public String subStringByByte(String str, int length, String endStr, String charset) {
        if (str == null || "".equals(str.trim()) || length <= 0) {
            return str;
        }
        try {
            int strlen = str.getBytes(charset).length;// 这里要和页面的编码相关
            if (strlen < length) return str;
            Pattern p = Pattern.compile("^[""u4e00-""u9fa5]$");
            int i = 0, j = 0;
            int sublength = length - ((endStr == null) ? 0 : endStr.getBytes(charset).length);
            for (char c : str.toCharArray()) {
                Matcher m = p.matcher(String.valueOf(c));
                i += m.find() ? 2 : 1;
                ++j;
                if (i == sublength) break;
                if (i > sublength) {
                    --j;
                    break;
                }
            }
            return str.substring(0, j) + endStr;
        } catch (UnsupportedEncodingException e) {
            return str;
        }
    }
posted @ 2010-12-14 10:49 筱 筱 阅读(346) | 评论 (0)编辑 收藏

英文不太好,经常忘记,所以现在写下来:
1,transient:在序列化一个类时,如果类中某个字段不想被序列化,则使用此关键字
2、volatile:用于线程同步时

posted @ 2010-12-13 20:49 筱 筱 阅读(237) | 评论 (0)编辑 收藏

根据分代收集器原理(可以参考垃圾回收机制分类),JVM的内存可分为三个域: 新域、旧域以及永久域
JVM生成的所有新对象放在新域中。一旦对象经历了一定数量的垃圾收集循环后,便进入旧域。而在永久域中是用来存储JVM自己的反射对象的,如class 和method对象,而且GC(Garbage Collection)不会在主程序运行期对永久域进行清理。其中新域和旧域属于堆,永久域是一个独立域并且不认为是堆的一部分
一、java.lang.OutOfMemoryError: PermGen space

PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,
这块内存主要是被 JVM存放Class和Method信息的,Class在被Loader时就会被放到PermGen space中,
它和存放类实例 (Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对
PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误,
这种错误常见在web服务器对 JSP进行pre compile(预编译)的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小
超过了jvm默认的大小(4M)那么就会 产生此错误信息了。
解决方法: 手动设置MaxPermSize大小

修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using CATALINA_BASE:   $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少 jar 文档重复占用内存的目的。

二、java.lang.OutOfMemoryError: Java heap space
Heap size 设置
JVM堆 的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heap size的值,
其初始空间(即 -Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等选项可
进行设 置。Heap size 的大小是Young Generation 和Tenured Generaion 之和(新域和旧域之和)。
提示:在JVM中如果98% 的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。
提示:Heap Size 最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。
解决方法:手动设置 Heap size
修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using CATALINA_BASE:   $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -Xms800m -Xmx800m   -XX:MaxNewSize=256m"


posted @ 2010-08-19 20:39 筱 筱 阅读(239) | 评论 (0)编辑 收藏

动态应用,是相对于网站静态内容而言, 是指以c/c++、php、Java、perl、.net等 服务器端语言开发的网络应用软件,比如论坛、网络相册、交友、BLOG等常见应用。动态应用系统通 常与数据库系统、缓存系统、分布式存储系统等密不可分。

大型动态应用系统平台主要是针对于大流 量、高并发网站建立的底层系统架构。大型网站的运行需要一个可靠、安全、可扩展、易维护的应用系统平台做为支撑,以保证网站应用的平稳运行。

大型动态应用系统又可分为几个子系统:

l         Web前端系统

l         负载均衡系统

l         数据库集群系统

l         缓存系统

l         分布式存储系统

l         分布式服务器管理系统

l         代码分发系统

Web前端系统

结构图:

为了达到不同应用的服务器共享、避免单点故障、集中管理、统一配置等目的,不以应用划分服 务器,而是将所有服务器做统一使用,每台服务器都可以对多个应用提供服务,当某些应用访问量升高时,通过增加服务器节点达到整个服务器集群的性能提高,同 时使他应用也会受益。该Web前端系统基于Apache/Lighttpd/Eginx等 的虚拟主机平台,提供PHP程序运行环境服务器对开发人员是透明的,不需要开发人员介入服务器管理

负载均衡系统


负载均衡系统分为硬件和软件两种。硬件负载均衡效率高,但是价格贵,比如F5等。软件负载均衡系统价格较低或者免费,效率较硬件负载均衡系统 低,不过对于流量一般或稍大些网站来讲也足够使用,比如lvs,nginx。大多数网站都是硬件、软件负载均衡系统并用。

数据库集群系统

结构图:


由于Web前端采用了负载均衡集群结构提高了服务的有效性和扩展性,因此数据库必须也是高可靠的才能保证整个服务体系的高可靠性,如何构建一个高可靠的、可以提供大规模并发处理的数据库体系?

我们可以采用如上图所示的方案:

1)        使用 MySQL 数据库,考虑到Web应用的数据库读多写少的特点,我们主要对读数据库做了优化,提供专用的读数据库和写数据库,在应用程序中实现读操作和写操作分别访问不同的数据库。

2)        使用 MySQL Replication 机制实现快速将主库(写库)的数据库复制到从库(读库)。一个主库对应多个从库,主库数据实时同步到从库。

3)        写数据库有多台,每台都可以提供多个应用共同使用,这样可以解决写库的性能瓶颈问题和单点故障问题。

4)        读数据库有多台,通过负载均衡设备实现负载均衡,从而达到读数据库的高性能、高可靠和高可扩展性。

5)        数据库服务器和应用服务器分离。

6)        从数据库使用BigIP做负载均衡。

缓存系统


缓存分为文件缓存、内存缓存、数据库缓存。在大型Web应用中使用最多且效率最高的是内存缓存。最常用的内存缓存工具是Memcachd。使用正确的缓存系统可以达到实现以下目标:

1、   使用缓存系统可以提高访问效率,提高服务器吞吐能力,改善用户体验。

2、   减轻对数据库及存储集服务器的访问压力

3、Memcached服务器有多台,避免单点故障,提供高可靠性和可扩展性,提高性能。

分布式存储系统

结构图:


WEB系统平台中的存储需求有下面两个特点:

1) 存储量很大,经常会达到单台服务器无法提供的规模,比如相册、视频等应用。因此需要专业的大规模存储系统。

2) 负载均衡cluster中的每个节点都有可能访问任何一个数据对象,每个节点对数据的处理也能被其他节点共享,因此这些节点要操作的数据从逻辑上看只能是一个整体,不是各自独立的数据资源。

因此高性能的分布式存储系统对于大型网站应用来说是非常重要的一环。(这个地方需要加入对某个分布式存储系统的简单介绍。)

分布式服务器管理系统

结构图:


随着网站访问流量的不断增加,大多的网络服务都是以负载均衡集群的方式对外提供服务,随之集群规模的扩大,原来基于单机的服务器管理模式已经不能够满足我们的需求,新的需求必须能够集中式的、分组的、批量的、自动化的对服务器进行管理,能够批量化的执行计划任务。

在分布式服务器管理系统软件中有一些比较优秀的软件,其中比较理想的一个是 Cfengine。它可以对服务器进行分组,不同的分组可以分别定制系统配置文件、计划任务等配置。它是基于C/S 结构的,所有的服务器配置和管理脚本程序都保存在Cfengine Server上,而被管理的服务器运行着 Cfengine Client 程序,Cfengine Client通过SSL加密的连接定期的向服务器端发送请求以获取最新的配置文件和管理命令、脚本程序、补丁安装等任务。

有了Cfengine 这种集中式的服务器管理工具,我们就可以高效的实现大规模的服务器集群管理,被管理服务器和 Cfengine Server 可以分布在任何位置,只要网络可以连通就能实现快速自动化的管理。

代码发布系统

结构图:

随着网站访问流量的不断增加,大多的网络服务都是以负载均衡集群的方式对外提供服务,随之集群规模的扩大,为了满足集群环境下程序代码的批量分发和更新,我们还需要一个程序代码发布系统。

这个发布系统可以帮我们实现下面的目标:

1) 生产环境的服务器以虚拟主机方式提供服务,不需要开发人员介入维护和直接操作,提供发布系统可以实现不需要登陆服务器就能把程序分发到目标服务器。

2) 我们要实现内部开发、内部测试、生产环境测试、生产环境发布的4个开发阶段的管理,发布系统可以介入各个阶段的代码发布。

3) 我们需要实现源代码管理和版本控制,SVN可以实现该需求。

这里面可以使用常用的工具Rsync,通过开发相应的脚本工具实现服务器集群间代码同步分发。

posted @ 2010-08-04 20:24 筱 筱 阅读(198) | 评论 (0)编辑 收藏

管道:"|"
    将一个命令的输出作为下一个命令的输入
    例:ls | grep text            --这个命令将查找当前目录下名称中包含text的目录或者文件
xargs:
    将一个命令的输入作为下一个命令的参数
    例:ls | xargs grep -i text        --这个命令将当前目下的所有文件作为参数传递给grep来查找文件中是否包含"text" 
         find . | xargs grep "user"    --查询当前目录及其子目录下所有内容中包含"user"的文件
posted @ 2010-07-19 00:19 筱 筱 阅读(373) | 评论 (0)编辑 收藏

mysql:select * from 表名 order by rand() limit 10;
sql server:select top 10 * from 表名 order by newid();
oracle:select * from(select * from 表名 order by dbms_random.value) where rownum<=20;
access:select top 10 * from 表名 order by rnd(ID)
posted @ 2010-05-09 22:35 筱 筱 阅读(694) | 评论 (0)编辑 收藏

样式代码如下:
html { filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1); }
需要最新网页标准支持:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
Flash要在object标签中加入如下代码:
<param value="false" name="menu"/>
<param value="opaque" name="wmode"/>
posted @ 2010-04-21 12:19 筱 筱 阅读(226) | 评论 (0)编辑 收藏

1、下载wamp5,安装wamp5,如需更改端口请修改Apache配置文件,更改端口(如:8888)后还需要更改wamp根目录wampmanager.ini文件中的以下地方
    Type: item; Caption: "Localhost"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/"; Glyph: 5
    Type: item; Caption: "phpMyAdmin"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/phpmyadmin/"; Glyph: 5
    Type: item; Caption: "SQLiteManager"; Action: run; FileName: "C:\WINDOWS\explorer.exe"; Parameters: "http://localhost:8888/sqlitemanager/"; Glyph: 5
2、安装后访问首页http://localhost:8888,点击phpinfo()查看php信息,如果只显示如下信息:
    This program makes use of the Zend Scripting Language Engine:
    Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
    查看php目录下的php.ini文件,没有[Zend]块,表明ZendOptimizer没有安装
3、下载ZendOptimizer,安装路径选择D:\Program Files\Zend,选择apache2.x及php.ini的位置,安装完成后php.ini最后会添加以下内容:
    [Zend]
    zend_extension_manager.optimizer_ts="D:\Program Files\Zend\ZendOptimizer-3.3.0\lib\Optimizer-3.3.0"
    zend_extension_ts="D:\Program Files\Zend\ZendOptimizer-3.3.0\lib\ZendExtensionManager.dll"
4、访问http://loalhost:8888/ppframe进行ppframe的安装,安装成功后登陆后台,如果没有安装ZendOptimizer,左侧的exam是打不开的,但是passport可以打开。

posted @ 2010-04-19 15:00 筱 筱 阅读(480) | 评论 (0)编辑 收藏

1、如果页面有<base/>标签的则要在js引入后再添加<base target="_self" />;

2、在<script/>中添加属性defer="defer";

posted @ 2010-03-31 17:28 筱 筱 阅读(382) | 评论 (0)编辑 收藏

比如java向txt文件中写入新的一行时,java获得文本输入框中的新行时等
Unix系统里,每行结尾只有“<换行>”,即“\r”;
Windows系统里面,每行结尾是“<换行><回车>”,即“\r\n”;
Mac系统里,每行结尾是“<回车>”,即“\n”。
一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;
而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。

posted @ 2010-03-31 13:37 筱 筱 阅读(2365) | 评论 (2)编辑 收藏

如果已经配置mysql的环境变量,请直接执行:mysql -u 输入用户名 -p 回车 之后输入密码
如果未配置环境变量请先进入mysql的bin目录下
执行如下语句导入:source 输入sql文件的位置
执行如下语句导出:mysqldump -u输入用户名 -p输入密码 数据库名 表名 >文件名.sql

posted @ 2010-01-19 11:26 筱 筱 阅读(275) | 评论 (0)编辑 收藏

服务端:http://labs.northscale.com/memcached-packages/
客户端:http://code.google.com/p/memcached/wiki/Clients/
posted @ 2009-12-31 10:57 筱 筱 阅读(423) | 评论 (1)编辑 收藏

1、安装jdk --> D:\Program Files\Java\jdk1.5.0
2、配置JAVA_HOME --> D:\Program Files\Java\jdk1.5.0
3、解压tomcat5.5 --> D:\Program Files\Apache Software Foundation\Tomcat 5.5
4、打开cmd,进入到tomcat5.5bin目录 --> D:\Program Files\Apache Software Foundation\Tomcat 5.5\bin>
5、执行命令:service install tomcat
        执行结果为:
            Installing the service 'tomcat' ...
            Using CATALINA_HOME:    D:\Program Files\Apache Software Foundation\Tomcat 5.5
            Using CATALINA_BASE:    D:\Program Files\Apache Software Foundation\Tomcat 5.5
            Using JAVA_HOME:        D:\Program Files\Java\jdk1.5.0
            Using JVM:              D:\Program Files\Java\jdk1.5.0\jre\bin\server\jvm.dll
            The service 'tomcat' has been installed.
        此时产生名为:Apache Tomcat tomcat 的服务
6、卸载命令:service remove tomcat
        执行结果为:
            The service 'tomcat' has been removed

posted @ 2009-12-25 15:12 筱 筱 阅读(667) | 评论 (0)编辑 收藏

@echo off
rem 这段代码的作用是对mysql进行查询操作,并将查询结果写入到result.txt文件中
echo %TIME%
set errorlevel=0
set path_bin_mysql="D:\Program Files\mysql_1\bin\mysql"
set host=localhost
set port=3308
set database_mysql=mysql
set user_mysql=root
set password_mysql=admin
%path_bin_mysql% -u%user_mysql% -p%password_mysql% -h%host% -P%port% %database_mysql%< test.sql >

result.txt
pause

posted @ 2009-11-30 17:17 筱 筱 阅读(353) | 评论 (0)编辑 收藏

千万人同时访问的网站,一般是有很多个数据库同时工作,说明白一点就是数据库集群和并发控制,这样的网站实时性也是相对的。这些网站都有一些共同的特点:数据量大,在线人数多,并发请求多,pageview高,响应速度快。总结了一下各个大网站的架构,主要提高效率及稳定性的几个地方包括:

  1、程序

  程序开发是一方面,系统架构设计(硬件+网络+软件)是另一方面。

  软件架构方面,做网站首先需要很多web服务器存储静态资源,比如图片、视频、静态页等,千万不要把静态资源和应用服务器放在一起。

  一个好的程序员写出来的程序会非常简洁、性能很好,一个初级程序员可能会犯很多低级错误,这也是影响网站性能的原因之一。

  网站要做到效率高,不光是程序员的事情,数据库优化、程序优化这是必须的,在性能优化上要数据库和程序齐头并进!缓存也是两方面同时入手。第一,数据库缓存和数据库优化,这个由dba完成(而且这个有非常大的潜力可挖,只是由于我们都是程序员而忽略了他而已)。第二,程序上的优化,这个非常的有讲究,比如说重要一点就是要规范SQL语句,少用in 多用or,多用preparestatement,另外避免程序冗余如查找数据少用双重循环等。另外选用优秀的开源框架加以支持,我个人认为中后台的支持是最最重要的,可以选取spring+ibatis。因为ibatis直接操作SQL并有缓存机制。spring的好处就不用我多说了,IOC的机制可以避免new对象,这样也节省开销。据我分析,绝大部分的开销就是在NEW的时候和连接数据库时候产生的,请尽量避免。另外可以用一些内存测试工具来做一个demo说明hibernate和ibatis谁更快!前台你想用什么就用什么,struts,webwork都成,如果觉得自己挺牛X可以试试tapestry。

  用数据库也未必不能解决访问量巨大所带来的问题,作成静态文件硬盘的寻址时间也未必少于数据库的搜索时间,当然对资料的索引要下一翻工夫。我自己觉得门户往往也就是当天、热门的资料点击率较高,将其做缓存最多也不过1~2G的数据量吧,举个例子:

拿网易新闻来http://news.163.com/07/0606/09/3GA0D10N00011229.html

  格式化一下,方便理解:http://域名/年/月日/新闻所属分类/新闻ID.html

  可以把当天发布的、热门的、流揽量大的作个缓寸,用hashtable(key:年-月-日-分类-ID,value:新闻对象),静态将其放到内存(速度绝对快过硬盘寻址静态页面)。

通常是采用oracle存储过程+2个weblogic,更新机制也几乎一样每签发一条新闻,就会生成静态页面,然后发往前端的web服务器,前端的web都是做负载均衡的。另外还有定时的程序,每5-15分钟自动生成一次。在发布新闻的同时将数据缓存。当然缓存也不会越来越大,在个特定的时间段(如凌晨)剔除过期的数据。做一个大的网站远没有想象中那么简单,服务器基本就要百十个的。

  这样可以大大增加一台计算机的处理速度,如果一台机器处理不了,可以用httpserver集群来解决问题了。


  2、网络
  中国的网络分南北电信和网通,访问的ip就要区分南北进入不同的网络。


  3、集群
  通常会使用CDN与GSBL与DNS负载均衡技术,每个地区一组前台服务器群,例如:网易,百度使用了DNS负载均衡技术,每个频道一组前台服务器,一搜使用了DNS负载技术,所有频道共用一组前台服务器集群。

  网站使用基于Linux集群的负载均衡,失败恢复,包括应用服务器和数据库服务器,基于linux-ha的服务状态检测及高可用化。

  应用服务器集群可以采用apache+tomcat集群和weblogic集群等;web服务器集群可以用反向代理,也可以用NAT的方式,或者多域名解析都可以;Squid也可以,方法很多,可以根据情况选择。

 4、数据库

  因为是千万人同时访问的网站,所以一般是有很多个数据库同时工作的,说明白一点就是数据库集群和并发控制,数据分布到地理位置不同的数据中心,以免发生断电事故。另外还有一点的是,那些网站的静态化网页并不是真的,而是通过动态网页与静态网页网址交换做出现的假象,这可以用urlrewrite 这样的开源网址映射器实现。这样的网站实时性也是相对的,因为在数据库复制数据的时候有一个过程,一般在技术上可以用到hibernate和 ecache,但是如果要使网站工作地更好,可以使用EJB和websphere,weblogic这样大型的服务器来支持,并且要用oracle这样的大型数据库。

  大型门户网站不建议使用Mysql数据库,除非你对Mysql数据的优化非常熟悉。Mysql数据库服务器的master-slave模式,利用数据库服务器在主从服务器间进行同步,应用只把数据写到主服务器,而读数据时则根据负载选择一台从服务器或者主服务器来读取,将数据按不同策略划分到不同的服务器(组)上,分散数据库压力。

  大型网站要用oracle,数据方面操作尽量多用存储过程,绝对提升性能;同时要让DBA对数据库进行优化,优化后的数据库与没优化的有天壤之别;同时还可以扩展分布式数据库,以后这方面的研究会越来越多;


  5、页面

  从开始就考虑使用虚拟存储/簇文件系统。它能让你大量并行IO访问,而且不需要任何重组就能够增加所需要的磁盘。

  页面数据调用更要认真设计,一些数据查询可以不通过数据库的方式,实时性要求不高的可以使用lucene来实现,即使有实时性的要求也可以用lucene,lucene+compass还是非常优秀的。

  新闻类的网站可以用静态页存储,采用定时更新机制减轻服务器负担;首页每个小模块可以使用oscache缓存,这样不用每次都拉数据。

  前端的基于静态页面缓存的web加速器,主要应用有squid等。squid 将大部分静态资源(图片,js,css等)缓存起来,直接返回给访问者,减少应用服务器的负载网站的静态化网页并不是真的,而是通过动态网页与静态网页网址交换做出现的假象,这可以用urlrewrite这样的开源网址映射器实现,后缀名为htm或者html并不能说明程序生成了静态页面,可能是通过 url重写来实现的,为的只不过是在搜索引擎中提升自己网站的覆盖面积罢了。

  生成静态页面的服务器和www服务器是两组不同的服务器,页面生成后才会到www服务器,一部分数据库并不是关系数据库,这样更适合信息衍生,www、mail服务器、路由器多,主要用负载平衡解决访问瓶颈。

  静态页面的缺点:

  1) 增加了程序的复杂度

  2) 不利于管理资料

  3) 速度不是最快

  4) 伤硬盘

  6、缓存

  从一开始就应该使用缓存,高速缓存是一个更好的地方存储临时数据,比如Web站点上跟踪一个特定用户的会话产生的临时文件,就不再需要记录到数据库里。

  不能用lucene实现的可以用缓存,分布式缓存可以用memcached,如果有钱的话用10来台机器做缓存,> 10G的存储量相信存什么都够了;如果没钱的话可以在页面缓存和数据缓存上下功夫,多用OSCACHE和EHCACHE,SWARMCACHE也可以,不过据说同步性不是很好;

  可以使用Memcache进行缓存,用大内存把这些不变的数据全都缓存起来,而当修改时就通知cache过期,memcache是LJ开发的一款分布式缓存产品,很多大型网站在应用,我们可以把Cache Server与AppServer装在一起。因为Cache Server对CPU消耗不大,而有了Cache Server的支援,App Server对内存要求也不是太高,所以可以和平共处,更有效的利用资源。
posted @ 2009-11-30 16:50 筱 筱 阅读(272) | 评论 (0)编辑 收藏


将response内响应给使用者的内容,使用GZIP压缩的方式回传给浏览器,而IE5和NS6也都有支持Gzip的压缩格式。
这个方法在之前就有人提出过,因为是让网页在输出时经过压缩,可以让传输量变小很多,虽然现在的网络频宽对于用来看网页已经绰绰有余,但是档案大小太大的网页还是会造成一定的影响。
经过Gzip压缩过的网页,档案大小可以到原本压缩前的20%。

package com.jsptw.filter;
import java.io.*;
import java.util.zip.GZIPOutputStream;
import javax.servlet.*;
import javax.servlet.http.*;
public class GZIPEncodeFilter implements Filter {
      public void init(FilterConfig filterConfig) {}
      public void doFilter( ServletRequest request, ServletResponse response, FilterChain chain)
                                      throws IOException, ServletException {       
        String transferEncoding = getGZIPEncoding((HttpServletRequest)request);       
        if (transferEncoding == null) {           
          chain.doFilter(request, response);       
        } else{         
          ((HttpServletResponse)response).setHeader("Content-Encoding", transferEncoding);
            GZIPEncodableResponse wrappedResponse = new GZIPEncodableResponse((HttpServletResponse)response);
            chain.doFilter(request, wrappedResponse);         
            wrappedResponse.flush();       
        }   
      }   
      public void destroy() {}   
      private static String getGZIPEncoding(HttpServletRequest request) {       
        String acceptEncoding = request.getHeader("Accept-Encoding");       
          if (acceptEncoding == null)
            return null;       
          acceptEncoding = acceptEncoding.toLowerCase();       
          if (acceptEncoding.indexOf("x-gzip") >= 0) {
            return "x-gzip";
          }       
          if (acceptEncoding.indexOf("gzip") >= 0) {           
            return "gzip";       
          }       
          return null;   
      }   
     
      private class GZIPEncodableResponse extends HttpServletResponseWrapper {       
        private GZIPServletStream wrappedOut;       
          public GZIPEncodableResponse(HttpServletResponse response) throws IOException {          
            super(response);           
              wrappedOut = new GZIPServletStream(response.getOutputStream());       
          }       
          public ServletOutputStream getOutputStream() throws IOException {           
            return wrappedOut;       
          }       
          private PrintWriter wrappedWriter;       
          public PrintWriter getWriter() throws IOException {           
            if (wrappedWriter == null) {               
                wrappedWriter = new PrintWriter( new OutputStreamWriter( getOutputStream(), getCharacterEncoding()));            }           
                 return wrappedWriter;       
              }       
          public void flush() throws IOException {           
            if (wrappedWriter != null) {              
                wrappedWriter.flush();           
              }          
              wrappedOut.finish();       
          }   
      }   
     
      private class GZIPServletStream extends ServletOutputStream {       
        private GZIPOutputStream outputStream;       
          public GZIPServletStream(OutputStream source) throws IOException {           
         outputStream = new GZIPOutputStream(source);       
       }       
       public void finish() throws IOException {
         OutputStream.finish();       
       }       
      public void write(byte[] buf) throws IOException {           
        outputStream.write(buf);       
      }       
      public void write(byte[] buf, int off, int len) throws IOException {           
        outputStream.write(buf, off, len);       
      }       
      public void write(int c) throws IOException {           
        outputStream.write(c);       
      }       
      public void flush() throws IOException {           
        outputStream.flush();       
      }      
      public void close() throws IOException {           
        outputStream.close();        
      }   
    }
}


web.xml中的设定为:
<filter>       
<filter-name>GZIPEncoder</filter-name>       
<filter-class>com.jsptw.filter.GZIPEncodeFilter</filter-class>
</filter>

<filter-mapping> 
<filter-name> GZIPEncoder</filter-name> 
<url-pattern>/*</url-pattern>
</filter-mapping> 

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/a_heng/archive/2009/09/22/4579979.aspx

posted @ 2009-11-30 16:26 筱 筱 阅读(287) | 评论 (0)编辑 收藏

一 简单加密(不可逆):
        MD5(信息摘要算法,Message Digest),SHA(安全散列算法,Secure Hash,Algorithm)、HMAC(散列消息鉴别码,Hash Message Authentication Code)

二 复杂算法:
        1、对称加密:加密解密使用相同的密钥:DES(Data Encryption Standard,数据加密算法) 、IDEA、RC2、RC4、SKIPJACK
        2、非对称加密:分为公开密钥(publickey)和私有密钥(privatekey),且公开密钥与私有密钥是一对。非对称加密算法实现机密信息交换的基本过程是:甲方生成一对密钥并将其中的一把作为公用密钥向其它方公开;得到该公用密钥的乙方使用该密钥对机密信息进行加密后再发送给甲方;甲方再用自己保存的另一把专用密钥对加密后的信息进行解密。甲方只能用其专用密钥解密由其公用密钥加密后的任何信息。非对称加密算法的保密性比较好,它消除了最终用户交换密钥的需要,但加密和解密花费时间长、速度慢,它不适合于对文件加密而只适用于对少量数据进行加密。经典的非对称加密算法如RSA(三个人名:Ron Rivest, AdiShamir 和Leonard Adleman)算法等安全性都相当高。

posted @ 2009-11-05 11:30 筱 筱 阅读(191) | 评论 (0)编辑 收藏

Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。

      1.INSERT INTO SELECT语句

      语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1

      要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:

select into与insert into select - xiaolei_funny - 一叶知秋 的博客select into与insert into select - xiaolei_funny - 一叶知秋 的博客INSERT INTO SELECT语句复制表数据

   --1.创建测试表

    create TABLE Table1

    (

        a varchar(10),

        b varchar(10),

        c varchar(10),

        CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED

        (

            a ASC

        )

    ) ON [PRIMARY]

    create TABLE Table2

    (

        a varchar(10),

        c varchar(10),

        d int,

        CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED

        (

            a ASC

        )

    ) ON [PRIMARY]

    GO

    --2.创建测试数据

    Insert into Table1 values('赵','asds','90')

    Insert into Table1 values('钱','asds','100')

    Insert into Table1 values('孙','asds','80')

    Insert into Table1 values('李','asds',null)

    GO

    select * from Table2

    --3.INSERT INTO SELECT语句复制表数据

    Insert into Table2(a, c, d) select a,c,5 from Table1

    GO

    --4.显示更新后的结果

    select * from Table2

    GO

    --5.删除测试表

    drop TABLE Table1

    drop TABLE Table2

      2.SELECT INTO FROM语句

      语句形式为:SELECT vale1, value2 into Table2 from Table1

      要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:

select into与insert into select - xiaolei_funny - 一叶知秋 的博客select into与insert into select - xiaolei_funny - 一叶知秋 的博客SELECT INTO FROM创建表并复制表数据

   --1.创建测试表

    create TABLE Table1

    (

        a varchar(10),

        b varchar(10),

        c varchar(10),

        CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED

        (

            a ASC

        )

    ) ON [PRIMARY]

    GO

    --2.创建测试数据

    Insert into Table1 values('赵','asds','90')

    Insert into Table1 values('钱','asds','100')

    Insert into Table1 values('孙','asds','80')

    Insert into Table1 values('李','asds',null)

    GO

    --3.SELECT INTO FROM语句创建表Table2并复制数据

    select a,c INTO Table2 from Table1

    GO

    --4.显示更新后的结果

    select * from Table2

    GO

    --5.删除测试表

    drop TABLE Table1

    drop TABLE Table2

posted @ 2009-11-04 13:21 筱 筱 阅读(471) | 评论 (0)编辑 收藏