随笔-75  评论-193  文章-5  trackbacks-0
  2013年1月28日
var fixgeometry = function() {
    /* some orientation changes leave the scroll position at something
     * that isn't 0,0. this is annoying for user experience. */
    scroll(0, 0);
    /* calculate the geometry that our content area should take */
    var header = $(".header:visible");
    var footer = $(".footer:visible");
    var content = $(".content:visible");
    var viewport_height = $(window).height();
    
    var content_height = viewport_height - header.outerheight() - footer.outerheight();
    
    /* trim margin/border/padding height */
    content_height -= (content.outerheight() - content.height());
    content.height(content_height);
  }; /* fixgeometry */
  $(document).ready(function() {
    $(window).bind("orientationchange resize pageshow", fixgeometry);
  });
posted @ the matrix 阅读(5153) | |  
  2012年5月14日
 
posted @ the matrix 阅读(1188) | |  
  2012年4月4日
环境:
    
    centos6.2(安装在vmware7.0中)
    magento1.6.2
    apache httpd server 2.2.15
    mysql 5.1.61
    php5.3.3

安装过程:

    apache http、mysql、php及相关扩展安装:
    其中apache http、mysql、php都是利用centos的添加/删除软件功能进行安装。同时使用该功能安装"php-xml"、"php-gd"、"php-pdo"、"php-mbstring"、"php-mysql"扩展。
    使用chkconfig配置httpd和mysql为系统服务。命令如下:
    chkconfig httpd on
    chkconfig -add mysqld
    chkconfig mysqld on
    使用chkconfig --list 可以查看所有的服务配置状态
    使用service httpd start、service mysqld start启动httpd和mysqld服务。可以通过service httpd restart重启相关服务。
    此时访问本机的http://localhost可以看到apache的欢迎界面,同时编辑index.php文件,其内容如下:
   
        phpinfo();
    ?>
    并将该文件置于/var/www/html目录下,访问http://localhost/index.php,此时应该不能看到php版本信息,仅能看到index.php的静态文本内容。
    修改/etc/httpd/conf/httpd.conf文件,修改如下:
    directoryindex index.html index.html.var ->  directoryindex index.html index.htm index.php
    增加:
    addtype application/x-httpd-php .php
    adddefaultcharset -> adddefaultcharset off  (解决中文乱码问题)
    增加一段virtualhost描述,如下(在配置文件的最后):
   
        documentroot /var/www/smallfive
        servername smallfive
        serveralias smallfive.com *.smallfive.com
   
    此时访问http://localhost/index.php,应该一切正常

    设置数据库:
    使用mysqladmin -u root password 'newpassword'设置mysql数据库的默认密码
    让数据库更安全:
    mysql -u root -p    进入mysql
    mysql> drop database test;                删除test数据库
    mysql> delete from mysql.user where user = '';       删除匿名帐户
    mysql> flush privileges;                 重载权限
    创建magento数据库
    mysql> cr   访问magento数据库,确保一切正常

    配置magento:
    解压缩magento1.6.2版本至/var/www/smallfive/magento目录
    解压命令:
   eate database magento;
    mysql> grant all privileges on magento.* to 'root'@'localhost' identified by 'newpassword'; 
  tar zxvf magento1.6.2.tar.gz
    此时访问http://localhost/magento,可根据magento的设置进行配置
   
    注意如下问题:
    1、确保当前用户拥有对/var/www/smallfive/magento可读可写权限
    2、还需安装mcrypt库,安装这个库比较繁琐,mcrypt依赖于libmcrypt库和mhash库,我们需要下载libmcrypt库和mhash库安装它们,然后再编译mcrypt。
    在编译之前,先做好如下准备工作:
        a、安装phpize:yum -y install php-devel
        b、安装c 脚本编译模块:
            yum -y install gcc gcc-g
            yum -y install gcc gcc-c
    安装mcrypt库过程,如下:
        a、下载libmcrypt和mhash库
            libmcrypt:http://sourceforge.net/project/showfiles.php?group_id=87941&package_id=91774&release_id=487459
            mhash:http://sourceforge.net/project/showfiles.php?group_id=4286&package_id=4300&release_id=645636
        b、将上述两个下载后,分别解压,并执行如下命令编译:
            ./configure
            make && make install
        c、下载php对应的源代码,解压,
            进入php源代码的 /ext/mcrypt目录
            执行phpize命令
            ./configure –with-php-config=/usr/bin/php-config
            make && make install
        d、在php.ini文件中增加如下内容:
            extension=/usr/lib/php/modules/mcrypt.so
            mcrypt.so文件路径在php-config文件中可以找到
        e、service httpd restart
   
    end!
     
    参考文章:
    http://www.eexu.com/article.asp?id=1730
    http://www.ruiwant.com/centos-6-0下magento环境配置总结.html
    http://zixun.www.net.cn/qita/2344.html
    http://os.qudong.com/linux/2010/0210/64441.html
posted @ the matrix 阅读(3107) | |  
  2012年3月2日
有时在vmware里面安装的系统或应用有license时间的限制,可以通过修改虚拟机时间的方法来防止过期,此时需在.vmx文件中加入下面的内容:
tools.synctime = "false"
time.synchronize.continue = "false"
time.synchronize.restore = "false"
time.synchronize.resume.disk = "false"
time.synchronize.shrink = "false"
rtc.starttime = 1183431600  #这是用来指定虚拟机启动后的时间。数字是自1970年1月1日零时零分零秒以来的秒数,可以通过如下网址将某个时间转换为该数字(unix时间戳):注意:同时还需在虚拟机操作系统的服务中,停用“vmware tools service”的服务。
在windows server 2003中操作系统自身也有时间同步功能,需在时间设定中停用,同时停用“windows timer”服务。
posted @ the matrix 阅读(8616) | |  
  2011年11月27日
主要参见:在安装好apache http server后,如果端口不正确,则修改"apache安装目录/conf/httpd.conf"文件中的如下信息:
listen 80  -> listen 8060
#servername localhost:80 -> servername localhost:8060

apache http server版本:2.2
php版本:5.3.8
wordpress版本:3.2.1
posted @ the matrix 阅读(629) | |  
  2011年5月31日

1. 打开工具oracle sql plus 以dba身份登录sys用户
sqlplus /nolog
conn sys@url as sysdba

2. 创建用户并指定表空间

使用客户端工具或者web管理控制台创建表空间以及用户
给用户赋予connect、resource、dba权限
grant connect,resource,dba to username;


注意:给oracle用户分配connect、resource角色时,此时connect 角色中有一个 unlimited tablespace 权限,也就是username这个用户可以在其他表空间里随意建表。
revoke unlimited tablespce from username;     --撤销username用户在任意表空间建表的权限
alter user username quota 0 on users;      --alter username quota 0 on users;  // 还不是很清楚具体含义???
alter user username quota unlimited on tablespacename;   --赋予username用户在tablespacename表空间任意建表的权限;

 


3. 使用imp工具导入dmp数据文件
imp usernameurl file=c:\db.dmp fromuser=username1 touser=username log=c:\log.txt


-------------------------------------------------------------------------------------------------------------
其它命令:
select * from dba_users;    --查询用户

select * from dba_tables;    --查询表
select * from dba_views;    --查询视图
select * from dba_tablespaces;    --查询表空间


oracle 10g,查询表空间使用率
select * from sys.dba_tablespace_usage_metrics;
-------------------------------------------------------------------------------------------------------------

drop user username cascade;

ora-01940:无法删除当前已连接的用户

select username, sid, serial# from v$session where username='username';

alter system kill session'sid,serial#'

 

posted @ the matrix 阅读(3873) | |  
  2011年5月20日
环境:windows7 professional

1、下载redmine1.1.3.zip、ruby1.8.7、rubygems-1.3.7.zip、mysql 5.0

2、安装mysql5.0,cmd窗口下使用mysql -u root -p 登录mysql数据库,执行如下语句创建redmine数据库及用户:
create database redmine character set utf8;
create user 'redmine'@'localhost' identified by 'my_password';
grant all privileges on redmine.* to 'redmine'@'localhost';
注:
    使用mysql5.5在后面进行初始数据时ruby会提示连接有问题
    在安装完mysql后,先不要进行配置,至“mysql安装路径\bin”目录下,修改mysqlinstanceconfig.exe为“以管理员成分执行此程序”,“以兼容模式运行该程序”
    进行数据库配置时,选择字符集为utf8

3、运行ruby1.8.7安装包,解压至d:/ruby187,将d:/ruby187/bin添加至path环境变量中
安装后可执行 ruby -v查看ruby版本以检验安装是否正确

4、解压rubygems-1.3.7.zip至d:/rubygems-1.3.7
进入d:/rubygems-1.3.7目录,执行ruby setup.rb
注:redmine需要rubygems 1.3.1 - 1.5.x,肯定不能用1.8.2版本

5、执行gem install rails -v=2.3.5 远程安装rails2.3.5版本
gem install mysql
gem install -v=0.4.2 i18n

6、解压缩redmine1.1.3至d:/redmine1.1.3目录
进入d:/redmine-1.1.3/config目录,修改database.yml.example文件为database.yml,并修改该文件中的production数据库连接配置为如下:
production:
  adapter: mysql
  database: redmine
  host: localhost
  username: redmine
  password: my_password
  encoding: utf8

进入d:/redmine1.1.3目录,执行
rake config/initializers/session_store.rb
rake db:migrate rails_env="production"

7、加载默认配置数据
rake redmine:load_default_data rails_env="production"
默认语言选择"zh"

8、运行
ruby script/server webrick -e production

9、访问:http://localhost:3000
使用admin/admin进行登入
进入设置,把默认语言设为“简体中文”,然后设置当前用户的默认语言设为“简体中文”,这样就是中文界面了

-----------------------------------------

继续,将redmine设置为windows 7的服务

1、首先需要配置mysql为windows 7的服务

2、ruby提供一个安装ruby程序为服务的包:mongrel_service。安装其实很简单,运行:gem install mongrel_service

3、安装redmine为服务,执行mongrel_rails service::install -n redmine -c c:\redmine-1.1.3 -p 3000 –e production
注意:此处打开cmd窗口时,需要输入cmd后,不是直接按enter,而是按 ctrl shift enter打开cmd窗口,此时以管理员身份打开,否则安装为服务时会提示拒绝访问。

4、安装服务后,需检查服务-e后的参数是不是production,如果不是production而是development,则在注册表中把参数手动改为production。修改方法是:打开“注册表编辑器”,展开分支“hkey_local_machine\system\currentcontrolset\services”,选择redmine服务,找到imagepath项,修改保存后在服务列表中启动服务,并把服务设置自动启动。

ok!
posted @ the matrix 阅读(2765) | |  
  2011年3月25日
参见如下链接:
posted @ the matrix 阅读(1181) | |  
  2010年11月9日
没仔细研究,先把项目地址记下:

这个博客中另有几个推荐的类似项目:
posted @ the matrix 阅读(1259) | |  
  2010年4月14日

这几天在看郎咸平的《谁在谋杀中国经济》,这本书我基本看过一遍了,认为全书的重点在于中华文化的四大茫然,整本书都是围绕这四大茫然展开论述,中华文化的四大茫然如下:
茫然之一:就知道赚钱
茫然之二:不了解世界
茫然之三:不了解别人为什么那么看你
茫然之四:不了解自己的缺点

大家有时间可以看看这本书,我觉得写的不错,至少我自己看完深有感触,我觉得完全可以将这几点套用到我们生活的很多方面,比如对于我们搞it的技术人员来说,我认为现在很多人也存在四大茫然:

茫然之一:只知道完成任务。也许是我年龄大了点,但我觉得现在很多小朋友,尤其是85年以后出生的,工作的时候只是在完成任务,事情做完了,有时也不测试,或者就是匆匆测试,匆匆结束,并没有好好的想为什么这件事老大要让我这样做,这样做有什么好处,会不会有缺点,我是不是有更好的方法。当你不去想的时候,意味着你少了很多提高的机会。

茫然之二:不追究为什么。很多人做事情就象第一条说的那样,只是完成任务,并不去想其中的原理是什么。面试过很多人,对于目前工作两三年的大部分人来说(当然我面试的不是好的学校毕业的,基本学校为中等偏下点),一旦涉及到spring、hibernate、struts等框架深入点东西的时候,大都回答不上来,只是对框架能熟练应用而已。这样够么?计算机的很多知识,当你熟悉了其运作原理,框架对于你来说,只是手到擒来,看看学学就会用了。我问过好几个同事,平时晚上回去都干嘛,很多人都回答我晚上回去看看电视,稍微看看书就睡觉了。我有点惊讶,我想如果你想成为一个技术高手,一个能拿高薪的程序员,你又没有天份,又不付出超过常人的努力,凭什么你比别人强呢?

茫然之三:不善于总结。很多人(又是很多人)过着做一天和尚撞一天钟的日子,日子一天一天过去,基本不去总结,只是过了好长一段时间会发觉,原来最近我啥也没有进步,啥也没学到,还是老样子。知识在于积累,你只有不断总结,知识才能更好的积累,才能更好的为你服务。

茫然之四:没有明确的目标。一个人没有目标就决定了他不会有长足的进步。你都没有想过自己要成为一个架构师,一个项目经理,一个部门经理,一个技术总监,都没有想过要成为这样的人需要具备什么样的条件,你怎么可能知道自己欠缺什么?需要补充什么呢?长远目标要明确,然后根据长远目标进行分析,我要达到这样的目标,还有什么欠缺,据此制定短期目标,短期目标一定要可实现可操作。这样随着你目标的一步一步实现,你各方面的能力也随之提高了。

写了几点,也作为对自己的鞭策。

posted @ the matrix 阅读(6112) | |  
  2010年2月3日

2010年已经过去一个月了,赶在农历春节前列一下今年的读书清单,不能总把精力放在工作中了,也需要补充点新知识了,否则没有新东西能贡献出来了。

1、《osgi原理与最佳实践》,结合这本书并研究springdm,做一些实例。

2、《sql语言艺术》

3、《oracle9i&10g编程艺术》

4、《架构之美》

5、《uml和模式应用》

6、《uml彩色建模》

7、《领域驱动设计与模式实战》

8、《敏捷软件开发 原则、模式与实践》

9、《软件开发的边界》

10、《软件随想录》

11、《走出软件作坊》

就这么多了,9、10、11去年都看过一遍了,但好多地方粗粗过了一下,还要仔细阅读。

另外也对自己提个要求,看书要做读书笔记。

2010年-我的读书年!

posted @ the matrix 阅读(2747) | |  
  2010年1月5日

摘自《软件随想录》

看了软件随想录中下面一段话,觉得非常棒,作为一名软件从业人员,不一定有机会能实现描述中的优秀软件产品,但这样的理念需要贯穿我们每个人的心田,时刻记在心中:

【创造一个有使用价值的软件,你必须时时刻刻都在奋斗,每一次的修补,每一个功能,每一处小小的改进,你都在奋斗,目的只是为了再多创造一点空间,可以再多吸引一个用户加入。没有捷径可走。你需要一点运气,但是这不取决于你是否幸运。你之所以会有好运气,那是因为你寸土必争。

每天你前进一小步,将一件东西做得比昨天好一点点。这样的改进几乎看不出可以让谁获益,几乎没有变化。但是,你前进了一小步。

有无数个要做的这样微小的改进。

为了发现可以改进的地方。你必须有一个思维定势,始终如一的用批判的眼光看世界。随便找一样东西,如果你看不出它的缺点,那么你的思维转型还没有成功。当你成功的时候,你身边亲密的人会被你逼得发疯。你的家人恨不得杀了你。当你步行上班的时候,看到一个司机漫不经心地开车,你几乎用了所有的意志力才勉强忍不住冲上去告诉那个司机,他这样开车差点儿要了旁边坐在轮椅上的那个可怜小孩的命。

当你改正了一个又一个这样的小细节后,当你磨光、定型、擦亮、修饰你的产品的每一个小边角后,就会有神奇的事情发生。厘米变成分米,分米变成米,米变成了千米。你最后拿出来的是一件真正优秀的产品。它第一眼就让人觉得震撼,出类拔萃,工作起来完全符合直觉。就算100万个用户中有一个用户某天突然要用到一个他100万次使用中才会用到一次的罕见功能,他发现了这个功能不仅能用,而且还很没:在你的软件中,即使是看门人的小屋都铺着大理石的地板,配有实心的橡木门和桃花心木的壁板。

就是在这个时候,你意识到这是一个优秀软件。】

posted @ the matrix 阅读(2258) | |  
  2009年11月25日


posted @ the matrix 阅读(571) | |  
  2009年11月11日

在flash builder 4 beta 2版本中,使用mxml方式实现state的切换有了很大改进,使用起来更方便,具体可参见下文:

看完这篇文章后,想到一个问题,如何用编程的方式实现切换呢,找了参考资料,实现了一个例子,代码如下:

开发环境:flash builder 4 beta2

xml version="1.0" encoding="utf-8"?>
<s:application
    
xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:s
="library://ns.adobe.com/flex/spark"
    creationcomplete
="creationcompletehandler(event)">
    
<fx:script>
        

            import mx.core.uicomponent;
            import mx.events.flexevent;
            import mx.states.setproperty;
            import mx.states.state;
            
            import spark.components.label;
            import spark.components.panel;

            private var statearray : array;
            private var state1 : state;
            private var state2 : state;
            
            protected function creationcompletehandler(event:flexevent):void
            {
                state1 = new state();
                state1.name="state1";
                
                state2 = new state();
                state2.name="state2";
                
                var statearray1:array = new array();
                var statearray2:array = new array();
                
                state1.overrides = statearray1;
                state2.overrides = statearray2;
                
                statearray = new array();
                statearray.push(state1);
                statearray.push(state2);
                this.states = statearray;
                
                var panel:panel = new panel();
                group.addelement(panel);
                var label:label = new label();
                panel.addelement(label);
                
                buildstates(statearray1, statearray2, panel, label);
                this.currentstate = "state1";
            }

            private function buildstates(statearray1:array, statearray2:array,
                compenent1:uicomponent, compenent2:uicomponent) : void{
                
                statearray1.push(makesetprop(compenent1, "title", "panel1"));            
                statearray1.push(makesetprop(compenent2, "text", "one"));
                
                statearray2.push(makesetprop(compenent1, "title", "panel2"));
                statearray2.push(makesetprop(compenent2, "text", "two"));
            }
            
            private function makesetprop(target:uicomponent, name:string, value:*):setproperty{
                var sp:setproperty = new setproperty();
                sp.target = target;
                sp.name = name;
                sp.value = value;
                return sp;
            } 
        
]]>
    
fx:script>
        
    
<s:vgroup autolayout="true" horizontalalign="center">
        
<s:hgroup horizontalcenter="0">            
            
<s:button label="one" 
                click
="this.currentstate='state1'"/>            
            
<s:button label="two" 
                click
="this.currentstate='state2'"/>            
        
s:hgroup>
        
<s:hgroup id="group" horizontalcenter="0">            
        
s:hgroup>
    
s:vgroup>
    
s:application>
posted @ the matrix 阅读(1600) | |  
  2009年10月22日

    这是前几天在别人的blog上看到的一幅图,觉得不错,基本涵盖了it人员需要掌握的基础知识这块,从这幅图中可以看出语言并不重要,关键是要搞明白整个环节,这样遇到任何问题就能有目的、有方法的学习了。

posted @ the matrix 阅读(943) | |  
  2009年7月19日

1、下载ruby并安装,下载地址:

下载了1.8.6-27 release candidate 2(ruby186-27_rc2.exe)版本

2、在windows的命令行下,输入 ruby –v,检查ruby是否正确安装,应该出现如下信息:

ruby 1.8.6 (2008-08-11 patchlevel 287) [i386-mswin32]

3、安装rails,执行gem install rails命令,安装成功后,执行rails -v检查。

我安装了rails2.3.2版本。使用gem install -version rails可以指定安装的rails版本,具体如何使用gem,可以用gem help install查看帮助。

 

参考:ruby on rails(ror)安装()

 

装好了便到ruby on rails的官方网站(),找到了

getting started with rails()

开始一步一步follow up。

rubyonrails的中文站上的翻译文档没有完全跟进,还是看英文的吧。

 

我使用的是mysql的数据库,操作系统:vista。

到创建posts应用的时候遇到了问题,创建数据后数据库中有数据,但是到listing posts界面无法查看,总是报错。

网上google了一下,果然有人遇到相同的问题,参照了如下凯发天生赢家一触即发官网的解决方案,到

上下载了libmysql.dll文件放到ruby_home/bin/目录下,问题解决。

参考:升级2.2后mysql驱动的问题()

 

感叹一下,当listing posts这个crud小应用跑起来后,觉得ruby on rails的开发是比java开发要快一些,看了一下它生成的代码,貌似也不多。

 

今天晚了,明天继续。

posted @ the matrix 阅读(1781) | |  
  2009年7月6日

    最近在做一个很小的项目的功能改进,小小的项目中原来连接的是mysql数据库,现在需要新连接一个数据库(oracle),仅仅从一张表查询数据即可,没有添加、修改、删除等等功能。本来这个小小的项目中用的是hibernate,现在又要增加一个数据库连接,觉得配置起来有点麻烦,忽然想起来,我干吗还要用hibernate呢,直接用jdbc不也挺好使么,想了便做,果然写起jdbc来,很是快捷,一会就搞好了。

    做好了以后,忽然觉得有点迷茫,感觉不用hibernate不也挺好的么,咱为什么现在开口闭口都是hibernate呢,于是便有了今天的题目。

    很久以前没有hibernate的时候:

    第一阶段:我们写程序都是直接用jdbc,甚至在jsp页面中直接去createconnection,然后执行查询,输出到页面。

    第二阶段:后来觉得每次都是创建一个连接,好像效率不高,于是看了别人的介绍,要用数据库连接池,好的,那便用数据库连接池吧,每次都从pool中获得一个connection,然后查询数据。

    第三阶段:用了连接池,还是效率不高,那怎么办呢?用缓存吧,自己实现缓存?可以,也可以用开源的缓存框架。

    第四阶段:到了oo大流行的时代了,一切都要oo,恰逢hibernate降临人世,于是一切都用hibernate来实现了,其实同期还是有不少其它ormap框架的,比如(toplink、jdo、ibatis等,ibatis国内用的还比较多,另外两个好像用的比较少)。

    第五阶段:忽然ejb大流行,事务的概念被广为传播(并不是原来没有事务的概念,只是实现起来比较麻烦),借助ejb的广为传播,spring hibernate的组合也慢慢占据了大半市场。此时事务用spring aop的声明式事务来解决,缓存可以用开源的缓存框架(已经和hibernate无缝集成了),数据库连接池也是通过配置的方式在springcontext.xml文件中配置,貌似一切都很完美。

 

    真的到了第五阶段,一切是不是真的完美了呢,如果一个很小的应用,需要从好几个数据库查询数据,但是每个数据库仅需要查询那么一两张表的数据,偶尔添加、删除几条数据,数据量也不大,此时我们是不是还用第一阶段的方式会更好呢,好像有时配置多数据源也不是那么方便的事情。或者使用spring中的jdbctemplate,貌似也不错。

    再往后看,难道spring hibernate的组合就天下无敌了么?难道就没有新的框架了么?前段时间,javaeye上关于充血模型、贫血模型的讨论吸引了多少眼球,以后是不是会有这么一个框架用于实现充血模型呢?

   说了这么多,最终只是想说明白这么一句:用恰当的技术做恰当的事情,这真是一个艰难的选择……,至于未来,更是迷茫,因为我们只是跟随者,而不是领导者。

posted @ the matrix|  
  2009年4月19日

前两天出差在外,利用空余时间将《深入浅出ext js》这本书的前五章翻了一遍,后面的章节粗粗浏览了一下,觉得这本书写的不错,写下自己的一点感悟:

1、适合的读者

a、是一名java开发程序员,做过web开发

b、对ajax开发的基础知识有所了解

2、书评:

        这本书我觉得应该改成这个名字:《ext js cookbook》,可能使得书的内容和名称更贴切,呵呵。

        书中对ext js的基础类、grid、form、tree、布局管理器、数据获取等各方面都做了详细的描述,基本上开发中需要用到的知识点,在书中都会提到,而且书中的很多例子和实际工作还是非常贴切的,对于工作中需要用到ext js或者需要学习ext js的程序员来说还是会很有帮助的。

        最后提点缺点,这本书中对ext js的知识点都做了比较详细的描述,但是缺乏对ext js的框架的深入分析。

posted @ the matrix 阅读(2380) | |  
  2009年4月12日

前两天在infoq上看到一篇文章:,今天下载了说明文档粗略了翻了一遍,clear toolkit包含五个部分,分别是:

  • clear data builder,这是个eclipse插件,可以根据sql语句或java数据传输对象为blazeds或lcds自动生成crud应用。
  • dto2fx,该插件会根据java类型自动生成对应的actionscript类。
  • log4fx是个构建于flex logging api之上的eclipse插件,它会自动化日志处理并且更加灵活,也更加友好。
  • fx2ant插件会为flex builder项目生成优化的ant构建脚本。
  • clear.swc是个增强的flex组件库。

暂时用不到这个工具,记录留待备查。

posted @ the matrix 阅读(651) | |  
  2009年4月7日

这篇blog是原来写在别的地方的,今天将其转到blogjava上来。
-------------------------------------------------------------------------------

今天仔仔细细的看了一下hibernate的缓存,并做了实例实践了一把。google一下,网上的教程、文章很多。
自己小结一下:

hibernate的缓存分为:

  • 一级缓存:在session级别的,在session关闭的时候,一级缓存就失效了。
  • 二级缓存:在sessionfactory级别的,它可以使用不同的缓存实现,如ehcache、jbosscache、oscache等。

缓存的注释写法如下,加在entity的java类上:

  • @cache(usage = cacheconcurrencystrategy.nonstrict_read_write)

缓存的方式有四种,分别为:

  • cacheconcurrencystrategy.none
  • cacheconcurrencystrategy.read_only,只读模式,在此模式下,如果对数据进行更新操作,会有异常;
  • cacheconcurrencystrategy.read_write,读写模式在更新缓存的时候会把缓存里面的数据换成一个锁,其它事务如果去取相应的缓存数据,发现被锁了,直接就去数据库查询;
  • cacheconcurrencystrategy.nonstrict_read_write,不严格的读写模式则不会的缓存数据加锁;
  • cacheconcurrencystrategy.transactional,事务模式指缓存支持事务,当事务回滚时,缓存也能回滚,只支持jta环境。

另外还有如下注意事项:

1、查询缓存需要在query的相应方法执行前加上这么一句:

query.setcacheable(true);

在使用hibernate时,获得的query有setcacheable方法,可以设置使用缓存,但当使用jpa时,javax.persistence.query并没有setcacheable方法,此时如果jpa的实现是hibernate时,可以将其进行如下转化,再调用setcacheable方法(如果jpa的实现是其它ormap框架,就不知道怎么做了)。

if (query instanceof org.hibernate.ejb.queryimpl) {
    ((org.hibernate.ejb.queryimpl) query).gethibernatequery().setcacheable(
true);
}

2、还有就是查询缓存的查询执行后,会将查询结果放入二级缓存中,但是放入的形式是以id为key,实例作为一个value。

3、hibernate的配置文件中需加入如下信息:

<property name="hibernate.cache.provider_class" value="org.hibernate.cache.ehcacheprovider" />
<property name="hibernate.cache.use_second_level_cache" value="true" />
<property name="hibernate.cache.use_query_cache" value="true" />


posted @ the matrix 阅读(10102) | |  
仅列出标题  下一页
网站地图