创业时代缓存
Ⅰ 2022年即将过去,你这一年的关键词是什么
2022年即将过去,我这一年的关键词是勤奋拼搏。
作为男人来说能够养家糊口下班回拍好慎家可以吃到热腾腾的饭菜。妻子温柔贤惠,孩子上进懂事,闲暇之余做点自己喜欢的事,玩玩游戏看看小说。
如果有钱,你当然也可以旅旅游,这是男人的幸福。作为女人来说,有自己的一份稳定工作,让自己有不伸手拿钱的底气,丈夫顾家体贴,孩子孝顺,家庭和睦,年轻漂亮,这是女人的幸福;
每一类人都有自己的幸福感,这种幸福感我觉得是不相通的,就像鲁迅先生说的:
人类的悲欢并不相通,我只觉得他们吵闹。
现在的人都喜欢站在道德制高点去评价袜野别人。
但是人类个体间是无法在感情上做到感同身受这四个字的,因为这句话本身放在现在社会去理解,就会是以下的解释:
1、大多数时候我们对陌生人的感受根本不关心,因为这个社会让每个人都感到疲惫,即使想关心,也可能会被误会成是带有其他色彩的关心;2、我们在关心他人的时候,其实并不了解事情的发展经过,只是站在了自己的角度去试着理解,无疑于是在营造一种假的亲密关袭敬系,想通过此种方式拉进彼此关系;3、如果将事事都与自己联系上,这种内心所感受到的重量是无法描述的。
Ⅱ 这个男人创造了世界上第一款3D游戏引擎,开创了PC游戏的新纪元!
说起 游戏 引擎那么大家第一反应就是目前市面上最流行的虚幻和unity3D这两个引擎,不仅专业的 游戏 公司在使用,独立 游戏 制作者也能够接触到这两款 游戏 引擎。而除了这两款比较大众化的 游戏 引擎之外,还有一些是资金雄厚的 游戏 公司专门为自己定制开发的 游戏 引擎,如EA的寒霜,动视暴雪的IW这些也是比较出名的。
但你们知道第一款用于专门面向3D 游戏 的 游戏 引擎是什么时候诞生的呢?他又是如何发展的?今天大麦就带各位来回顾曾经3D 游戏 引擎的发展史。
在1990年的一个傍晚,两个热爱任天堂 游戏 的年轻人自己在 PC端开发了一个 游戏 引擎并成功的将街机 游戏 《超级马里奥》移植到PC端上同时拥有更好的画质 ,他们兴奋的将这个移植版的马里奥发给了任天堂寻求合作。
然而当时的任天堂在主机界的地位如日中天,高傲的认为未来 游戏 的主要发展之路还是在主机端上,PC端没有太好的发展前景。于是只是简单的夸奖了两个年轻人的工作就再无下文。
隔年,这两个年轻人便自己创业成立了ID software公司,他们两的名字是 约翰·卡马克和约翰·罗梅洛,或许是命运的安排这两个哥们都叫约翰。
对于一般玩家来说可能并不了解卡马克这个人,但是他在 游戏 行业绝对是赫赫有名,当年几乎就是仅凭他一己之力推动了整个3D 游戏 行业的发展,他设计的3D绘图技术是现在绝大部分3D 游戏 引擎的设计基础。后来由他主导制作的第一款第一人称3D射击 游戏 也是 游戏 史上第一款3D射击 游戏 ,因此他被人们冠以了 FPS 游戏 之父 的称号!
卡马克和他的伙伴设立了ID Software这家公司以后发售的第一款 游戏 用的就是卡马克当年自己开发的一款 游戏 引擎-- Commander Keen in Invasion of the Vorticons中文译名:指挥官基恩:外星人入侵 ,或许以我们现在的眼光来看,这款 游戏 画质只能算一般,当时在那个 游戏 绝大多数PC 游戏 还是基于MS-DOS操作平台下的 游戏 ,指挥官基恩:外星人入侵绝对算得上是一款画质惊艳无比的 游戏 。
不过有趣的是,在那个年代大家对于 游戏 引擎的概念还没有现在这么鲜明,而且也不存在商用 游戏 引擎这种概念。因此那时候对于引擎的取名一般就是和所制作的 游戏 同名,所以ID Software的第一款 游戏 引擎名字就叫做 Commander Keen engine,包括后来制作的第一款3D 游戏 引擎也叫做Wolfenstein 3D(德军总部3D) 。
而且这款 游戏 国外还有粉丝专门为他制作了网站,可见当年指挥官基恩系列受到了玩家多大的追捧!
在上个世纪九十年代是计算机技术飞速发展的年代,更快的CPU,更大的内存,很大的存储空间,给了卡马克天马行空的创意提供了现实基础。他开始着手制作PC端的第一款3D 游戏 , Hovertank 3D(航行坦克)。
卡马克花了6周的时间为航行坦克开发出了新 游戏 引擎,这次的 游戏 引擎运用的全新的贴图技术,首次实现了在PC端出现了3D图像!这也奠定了未来首个商用3D 游戏 引擎的出现。
说到FPS 游戏 ,绝对要提 游戏 史上一款程碑式的 游戏 --- 重返德军总部3D 。他代表了PC 游戏 正式从2D图像跨入3D图像,同时他也是PC端上第一款第一人称射击 游戏 !一代和二代的重返德军总部都还是一种像素式的2D图形 游戏 , 在ID Software取得了续作的开发权后,将自己在航行坦克中积累的3D制作技术运用在这款新 游戏 上。
当时的重返德军总部一经发售,又立刻引发了玩家们的追捧。玩家们根本没有见过这种3D式的第一人称射击 游戏 ,但有趣的是重返德军总部3D是用了一种射线追踪技术来渲染 游戏 内的物体具体来说就是 游戏 中每个像素会发射一道光束,如果这道光束碰到了障碍物形成反射, 游戏 就会按照设定好的程序在障碍物的相应位置创建单维深度缓存(dimensional depth buffer),建立纹理图像 。因此严格上来讲这并不属于真正的3D 游戏 ,因为 游戏 中并没有任何的建模,依旧都是依靠贴图来实现的。
然而重返德军总部3D只是卡马克的牛刀小试,真正的重头戏还是1993年推出的DOOM(毁灭战士)!
在为毁灭战士制作的 游戏 引擎修复了重返德军总部3D引擎中一些缺陷,增加了更为丰富的光照效果, 游戏 场景更加生动,物品交互加强,支持立体音效。至此一款现代化的通用 游戏 引擎才真正诞生了。
拥有如此强大的 游戏 引擎的支持下,毁灭战士不出意外的大获成功。当年销量达到了350万份,同时还极大推动了昂贵的PC的销量。当年ID Software实现了超过数亿美元的营收,公司挣的是盆满钵满,据传言称,公司的停车库中只停着法拉利哈哈哈。
说ID Software是 游戏 史上最伟大的 游戏 公司之一一点也不为过,因为在1996年发售的Quake(雷神之锤)又是一款里程碑式的 游戏 存在。
雷神之锤的 游戏 引擎不同于毁灭战士,这一次他使用的是实实在在的3D引擎。 Quake引擎是当时第一款完全支持多边形模型、动画和粒子特效的引擎,而在技术之外,它的 游戏 操控方式也树立了FPS 游戏 的标准。 游戏 采用流动控制方案(fluid control scheme ),它使用鼠标来观看/瞄准/定向以及用键盘前进/后退/侧移,这也成了FPS 游戏 最普遍的操控模式,直到今日仍没有变化。
在雷神之锤之后,ID Software继续再接再厉,依靠先进的3D引擎技术第二年就发布了雷神之锤2,到了1999年又发布了雷神之锤3。而每一代新雷神之锤的发布, 游戏 引擎也在不断的进化。 到了雷神之锤3,由于引擎能实现的画质越来越高,已经不能在单纯的依靠软件渲染必须要有一款支持硬件加速的显卡才能运行。这也极大了推动了那个年代显卡行业的发展。
在美国,商人们对于专利的概念极为看重。专利不仅能保护他们的知识产权,还能带给他们极大的利润。然而,卡马克却是一个不折不扣的开源软件倡导者。在ID Software公司拥有这么强的 游戏 引擎技术以后,卡马克心中唯一的想法就是将他的技术共享,以此来推动整个行业的发展。
1995年,他公布了重返德军总部3D的源代码,1996年公布了雷神之锤的源代码,1997年又放出了毁灭战士的源代码,1999年毁灭战士的源代码又以GSL准则对外公布,2005年公布雷神之锤3的源代码。
这样公布 游戏 源代码的行为几乎是前无古人后无来者的存在。
ID Software公司极大的推动了那个时代 游戏 引擎成熟化,当时第一代《使命召唤》和《荣誉勋章》使用的就是雷神之锤3的 游戏 引擎,后来IW入住动视,为动视开发的御用引擎IW也是基于ID tech引擎制作而来。
后来Epic公司的虚幻引擎问世,相比于只负责3D图像处理的ID tech引擎来说,虚幻 引擎的涵盖方面更多,涉及物理特性、动画演示、音频效果和碰撞检测等 游戏 的所有组件,也就是说Unreal引擎的集成度更高,通用性更强。而且虚幻引擎不单单涉及 游戏 领域,他还能够运用在建筑设计、影视制作、动作捕捉、3D建模等等方面。
在九十年代之后,得益于卡马克的无私贡献, 游戏 引擎开始井喷式爆发。除了Epic的虚幻2虚幻3外,V社在雷神之锤引擎的基础上也开发了自家的Source引擎。育碧依靠一家德国公司开发了嚎哭引擎,也因此诞生了后来的孤岛惊魂系列。
后来市面上的 游戏 引擎数量越来越多,人们也逐渐淡忘了曾经那第一款现在来看略显简陋的3D 游戏 引擎DOOM和Quake,但是大家永远不会玩家卡马克为这个时代所带来的伟大贡献!
Ⅲ 像美团外卖这样的APP用一种开发语言,能开发得出来吗
像美团外卖这样的APP用一种开发语言,能开发得出来吗?答案是不能。
美团发展到现在可以说已经是一个【巨无霸】了,里面集成了很多很多功能,除了核心的外卖,还有 旅游 、 娱乐 、购物、出行,金融等等业务线,那么这么多复杂的业务根本不可能用同一种开发语言实现。
那么美团都用到哪些开发语言和技术了呢?下面就根据我的理解详细说一下。
前端是把产品的核心服务交给用户的呈现者,它的表述方式、展示形式以及交互逻辑都跟用户息息相关,都影响着用户使用产品的体验,也就是说直接影响产品的用户留存。
前端开发主要分为三大类型:Andriod、IOS和PC(H5) ,Android开发语言是Kotlin和java,IOS开发语言是Object-c和Swift,PC(H5)开发语言就比较杂了,有JS、CSS、HTML,还有很多第三方的前端框架,比如Angular.js、vue.js、Bootstrap、JQuery等等。
关于后端的功能,这一点可以说是众说纷纭,主要需要考虑的是如何实现功能、数据的交互流程和存取、平台的稳定性与性能等。
那么后端都用到哪些开发语言和技术呢?
根据后端技术选型的标准,后端可选的开发语言和技术是非常多的。
比如Java体系的话,可以选用SpringMVC、Spring cloud、Hibernate,Mybatis、Mysql、Redis、Memcache、zookeeper、Kafka......;
比如python体系的话,可以选用Django、Flask、Tarnado、Web2py等,中间件都是通用的,Redis,MQ、MySQL、Kafka等都可以用在python体系中;
当然还有PHP、C、Perl等开发语言。
综上所述,美团这个巨无霸公司,随着业务线的扩展用到的技术肯定会越来越多,而且越来越复杂,技术快速变革的时代,适者生存的竞争性也会越来越激烈。
俗话说:罗马不是一日建成的,任何事都不可能一蹴而就,包含技术。在以后的发展中美团也会逐步更新自己的技术和开发语言的。
至少三种语言。后端一种语言(比如Java丶Go丶Python丶PHP等),后端语言及生态比较成熟。下面重点聊前端App开发。
前台两种语言(Android和iOS是不同的开发环境。比如Android用Java或者Kotlin,iOS采用Object C++或Swift),称之为Native开发。
当然创业公司可以用一种前端语言写App前端,这样就不需要Android和苹果分两种语言写,写一次代码可以编译成Android和iOS的App,现在通行的方案有Vue之类的DOM渲染模式,以及ReactNative方案(RN)。性能上RN优于DOM渲染但低于用Native开发的App。所以美团这种公司,一定是Native方式写App,但RN是初创项目不错的选择。
与RN竞争的还有一种新贵flutter,是google推出来的,但设计原理与RN不同,性能方面优于RN,只是目前生态不够健全,国内有闲鱼app是采用此技术。未来可能会占一席之地。
最后,其实App开发已经是强努之末,我觉得主流应该是朝PWA和小程序方向发展。
你好,开发譬如美团这种APP,用一种语言是实现不了的,一个APP有安卓和苹果两个操作系统,开发能在安卓iOS端应用的APP主流的开发语言和技术是很多的,如后台有JAVA、C++、PHP、Python等多种开发语言,前端有kotlin、HTML、css、jquery、ajax、bootstrap、angular.js、react、vue.js、node.js、swift、object-c等多种语言和框架。
一个APP的开发是需要前端技术和后台技术共同配合完成,这样的APP不论是功能还是性能都给用户很好的体验,单一开发语言毕竟技术支持有限,所以即使能开发出来,APP的用户体验也是不理想的。
一般APP有这几种开发组合模式:1、原生安卓iOS开发,前端:JAVA、kotlin、swift、object-c后台:JAVA、PHP、C++等后台技术,这种模式开发周期长,成本高,性能好;2、混合APP开发即hybrid app,前端以网页技术为主,穿插原生开发功能,兼具原生APP和web app的优点,如淘宝、微信等应用都是走的这个技术;3、web app,前端纯网页技术,后台为主流开发语言,这种模式开发速度快,成本低,界面体验可能弱一些。
可见开发一款APP大多数都是多种语言配合完成,谢谢阅读。
看完之前的评论,依然好奇为什么一个语言不能完全胜任。
前端跨平台的方案有react native,cordova,flutter等,如果需要兼容开发小程序,h5页面,可以采用taro来开发,一套代码,所有平台通吃。
后端的方案有服务端运行时nodejs,大数据背景下运用而生的数据库mobgodb,缓存解决方案redis,搜索工具elasticsearch,负载均衡ngix,基本上是需要什么就有什么
所以总结下来,一句话,一种语言可以实现类似美团这样的app和小程序。为什么美团使用的语言那么多,一大原因估计是美团app开发的早,当时前端技术不成熟,工具没现在这么多。
使用混合开发与C++ 进行跨平台开发,有好有坏。
C++ 进行跨平台开发
编写一次,随处运行。早在 2013 年,Dropbox 就采用上述策略进行移动开发,这背后的想法很简单:用 C++ 编写一次代码,而不是用 Java 和 Objective-C 编写两次。那时,整个移动工程团队相对还比较小,但需要支持快速增长的移动路线图。因此,公司希望找到一种方法,使这个小团队可以快速交付大量 Android 和 iOS 代码。
如今,Dropbox 完全放弃了这个策略,转而使用各个平台的原生语言(主要是 Swift 和 Kotlin ,这两种语言在刚开始制定移动策略时还不存在)。
Hybrid App混合开发
Hybrid App主要以JS+Native两者相互调用为主,从开发层面实现“一次开发,多处运行”的机制,成为真正适合跨平台的开发。Hybrid App兼具了Native App良好用户体验的优势,也兼具了Web App使用HTML5跨平台开发低成本的优势。
目前已经有众多Hybrid App开发成功应用,比如美团、爱奇艺、支付宝等知名移动应用,都是采用Hybrid App开发模式。
移动应用开发的方式,目前主要有三种:
几种模似都可以开发出应用,小应用无所谓,但是大流量应用,对图形要求高的如 游戏 等原生开发的效果还是最好
支付宝打开很慢,就是因为采用混合开发,使用人多了不如原生开发
不行的哦。任何你看到的应用和网页,都需要多个语言开发的,大的分比如前端和后端,用的语言都是不一样的
Ⅳ java 目前市面上比较火的框架有哪些
Java 始终排在第一位,这使它成为有史以来最着名的软件编程语言之一。及时的更新和新版本发布使它成为一种充满活力的、有竞争力的编程语言。
2020年最常用的java框架
十大常用框架:
一、SpringMVC
二、Spring
三、Mybatis
四、Dubbo
五、Maven
六、RabbitMQ
七、Log4j
八、Ehcache
九、Redis
十、Shiro
模型(Model )封装了应用程序的数据和一般他们会组成的POJO。
视图(View)是负责呈现模型数据和一般它生成的HTML输出,客户端的浏览器能够解释。
控制器(Controller )负责处理用户的请求,并建立适当的模型,并把它传递给视图渲染。
Spring的web模型 - 视图 - 控制器(MVC)框架是围绕着处理所有的HTTP请求和响应的DispatcherServlet的设计。
Authentication 权限
Caching 缓存
Context passing 内容传递
Error handling 错误处理
Lazy loading懒加载
Debugging 调试
logging, tracing, profiling and monitoring记录跟踪优化校准
Performance optimization性能优化
Persistence 持久化
Resource pooling资源池
Synchronization同步
Transactions 事务
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
一、SpringMVC
Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发,Spring Web MVC也是要简化我们日常Web开发的。
Spring Web MVC处理请求的流程
具体执行步骤如下:
1、 首先用户发送请求————>前端控制器,前端控制器根据请求信息(如URL)来决定选择哪一个页面控制器进行处理并把请求委托给它,即以前的控制器的控制逻辑部分;图2-1中的1、2步骤;
2、 页面控制器接收到请求后,进行功能处理,首先需要收集和绑定请求参数到一个对象,这个对象在Spring Web MVC中叫命令对象,并进行验证,然后将命令对象委托给业务对象进行处理;处理完毕后返回一个ModelAndView(模型数据和逻辑视图名);图2-1中的3、4、5步骤;
3、 前端控制器收回控制权,然后根据返回的逻辑视图名,选择相应的视图进行渲染,并把模型数据传入以便视图渲染;图2-1中的步骤6、7;
4、 前端控制器再次收回控制权,将响应返回给用户,图2-1中的步骤8;至此整个结束。
二、Spring
2.1、IOC容器:
IOC容器就是具有依赖注入功能的容器,IOC容器负责实例化、定位、配置应用程序中的对象及建立这些对象间的依赖。应用程序无需直接在代码中new相关的对象,应用程序由IOC容器进行组装。在Spring中BeanFactory是IOC容器的实际代表者。
2.2、AOP:
简单地说,就是将那些与业务无关,却为业务模块所共同调用的逻辑或责任封装起来,便于减少系统的重复代码,降低模块间的耦合度,并有利于未来的可操作性和可维护性。AOP代表的是一个横向的关系
AOP用来封装横切关注点,具体可以在下面的场景中使用:
三、Mybatis
MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
总体流程:
(1)加载配置并初始化
触发条件:加载配置文件
将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)接收调用请求
触发条件:调用Mybatis提供的API
传入参数:为SQL的ID和传入参数对象
处理过程:将请求传递给下层的请求处理层进行处理。
(3)处理操作请求
触发条件:API接口层传递请求过来
传入参数:为SQL的ID和传入参数对象
处理过程:
(A)根据SQL的ID查找对应的MappedStatement对象。
(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。
©获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。
(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。
(E)释放连接资源。
(4)返回处理结果将最终的处理结果返回
MyBatis 最强大的特性之一就是它的动态语句功能。如果您以前有使用JDBC或者类似框架的经历,您就会明白把SQL语句条件连接在一起是多么的痛苦,要确保不能忘记空格或者不要在columns列后面省略一个逗号等。动态语句能够完全解决掉这些痛苦。
四、Dubbo
Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC(远程过程调用协议)远程服务调用方案,以及SOA服务治理方案。简单的说,bbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有bbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架。
1、透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。
2、软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
3、 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。
节点角色说明:
五、Maven
Maven这个个项目管理和构建自动化工具,越来越多的开发人员使用它来管理项目中的jar包。但是对于我们程序员来说,我们最关心的是它的项目构建功能。
六、RabbitMQ
消息队列一般是在项目中,将一些无需即时返回且耗时的操作提取出来,进行了异步处理,而这种异步处理的方式大大的节省了服务器的请求响应时间,从而提高了系统的吞吐量。
RabbitMQ是用Erlang实现的一个高并发高可靠AMQP消息队列服务器。
Erlang是一门动态类型的函数式编程语言。对应到Erlang里,每个Actor对应着一个Erlang进程,进程之间通过消息传递进行通信。相比共享内存,进程间通过消息传递来通信带来的直接好处就是消除了直接的锁开销(不考虑Erlang虚拟机底层实现中的锁应用)。
AMQP(Advanced Message Queue Protocol)定义了一种消息系统规范。这个规范描述了在一个分布式的系统中各个子系统如何通过消息交互。
七、Log4j
日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。
八、Ehcache
EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是Hibernate中默认的CacheProvider。Ehcache是一种广泛使用的开源Java分布式缓存。主要面向通用缓存,Java EE和轻量级容器。它具有内存和磁盘存储,缓存加载器,缓存扩展,缓存异常处理程序,一个gzip缓存servlet过滤器,支持REST和SOAP api等特点。
优点:
1、 快速
2、 简单
3、 多种缓存策略
4、缓存数据有两级:内存和磁盘,因此无需担心容量问题
5、 缓存数据会在虚拟机重启的过程中写入磁盘
6、可以通过RMI、可插入API等方式进行分布式缓存
7、 具有缓存和缓存管理器的侦听接口
8、支持多缓存管理器实例,以及一个实例的多个缓存区域
9、提供Hibernate的缓存实现
缺点:
1、使用磁盘Cache的时候非常占用磁盘空间:这是因为DiskCache的算法简单,该算法简单也导致Cache的效率非常高。它只是对元素直接追加存储。因此搜索元素的时候非常的快。如果使用DiskCache的,在很频繁的应用中,很快磁盘会满。
2、不能保证数据的安全:当突然kill掉java的时候,可能会产生冲突,EhCache的解决方法是如果文件冲突了,则重建cache。这对于Cache数据需要保存的时候可能不利。当然,Cache只是简单的加速,而不能保证数据的安全。如果想保证数据的存储安全,可以使用Bekeley DB Java Edition版本。这是个嵌入式数据库。可以确保存储安全和空间的利用率。
九、Redis
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis数据库完全在内存中,使用磁盘仅用于持久性。相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。Redis可以将数据复制到任意数量的从服务器。
1.2、Redis优点:
(1)异常快速:Redis的速度非常快,每秒能执行约11万集合,每秒约81000+条记录。
(2)支持丰富的数据类型:Redis支持最大多数开发人员已经知道像列表,集合,有序集合,散列数据类型。这使得它非常容易解决各种各样的问题,因为我们知道哪些问题是可以处理通过它的数据类型更好。
(3)操作都是原子性:所有Redis操作是原子的,这保证了如果两个客户端同时访问的Redis服务器将获得更新后的值。
(4)多功能实用工具:Redis是一个多实用的工具,可以在多个用例如缓存,消息,队列使用(Redis原生支持发布/订阅),任何短暂的数据,应用程序,如Web应用程序会话,网页命中计数等。
1.3、Redis缺点:
(1)单线程
(2)耗内存
十、Shiro
Apache Shiro是Java的一个安全框架,旨在简化身份验证和授权。Shiro在JavaSE和JavaEE项目中都可以使用。它主要用来处理身份认证,授权,企业会话管理和加密等。Shiro的具体功能点如下:
(1)身份认证/登录,验证用户是不是拥有相应的身份;
(2)授权,即权限验证,验证某个已认证的用户是否拥有某个权限;即判断用户是否能做事情,常见的如:验证某个用户是否拥有某个角色。或者细粒度的验证某个用户对某个资源是否具有某个权限;
(3)会话管理,即用户登录后就是一次会话,在没有退出之前,它的所有信息都在会话中;会话可以是普通JavaSE环境的,也可以是如Web环境的;
(4)加密,保护数据的安全性,如密码加密存储到数据库,而不是明文存储;
(5)Web支持,可以非常容易的集成到Web环境;
Caching:缓存,比如用户登录后,其用户信息、拥有的角色/权限不必每次去查,这样可以提高效率;
(6)shiro支持多线程应用的并发验证,即如在一个线程中开启另一个线程,能把权限自动传播过去;
(7)提供测试支持;
(8)允许一个用户假装为另一个用户(如果他们允许)的身份进行访问;
(9)记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录了。
文字描述可能并不能让猿友们完全理解具体功能的意思。下面我们以登录验证为例,向猿友们介绍Shiro的使用。至于其他功能点,猿友们用到的时候再去深究其用法也不迟。
十一、设计模式
这个算不上框架,可自行忽略,不过我认为设计模式的思想很有必要了解一下。
思想:
开闭原则:
开闭原则就是说对扩展开放,对修改关闭。在程序需要进行拓展的时候,不能去修改原有的代码。
针对接口编程,针对接口编程,依赖于抽象而不依赖于具体。
尽量使用合成/聚合的方式,而不是使用继承。
一个实体应当尽量少的与其他实体之间发生相互作用,使得系统功能模块相对独立。
使用多个隔离的接口,比使用单个接口要好。
里氏代换原则:
(1)子类的能力必须大于等于父类,即父类可以使用的方法,子类都可以使用。
(2)返回值也是同样的道理。假设一个父类方法返回一个List,子类返回一个ArrayList,这当然可以。如果父类方法返回一个ArrayList,子类返回一个List,就说不通了。这里子类返回值的能力是比父类小的。
(3)还有抛出异常的情况。任何子类方法可以声明抛出父类方法声明异常的子类。 而不能声明抛出父类没有声明的异常。