首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >怎么从初、中级Java程序员过渡到高级Java程序员?

怎么从初、中级Java程序员过渡到高级Java程序员?

作者头像
java架构师
发布2018-10-08 09:57:15
5930
发布2018-10-08 09:57:15
举报
文章被收录于专栏:Java架构师进阶Java架构师进阶

原文地址:https://www.toutiao.com/i6599524702937416195/

扩展性

分为垂直扩展和横向扩展,垂直扩展就是增加单台服务器的处理能力,需要你熟悉硬件、操作系统、中间件的知识;横向扩展一般就是指集群式部署,这都有行业解决方案,你需要做的只是将你的系统设计的具有可扩展性,说白了就是系统可以多份部署,但对外表现为单一应用。

分布式

单台服务器处理能力有他的极限,但是我们可以将某一个业务拆分成多个子业务,分别部署在不同的服务器上,说白了就是在设计的时候要注意业务的拆分,比如某一个交易平台,你把他拆分成几个子系统,做一个订单处理的应用,再做一个支付的应用等等,做成分布式应用

技术类——数据读写分离

数据库资源宝贵,扩展性较差,一般读多写少,读操作尽量可以通过缓存技术去读取缓存,使用自动进程定期将数据库中的数据写入缓存(EHCACHE/MEMCAHCE/REDIS等)中,这样可以大大降低交易数据库的连接压力,提高系统的并发能力。

技术类——连接池、队列、数据压缩等技术

通过连接池、队伍等实现方式来减少系统的开销,通过数据压缩技术减少带宽压力。

业务类

可能某些时候我们改变一下业务处理方式和业务流程,就可以大大降低系统开销,比如把某些耗时较长的同步处理转为异步处理

以上是高并发、高性能系统建设中最常见的几种做法或者思路。

哈利法塔和民房使用的材料都是混凝土和钢筋,前者需要系统的知识面、科学的方法论、良好的设计、灵活的工具使用,后者只需要把材料往上堆、往上糊就可以了,这就是民工与工程师的区别。

实际一点,做软件成长最快的方式当然是不断的写,不断的做项目,不断的学习,熟能生巧,不断的总结形成自己科学的方法论和知识库,这样才能游刃有余。如果接触不到更多项目,可以到GitHub上开开视野。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.09.10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档