状态机复合状态 怎么写代码_状态不属于代码

状态机复合状态 怎么写代码

Web应用程序中的“状态”是什么? 它是要存储的数据(与目的地无关—内存,数据库,文件系统)。 应用程序本身不得在代码中存储任何状态。 这意味着您的类应该只包含带有无状态对象的字段。 换句话说,在程序流程期间,您不应在服务,DAO或控制器中存储任何内容。 这是服务层的完整“必须”。 为什么?

您的应用程序需要可扩展。 这意味着它需要在集群中运行,而状态是最难分配的。 如果您将状态存储的位置最小化,则可以将群集的复杂性最小化。 但是状态应该存在,在这里拥有状态就可以了:

  • 数据库–无论是SQL,NoSQL还是搜索引擎,它都是存储状态的主要内容。 它应该是支持集群的东西,或者是处理来自多个其他“代码”服务器的请求的大型专用计算机。 该代码与数据库进行通信,但是代码本身不会为一个以上的客户请求存储任何内容。
  • 缓存-缓存相对容易分发(基本上是键值)。 有许多现成的解决方案,例如EhCache和memcached。 因此,您可以配置缓存并将结果存储在内存中,而不是计算结果或根据每个请求从数据库获取结果。 但是,代码仍然没有存储任何内容,它只是填充并查询缓存。
  • HTTP会话–在Web组件(控制器,托管Bean,无论您叫什么)中。 它与缓存非常相似,但是具有不同的目的–允许识别同一用户的后续操作(http本身是无状态的)。 但是,由于您的代码在多台计算机上运行,​​因此负载均衡器可能并不总是将后续请求发送到同一服务器。 因此,会话也应该在所有服务器之间复制。 幸运的是,大多数容器都内置了该选项,因此您只需添加一条配置行。 或者,您可以指示负载均衡器使用“粘性会话”(根据会话cookie来确定发送请求的服务器),但是它也会将一些状态管理也移至负载均衡器。 无论您选择哪种选项,都不要在会话中放入太多数据
  • 文件系统–存储文件时,需要所有计算机都可以访问它们。 这里有多个选项,包括SAN或使用Amazon S3之类的云存储服务,可通过API访问

所有这些都在代码之外进行管理。 您的代码仅通过API(会话API,缓存API,JDBC,S3 /文件系统API)使用它们。 如果代码包含该状态中的任何一个(作为对象的实例变量),则该应用程序将难以支持(您必须自己管理状态),并且可伸缩性也会降低。 当然,在少数情况下,如果不将状态存储在代码中就行不通。 记录这些,并确保它们不依赖于在集群中工作。

但是,如果将状态存储在执行业务逻辑的对象中,那会出错吗? 然后,您有两个选择:

  • 同步对字段的访问–这会降低性能,因为所有发出请求的用户都必须排队等待服务来管理其字段;
  • 为每个HTTP请求创建类的新实例,并以某种方式管理实例。 管理这些实例是困难的部分。 人们可能会倾向于选择会话来执行此操作,这意味着会话会变得非常大且难以复制(跨多台计算机共享大量数据的速度较慢,会话复制必须快速)。 更不用说不必要地增加了内存占用。

这是不做什么的简单例子。 您应该将这些类型的值作为方法参数传递,而不是将其存储在实例中:

class OrderService {double orderPrice;void processOrder(OrderDto order) {for (Entry entry : order.getEntries() {orderPrice += entry.getPrice();}boolean discounts = hasDiscounts(order);}boolean hasDiscounts(OrderDto order) {return order.getEntries().length > 5 && orderPrice > 200;}
}

因此,使您的所有代码都为无状态–这将确保至少某种程度的可伸缩性。

参考:我们的JCG合作伙伴 未将State 列入 守则   Bozho的技术博客中的 Bozhidar Bozhanov 。


翻译自: https://www.javacodegeeks.com/2012/02/state-does-not-belong-in-code.html

状态机复合状态 怎么写代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/356663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言均值滤波程序,均值滤波C语言代码实现的一种简单方式

计算均值滤波时,需要每次求数组的和,再求均值,一般先放入一个数组,循环移出最后一个旧的值循环移入新的值一般原来的做法/******************************************************************************//*** param[in] data[…

用户管理实例 之 添加、查询

访问视图先是访问控制器中的方法,在去找跟方法同名的视图,或者指定的视图 这里是用LinQ查询数据库的一张表的数据,在控制器中ViewData存储数据,把此数据(一张表)在前台页面上显示出来。 控制器中&#xff1…

Java内存体系结构(模型),垃圾回收和内存泄漏

Java内存架构(Java内存模型) 上面是堆的Java内存模型以及Java虚拟机(JVM)中运行的任何Java应用程序的PermGen。 还提供了比率,以使您更好地了解如何在每种世代类型之间分配允许的内存。 以上所有内容完全适用于Java 1…

1101. 献给阿尔吉侬的花束(bfs找最短路径)

题目: 1101. 献给阿尔吉侬的花束 - AcWing题库 输入样例: 3 3 4 .S.. ###. ..E. 3 4 .S.. .E.. .... 3 4 .S.. #### ..E.输出样例: 5 1 oop! 思路:bfs宽搜 用队列实现bfs。踢出队列头,并在队列尾插入与对头相关的…

c 编程语言概述,C编程语言概述

C编程语言概述引导语:C的应用范围广泛,具备很强的数据处理能力,以下是百分网小编分享给大家的C编程语言概述,欢迎阅读学习!编程语言概述学习一门新语言的惟一途径就是使用它来编程。对于初学者来说, 编写的第一个程序几…

Linux crontab定时执行任务

基本格式 : *  *  *  *  *  command 分 时 日 月 周 命令 第1列表示分钟1~59 每分钟用*或者 */1表示 第2列表示小时1~23(0表示0点) 第3列表示日期1~31 第4列表示月份1~12 第5列标识号星期0&…

apache mahout_Apache Mahout:入门

apache mahout最近,我有一个有趣的问题要解决:如何使用自动化对不同来源的文本进行分类? 前一段时间,我读到一个有关该项目以及许多其他文本分析工作的项目– Apache Mahout 。 尽管它不是一个非常成熟的版本(当前版本…

硬链接和软连接(符号链接)

硬链接:不同路径的文件指定的是同一个inode硬链接不能跨分区存在硬链接不能链接到目录(要避免循环引用)删除硬链接只会减少文件被硬链接的次数,源文件不会动.软链接:是一个独立的文件,有自己独立的inode,引用的是路径本身,不是inode删除软链接,跟源文件没任何关系软…

基于nbu oj c语言答案,Just oj 2018 C语言程序设计竞赛(高级组)F:Star(结构体排序+最小生成树)...

Time Limit: 1 s Memory Limit: 128 MBProblem Description31世纪,人类世界的科技已经发展到了空前的高度,星际移民,星际旅游早已经不再是问题。人类已经掌握了开发星系的能力。但是,无论发展到何种地步,资源一直…

与JBoss BPM Travel Agency更新了现代BPM数据集成

不久前,我们启动了一个规模较大的JBoss Travel Agency演示项目,以展示JBoss BPM Suite的一些更有趣的功能。 我们提供了一系列视频 ,不仅向您展示了如何安装它,项目中各种规则和流程工件的含义,还向您介绍了在实际使用…

c语言中坐标xoy轴在哪里,用C语言在linux下获取鼠标指针的相对位置

1. 关于"/dev/input/mice"相信很多人都用过Linux,也许你发现不管是在X-window下面,还是在Console下面,鼠标都是可以操作的。那么你有没有考虑过这些鼠标都是从哪来的?不错!他们都是从"/dev/input/mice&…

codeblock不能调试

问题:codeblock 不能调试,如下图: 解决方法: 首先,项目的保存路径不能是中文路径。 其次,必须创建工程。 最后,build选项里select target选成debug codeblock如何创建工程:http://j…

与詹金斯一起将GitLab中的Gradle项目发布到Artifactory

我将详细展示如何定期构建您的项目,然后如何进行发布。 它涉及许多工具的协作,我发现这些工具难以正确设置,这就是我编写此代码的原因。 目标 我将向您展示如何实现以下两种方案。 第一个是如何进行常规开发的非发行版: 实现一些…

比较排序算法的时间复杂度 c语言,c语言四种排序算法时间复杂度比较(10页)-原创力文档...

1、方案设计:我这次实验通过随机生成30000个随机数,把随机数存到数组中,用这同一组随机数据分别进行四种排序,直接插入排序、直接选择排序、冒泡排序和快速排序。还通过了调用txt文件把运算所需时间导出,分别输出各个算…

三维漫游的实现

一、本文主要是展示一个demo,实现的是画一个三维的立方体,通过滑动屏幕来旋转方向,上下左右来移动。直接上代码: MainActivity:package com.example.zp.a3dword;import android.graphics.Bitmap;import android.graphi…

MySQL JDBC驱动程序如何处理准备好的语句

准备的语句类型 在研究《 高性能Java持久性》一书中的“ 语句缓存”一章时,我有机会比较了Oracle,SQL Server,PostgreSQL和MySQL处理预准备语句的方式。 感谢Jess Balint (MySQL JDBC驱动程序贡献者),他在…

Nodejs学习(三)-安装nodejs supervisor,提高点效率吧。

安装好了express准备写项目,可是发现随便改一下js都要使用npm start重新启动才能生效,这个很不好,搜索一下发现有这么一个模块supervisor。那就安装一下吧。 1.安装,这个必须是全局安装那就开始吧。 npm -g install supervisor 设…

网络语言不c,哪些网络用语不文明?

满意答案林昨末sk2013.02.26采纳率:47% 等级:11已帮助:8049人Q1. 你认为在网络上出现的不文明用语情况_B___?A.是人们宣泄情绪的一种重要方式 B.是当今社会的一个缩影,没有办法C.不应当提倡,应加大管理力…

android 无限旋转动画,android ——不停旋转动画

xml文件android:fromDegrees"359"android:toDegrees"0"android:duration"1000"android:repeatCount"-1"android:pivotX"50%"android:pivotY"50%"/>代码/开始旋转/public voidstartRotateAnimation(View view, …

九章算法强化班 - 课程大纲

第1章 FLAG算法面试难度提高?如何准备? 各类IT企业的面试算法难度及风格 如何解决中等难度以上的算法题 如果解决follow up问题 Two sum   1. Two sum follow up I   2. Two sum follow up II - Triangle count Kth largest element   1. 第…