不要让开源架构代替我们的设计

news/2024/7/8 11:19:52

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

现在开源的各种framework非常的多。干什么的都有。但是,是不是我们使用了这些开源framework就能够一劳永逸的解决我们的设计问题呢?我觉得答案是否定的。如果没有自己对设计和系统的理解。框架滥用就在所难免。比如说hibernate(以下简称HI),它是一个对象持久框架,他的目的非常的简单,就是提供对象持久化的手段。但是在日常的工作中,我经常看见很多人把HI用的非常的复杂,希望用HI实现一些复杂的数据库查询,似乎把HI看作了一个数据库抽象层了。使用HI,却永远不忘记SQL。我觉得这是不正确的。虽然HI的本质是ORM。但是它可不是用来替换数据库的。不要把HI当作数据库一样去操作。在设计的时候要考虑对象的差别,那些是业务对象,那些本身就是数据。如果本身就是处理数据的话,我们可以使用criteria这样的数据操作封装来操作数据。甚至,直接使用SQL语句,这时候我们的视角就发生了变化,不在是停留在业务对象上了。数据就是数据不要往对象上靠,这样更好。动不动的就搞一个POJO可不是一个好的习惯。另外,如果我们是对原有系统进行改造的话,推荐使用cayenne,apache的开源orm,有自己的管理器,可以自动从数据库中同步出pojo来。   

如果是我们自己从头开始设计系统,建议不要再在数据库里面指指戳戳了。把数据库表之间的关系,改为对象之间的关系,自己写程序来维护自己对象之间的关系,推荐使用di(依赖注入),不用也可以,关键看你系统的规模。数据库中的表要尽可能的简单,要分维度和事实,以便于复用并(建议大家了解一些数据仓库的概念)减少表中的字段数。如果你采用多维结构来设计数据库的话,表中的字段不会很多。设计的好坏完全凭你多年的经验和对客户系统的了解。(分析出那些是维度,那些是事实,不是一个容易的事情,做过的人都知道)   

 对于框架的应用,我本身都是非常慎重的。如果我们不理解这些框架的使用背景,使用这些框架,就难免产生各种各样的问题。那么,好与不好的原则是什么?我觉得《Better, Faster, Lighter Java》一书的作者说的很好:Keep It Simple、Do One Thing,and Do It Well、Strive forTransparency。翻译过来就是:保持简单、一次做好一件事、力求透明。其实一个好的框架最起码要做到的就是透明性,有些人也管它叫非侵入性。比如spirng。(spring因此遭到批评说它其实什么也没有做,这个我有所同感)其实侵入性不是框架的问题,是我们自己设计的问题。我们应该在我们的设计中对引入的框架部分做我们自的接口,这样就可以摆脱框架侵入性的困扰。   

最后我想说说我心目中的先进的web应用框架应该是什么样子的。首先它一定是REST的,所有的东西都是资源,这样可以避免session的烦恼。其次,它一定是面向服务的,也就是所谓的soa,这样可以实现松耦合,并且可以实现类似组件的功能。view部分一定是ajax的,但是也要组件化,现成的方式是EXT+buffalo。但其实也可以使用其他的界面方式,比如net的winform或者java的swing。最后还有一个对象管理器,专门负责业务对象的管理。透明的采用aop的方式,把日志、任务、权限、事物、工作流,集成进来,各个部分都是独立可配置的。可以根据需要将它们配置进我们的应用中。最后提供一种分布式的解决方案来应对可伸缩性。另外根据约定,尽量减少配置的数量和次数,尽可能的提供配置工具,而不是我们手写XML配置文件。

转载于:https://my.oschina.net/weiweiblog/blog/470112


http://www.niftyadmin.cn/n/2644046.html

相关文章

使用飞信带的.net虚拟机vmdotnet精减.net安装文件包 (非托管运行)

飞信中带的VMDotNet,也就是所谓的.NET FRAMEWORK虚拟机吧。相信有很多人也已经看过相关文章了,但是对于新手我还是再提一下,在你的飞信的安装目录下有一个VMDotNet文件夹,这 个就是我们要用的最主要的内容了,先把它COP…

安全域的划分

安全域概述•网络安全域是指同一系统内有相同的安全保护需求,相互信任,并具有相同的安全访问控制和边界控制策略的子网或网络,且相同的网络安全域共享一样的安全策略。广义可理解为具有相同业务要求和安全要求的IT系统要素的集合。网络安全域…

JAVA中list,set,数组之间的转换详解

JAVA的list,set,数组之间的转换,主要是使用Apache Jakarta Commons Collections,具体的方法如下:import org.apache.commons.collections.CollectionUtils; String[] strArray {"aaa", "bbb", "ccc"}; …

CuteEditor6.0使用配置心得体会

CuteEditor是一款功能非常强大,支持图片上传、文件下载和word类似的文字编辑器。并且Vs2003和Vs2005都可以适用。对于新闻发布系统和博客之类的系统,是非常的方便的。对一个刚接触这款编辑器的朋友来说或许会遇到和我一样的许多问题,现在我就…

rsync-服务器之间备份

需求:需要把A服务器上的某些数据定期备份到B服务器中A服务器:#yum install -y rsync#rpm -qa | grep rsync#vim /etc/xinetd.d/rsyncyes改成no ,开启 rsync#chkconfig rsync on #chkconfig --list rsync生成配置文件#vim /etc/rsyncd.…

基线的定义

基线(Baseline)说起. 基线是软件文档或源码(或其它产出物)的一个稳定版本,它是进一步开发的基础.所以,当基线形成后,项目负责SCM的人需要通知相关人员基线已经形成,并且哪儿可以找到这基线了的版本.这个过程可被认为内部的发布.至于对外的正式发布,更是应当从基线了的版本中发布…

经纬度编码转换

众所周知,包括LT在内的所有导航软件的地图,就是经纬度坐标的点的集合。然后,与GPS的经纬度信号匹配,才能应用成为导航。但是由于国家政策原因,LT不能直接用经纬度定位一个目标。为此,LT用了一种变通的方法&…

MySQL锁表解决方法(转)

MySQL锁表解决方法 一、我的处理过程 1、查进程,主要是查找被锁表的那个进程的ID SHOW PROCESSLIST; 2、kill掉锁表的进程ID KILL 10866;//后面的数字即时进程的ID 网上找了些资料,了解了一下,先分享一下: 二、mysql的锁表问题 …