`
裴小星
  • 浏览: 260950 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
8ccf5db2-0d60-335f-a337-3c30d2feabdb
Java NIO翻译
浏览量:27563
F3e939f0-dc16-3d6e-8c0b-3315c810fb91
PureJS开发过程详解
浏览量:71873
07a6d496-dc19-3c71-92cf-92edb5203cef
MongoDB Java ...
浏览量:61975
社区版块
存档分类
最新评论

OMToolkit介绍(5): 总结

阅读更多
OMToolkit介绍(5): 总结


(1) OMToolkit整体结构


  OMToolkit包含了Web Server(sever包)、Web Framework(web包)和Object-Oriented Database(data包)三个部分。(图例中的箭头表示“使用”关系)
  OMToolkit与Web应用开发者的接口是Entity,即用户需要实现一组Entities,这些Entities包含了数据以及对数据的操作。
  server包中的类借助基于NIO的轮询接收请求,如果该Web请求需要进行动态的处理(不是resources请求),则调用web包中的类进行处理。
  web包将提取所请求的Entity、所需要调用的方法和需要赋值的属性,借助反射调用用户实现的Entity的方法来处理请求。
  请求处理完毕,将由data包中的类负责将更新过的数据保存到数据文件中。

(2) Server包的结构


  server包中表示守护进程的类是Server类,Server类利用NIO中的Selector进行select,获取需要处理的key,及附加的处理类。
  key上的Channel分为代表服务器端socket的ServerSocketChannel和代表客户端socket的SocketChannel类。
  ServerSocketChannel上附加了Acceptor,而SocketChannel上附加了Worker。
  Acceptor的处理过程是将SocketChannel注册到Selector上,创建Worker并附加到SocketChannel对应的key上。

  Worker的处理过程比较复杂,先用图示说明,如下:

  Worker包含了Reading、Processing、Wrting三个内部类,分表表示读取状态、处理状态和写回状态。
  Reading和Writing的run方法会在Server轮询中被调用,每次读写一部分数据,各个Worker的run方法是单线程进行的,所以Reading和Writing的run方法的执行也是单线程的。
  Processing的情形有所不同,会被提交到线程池中,当有空闲的线程时就执行run方法处理请求。Processing的处理过程是多线程的。
  之所以采用不同的策略,是因为通常而言多线程的切换会有额外的开销,但是Processing的过程往往相对复杂和多样,不一定能够划分为可以轮询的时间片,因此仍采用多线程进行处理。
  由于这是一个Web Server,所以需要等全部请求读取完毕才能进行处理,然后一起写回;如果是C/S模式或RIA中的Socket Server,则可以考虑一边读取、一边处理、一边写回。

  Worker在处理过程中将创建Request对象,用于分析输入的报文,Requset的一些方法调用了CookieUtil和SessionUtil中的一些方法,用于解析cookie和session的信息。

(3) Web包的结构


  Controller中Request中提取所需要的信息,先调用AccessChecker对访问的合法性进行检查(用户的权限,输入的参数等),如果通过检查,则创建Entity和Tranaction,并将Tranaction附加到Entity中。PageUtil和View类分别负责分页处理和视图渲染,可以理解为在Entity中使用的工具类。
  Entity内置的doList和toView等方法已经使用了这两个类,用户也可执行使用这两个类来产生所需的输出。另外,用户也可以通过Entity.getTransaction()方法来获取对事务的管理,进行rollback或commit。

(4) Data包的结构


  data包中的DataUtil可以认为是这个数据包的对外接口,负责数据文件中的Entity信息的增删改查等。FieldUtil提供对数据的操作,而FieldVisitor提供对数据的遍历。
  Cache是对已经获取过的Entity进行缓存,并定时清理。
  Meta保存Entity的id,Entity信息在数据文件中的起始位置和长度,Entity的类型名称等重要信息;程序启动时将加载所有的Meta信息。
  数据文件以文本形式保存,分为两个:data/data和data/meta。

(5) 总结

  OMToolkit的目标是尽可能简化Web应用的开发(尤其是业务逻辑简单的Web应用),因此把传统开发中(尤其是SSH)需要的Action、Service、DAO等多个层次合并在了一起;同时,自行开发Server和Database,以使用Web Framework的需要,而不是让Web Framework去适应Server和Database。
  Entity的设计是将数据以及对数据的处理放在了一起,而将对方法的调用开放给Web请求(调用的Entity、方法、属性值都是从Web请求中获取的),但同时也进行严格的权限和更新参数的限制,以保证安全性。
  后续版本中将依次对Web Framewok、Web Server和Database进行优化,0.1.0版本需要约一年的时间,希望到时的OMToolkit即使不够“好用”,但也至少是“可用”的。
  谢谢。(附件中是最新的OMSimpleBlog和OMToolkit的源码)
6
1
分享到:
评论
1 楼 sp42 2014-08-10  
非常不错,楼主做的正是鄙人想做的做的,而且比鄙人的来的成熟、健壮。
当时我采用 SSJS 去写(服务端 js),到现在,还是觉得 JS 不太适合做这方面的工作。

相关推荐

    OMToolkit介绍(2) :Web Server 实现

    NULL 博文链接:https://xxing22657-yahoo-com-cn.iteye.com/blog/967228

    OMToolkit介绍(3) :Web Framework 实现

    NULL 博文链接:https://xxing22657-yahoo-com-cn.iteye.com/blog/968732

    OMToolkit介绍(4) :Object-Oriented Database 实现

    NULL 博文链接:https://xxing22657-yahoo-com-cn.iteye.com/blog/970072

    OMToolkit: Web Server,Web Framework 及 Object-Orinted Database 的简单实现

    NULL 博文链接:https://xxing22657-yahoo-com-cn.iteye.com/blog/962455

    C 语言实现 linux pwd 命令内含源码以及说明书可以自己运行复现.zip

    C 语言实现 linux pwd 命令内含源码以及说明书可以自己运行复现.zip

    2024年中国变焦LED手电筒行业研究报告.docx

    2024年中国变焦LED手电筒行业研究报告

    node-v8.11.2-darwin-x64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v4.8.2-x86.msi

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    ffmpeg 结合 SDL 编写播放器内含源码以及说明书可以自己运行复现.zip

    ffmpeg 结合 SDL 编写播放器内含源码以及说明书可以自己运行复现.zip

    2024-2030中国OPzV胶体电池市场现状研究分析与发展前景预测报告.docx

    2024-2030中国OPzV胶体电池市场现状研究分析与发展前景预测报告

    node-v4.9.0-win-x64.zip

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    2024年中国齿轮离心鼓风机行业研究报告.docx

    2024年中国齿轮离心鼓风机行业研究报告

    python教程-03-标签属性的获取和设置.ev4.rar

    python教程-03-标签属性的获取和设置.ev4.rar

    狂雨小说CMS-多功能小说系统

    安装说明 系统要求 PHP要求5.6版本以上,低于5.6版本无法运行 支持php7 addons,application,config,extend,public,runtime,template,uploads 目录必须要有写入权限 777 网站必须配置好伪静态(.htaccess为Apache伪静态配置文件,kyxscms.conf为Nginx伪静态配置文件) 宝塔面板要在 软件 php 设置里安装扩展 fileinfo

    基于java的高校毕业设计选题管理系统论文.docx

    基于java的高校毕业设计选题管理系统论文

    信创微服务平台建设指南(PDF)

    当前,以微服务、DevOps、容器、多云业务管理为代表的云原生技术已经广泛成熟应用,成为加速企业数字化业务高效创新、实现企业数字化转型的最佳技术支撑。而信创支持、国产化支持,是中国企业数字化转型不得不满足的基本要求。更有专家指出,在关乎企业生存的必选项“数字化转型”以及国家信创战略的共同冲击下,企业需要改变现有业务和IT的架构,更快速地应对挑战、响应变化,增强自身的竞争力。 信创微服务平台建设指南应当综合考虑当前的技术发展趋势、企业及用户的需求,以及平台的可持续发展能力。 《信创微服务平台建设指南》可参考文章:https://mp.weixin.qq.com/s/cfJH72JFxDTHCPsfFWMUqA

    node-v8.14.0-linux-ppc64le.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    Python爬虫.pdf

    上文提供了一个基础的Python爬虫示例,旨在从CSDN(一个知名的技术博客平台)上爬取特定文章的内容。这个示例代码展示了使用requests库发送HTTP请求,以及使用BeautifulSoup库解析HTML内容的基本流程。 步骤详解 导入必要的库: requests库用于发送HTTP请求。 BeautifulSoup库用于解析HTML内容。 time库用于控制请求之间的延迟。 设置目标URL和请求头: 目标URL是想要爬取的CSDN文章的URL,这里用占位符'https://blog.csdn.net/some_user/article/details/some_article_id'表示,实际使用时需要替换为真实的URL。 请求头(headers)通常用于模拟浏览器行为,避免被目标网站识别为爬虫。这里设置了User-Agent字段。 发送请求并获取响应内容: 使用requests.get()方法发送GET请求到目标URL,并传入请求头。 使用response.raise_for_status()方法检查请求是否成功。如果响应状态码不是200(成功),则抛出异常。 解析HTML内

Global site tag (gtag.js) - Google Analytics