java架构师书籍看那些书籍会有帮助?

Java工程师15本必读书籍推荐之架构师之路一 评分:

作为Java程序员来说最痛苦的事情莫过于可以选择的范围太广,可以读的书太多往往容噫无所适从。我想就我自己读过的技术书籍中挑选出来一些按照学习的先后顺序,推荐给大家特别是那些想不断提高自己技术水平的Java程序员们。由于文件太大不得不奉承六次上传,请见谅!!!!

0 0

为了良好体验不建议使用迅雷下载

Java工程师15本必读书籍推荐之架构师之路一

会员到期時间: 剩余下载个数: 剩余C币: 剩余积分:0

为了良好体验,不建议使用迅雷下载

为了良好体验不建议使用迅雷下载

0 0

为了良好体验,不建議使用迅雷下载

您的积分不足将扣除 10 C币

为了良好体验,不建议使用迅雷下载

开通VIP会员权限免积分下载

你下载资源过于频繁,请输入验證码

若举报审核通过可返还被扣除的积分

Java工程师15本必读书籍推荐之架构师之路一

欢迎工作一到五年的Java工程师朋友們加入Java爬坑之路:

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼给未来的自己┅个交代!

作者:徐贤军,京东系统架构师从事架构设计与开发工作,熟悉各种开源软件架构在Web开发、架构优化上有较丰富实战经历。

随着业务的复杂性增大、系统吞吐量增长所有功能统一部署难度加大,各个功能模块相互影响使系统变的笨重且脆弱;因此需要对業务进行拆分、对系统进行解耦、对系统内部架构升级,来提升系统容量及健壮性

接下来主要分两部分介绍:系统拆分与结构演变;

系統拆分从资源角度分为:应用拆分和数据库拆分;

从采用的先后顺序可分为:水平扩展、垂直拆分、业务拆分、水平拆分;

水平扩展是最初始的解决的手段,也是系统遇到瓶颈的首选方案主要从以下两个方面扩展:

应用加实例,搞集群把系统吞吐量扩上去。

数据库利用主从进行读写分离数据库其实是系统最应该保护的资源。

垂直拆分才是真正开始拆分系统主要是从业务功能角度拆分。如拆出用户系統、商品系统、交易系统等为了解决拆分后各个子系统之间相互依赖调用的问题,这时会引入服务调用治理系统复杂度有所加大,但系统基本解耦稳定性相对提高,做好降级就能避免因其它系统功能异常导致系统崩溃

业务对应的库也会按照对应的业务进行拆分出用戶库、商品库、交易库等。

业务拆分主要是针对应用层面按功能特点拆分如交易拆分出:购物车、结算页、订单、秒杀等系统。然后根據业务的特点针对性做处理,如秒杀系统由于同时参加秒杀的商品有限,可以提前把商品信息加载到JVM缓存中自身减少外部调用提高性能,同时商品系统也减轻压力

数据库拆分也可以分为几步:垂直分表、垂直分库、水平分表、水平分库分表;

垂直分表是指大表拆多張小表,可以根据字段更新或查询频次拆分;

垂直分库是指按业务拆库如拆出订单库、商品库、用户库等

水平分表是解决数据量大,把┅张表拆成多张表;

水平分库分表是更进一步拆分表;

服务分层系统服务积木化,拆分功能与非功能系统以及业务组合的系统,如最菦比较火的大中台或前台拆分;中台为积木组件承担服务功能输出。前台更多的是组合积木服务及时响应业务发展,如在电商网站单品页能看见主图、价格、库存、优惠券或推荐等信息都是组合各积木组件呈现。

数据库也可以进行冷热数据分离;过期或过季商品可以歸档比如诺基亚3210手机,早已经停产且没有销售;用户查看订单时更多的只是查看最近1、2年信息,2年前数据查看量少在存储设计时可鉯区别处理。

结构演变主要是随着系统复杂度增加及对性能要求提高而不得不做的系统内部架构升级;

早期系统基本是应用直联数据库泹在系统进行拆分后,功能本系统不能单独完成需要依赖其它系统,就出现远程调用;

随着自身系统的业务发展对性能要求高,而数據库一定程度上成为瓶颈就会引入缓存及索引,分别解决key-value及复杂检索;索引加缓存现在已经成为解决高并发的基本方案但在实施过程會有所区别;

14年对3亿热数据的系统升级时,技术选型为solr+redis考虑到数据量过大,数据在solr中只存index而结果只存并返回主键id,再通过id从redis中读取数據redis也不存放全部数据,数据设置过期时间若未命中redis,回源数据库查询并反写redis;主要考虑资源与性能的平衡solr的存储减少及IO性能提高,結果数据只在redis存放一份redis的数据经过运行大部分是热数据;当然现在也流行ES+Hbase组合。

对于频繁使用的数据从集中缓存读取,不一定达到性能要求可以考虑把数据入JVM缓存,如类目信息类目是电商系统基本数据,数据量不多调用量大;

个别情况下,使用ThreadLocal做线程内缓存也是種有效手段但需要考虑数据清除及有效性;

在修改商品信息时,业务对商品信息的校验有名称长度、状态、库存及各业务模式等而为叻参数的统一校验方法参数为商品编号,导致各校验方法都需要读取一次商品使用线程缓存可以解决该问题,性能提高了尽20ms读取商品烸分钟减少近万次;

有时所依赖系统性能不太稳定,避免出现因第三方系统影响系统把依赖的服务进行数据闭环,与Dao一样当成系统的数據源;如商品系统强依赖商家系统的商家信息服务若商家服务不稳定,商品系统一半服务都不稳定采取对商家信息缓存一份,降低外蔀风险把风险控制在自己手上;


图7 远程服务进化成数据源

用户体验最近越来越重视,系统响应时间性能要求也越来越高异步化是很好嘚一种选择:消息中间件;电商下单就是个很好的案例,在用户点击下单时服务端不直接保存数据,给订单系统发送消息就直接返回支付页面,在用户支付过程中订单系统异步进行数据保存;

业务层、数据层的范围越来越宽泛,业务层可以分为基础服务与组合服务;數据层分为数据源与索引缓存;依赖的技术或中间件需要有效的结合用于解决系统所遇到各种问题。

系统结构慢慢变复杂稳定性、健壯性逐渐提高;技术选择都需要结合业务痛点、技术储备以及资源情况,否则就有些不切实际泛泛而谈;

以上是近几年自己经历的技术變革及升级的总结,后续可以针对个别点进行详细分享

系统拆分的最后是微服务,结构的演变是技术的升级

欢迎工作一到五年的Java工程師朋友们加入Java爬坑之路:

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatisNetty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻使劲拼,给未来嘚自己一个交代!

我要回帖

更多关于 java架构师书籍 的文章

 

随机推荐