内容简介:2018技术盘点2018年的最后一天,安安静静的在家里进行这一年的盘点,这一年发生的事情着实不少。印象深刻的也很多,下午花了4个小时盘点了这一年生活方面的点滴。作为一个码农,2018年作为自己正式迈入码农圈的第一个半年,在技术方面自然也学到了不少东西。所以借着2018年最后几个小时,对这半年来自己在技术上的成长做一次盘点,为后续的职业生涯奠定一个风向标。对于个人总结而言主要分为两个维度,首先是从业务的角度,其次是从个人成长的角度。然而对于博客而言,今天就先暂时不对业务方面进行总结了,毕竟业务方面已经通过绩效
2018技术盘点
2018年的最后一天,安安静静的在家里进行这一年的盘点,这一年发生的事情着实不少。印象深刻的也很多,下午花了4个小时盘点了这一年生活方面的点滴。作为一个码农,2018年作为自己正式迈入 码农 圈的第一个半年,在技术方面自然也学到了不少东西。所以借着2018年最后几个小时,对这半年来自己在技术上的成长做一次盘点,为后续的职业生涯奠定一个风向标。
个人技能树
对于个人总结而言主要分为两个维度,首先是从业务的角度,其次是从个人成长的角度。然而对于博客而言,今天就先暂时不对业务方面进行总结了,毕竟业务方面已经通过绩效评价已经总结过了。这篇博客则对个人这半年来在技术上的成长进行盘点。
概览
下图主要展示了在这半年的时间中个人涉猎的技术。下文则具体总结自己对于这些技术的掌握情况。
日志收集链路
在日志收集链路中,自己主要针对日志收集SDK Log4j2以及收集的通道性的组件Flume进行了解
Log4j2
对于Log4j2,自己通过源码的学习,了解了其中LogManager的启动原理,了解了其中最核心的组件LogContext,Configure之间的关系。其次,更细节的,掌握了其中Plugin的开发流程以及Plugin的核心管理组件PluginManager的工作原理。最后,研读了AsyncAppender以及AsyncLogger的源码。对于Log4j这一 Java 最为常用的日志组件有了全方位的认识以及更深入的理解。对于之前的一些打印日志出现的异常,现在已经能够比较快速地定位到源码层次的问题所在。
Flume
Flume在整个日志收集链路扮演者一个十分重要的角色,主要功能个人理解为前后解耦的一级消息队列,负责中转前端日志组件发来的日志,然后通过source->channel->sink的传输模型将消息发送到后端日志存储,例如Kafka,Pulsar等。通过半年的工作,对Flume的原理有了更深入的理解,然而在源码方面,感觉还是有所欠缺,目前对于源码层次的掌握,只存在于Flume的启动流程。其中对于Supervisor的 设计模式 对后续的其他代码的开发具有比较大的借鉴意义。
实时计算引擎Flink
作为日志收集的下游,实时计算引擎方面在这半年接触的更多是Flink,这主要是因为Flink目前迅速的发展趋势,以及阿里巴巴的大力宣传,这半年来,自己通过参加Flink Meetup以及12月刚刚结束的Flink Forward China,了解了目前各大互联网公司对Flink这款新兴实时计算引擎的应用。个人方面,了解了Flink中的核心组件,例如JobManager,TaskManager的大致定位,作业提交流程以及Flink中核心的State定义以及数据形态。但不足之处在于实战经验过少。
实时数据存储
与以HDFS为核心的离线存储不同,实时计算由于对时效性要求更高,所以需要对以Kafka为核心的实时存储进行深入理解。在这半年中,通过精读论文《Kafka: a Distributed Messaging System for Log Processing》了解了Kafka中的数据模型,包括Topic,Partition,offset,以及通信模型Consumer,Producer,Broker之间的交互。跟自己入职面试时相比,对Kafka的理解应该是更加深入的(面试时貌似是好多概念都不懂呢)
Pulsar
Pulsar是前Twitter工程师研发的,号称比Kafka更加云原生的实时计算存储组件,其核心则是将存储于处理完全进行分离,broker与底层bookie能够灵活的进行分离部署,对于数据存储与数据计算的关系,Pulsar认为,存储计算分离不仅能够更加灵活的独立调整底层的存储能力外,重要的还有存储计算分离能够在计算完全不受影响的情况下对存储节点进行重启。Pulsar将订阅这一动词做成了一个抽象的概念,下面可以继承三种消费状态,“独占式”,“灾备式”以及共享式,能够灵活的适应线上对于消息队列以及类似Kafka这种实时存储的场景。
Bookeeper
作为Pulsar的底层存储,Bookeeper是转为Append only这种日志结构的数据量身定做的存储系统,在设计上,与Kafka有一些相似的特性,这里面相关的特性主要集中在论文《Durability with BookKeeper》中,由于阅读笔记的思维导图过大,我将抽空将思维导图文档化,总结出相应的博客
数据存储系统通用原理
今年下半年的一个重要发现就是看了一本好书《Desingning Data Intensive Applications》这本书真的是我这几年发现的少见的好书,虽然很厚,但是每一页都十分重要,相比现在大多数技术书都是你抄我,我抄你这种模式真的是少见了,这本书首先一点就是介绍的十分全面,从纵向维度,主要包括数据结构,数据存储,数据查询进行阐述,横向维度,则设计单机数据存储系统以及分布式系统,其中还包括一些分布式系统中一些特有的问题进行描述,包括分布式事务,分布式锁等方面。第二则是十分易懂,自己曾经看过一些相关的数,感觉没有一本书能像这本书一样能把一个十分晦涩的原理介绍的十分清晰地,这充分体现了作者的底蕴,毕竟自己理解很容易,能让人理解却绝非易事。在19年,自己希望吧所剩的看完后,再重新看一遍这本书,对于每一张进行整理,最后尽可能多的理解这些原理,最后达到玩转存储系统的目的。
系统栈处理问题
对于这一方面,更应该是细水长流的问题,这点我深信不疑。我曾在毕业论文里就谈到过,大数据处理系统的一个非常重要的特点就是,系统栈十分复杂,各个层级之间会相互影响。所以作为大数据系统的开发者,遇到旁人所说的“疑难杂症”的概率会高于其他业务线,因为越是底层的系统,和操作系统打交道越多,自己一直觉得,大数据系统中,从尽可能要节约成本的角度出发,一定要尽可能的压榨干每一台提供服务的服务器的一切资源。如何从操作系统的指标中快速地发现系统异常的具体原因的技能应该是我们每个系统开发者必须具备的能力,否则早晚会面临淘汰。在这个方面,自己只能一点点的根据外部的资料以及平时组内查问题的套路得到一些经验,这里极客时间倪鹏飞老师的《Linux性能优化指南》是个不错的选择。
编程语言与框架
最后则是一些实战性的东西,这里主要和我这半年来所涉及的工程有关,这些东西的学习感觉本着实用的原则即可,随着工程一点点的进行总结积累。
自己期待的技能树
还有2小时就到新的一年了,通过了这半年的适应,自己也算是适应了职场的工作节奏,对于自己所研究的方向也有了初步的认识,所以在19年到来之际,列出了自己期望达到的技能树。
硬实力
我主要将自己需要具备的能力分为两个大的能力,软实力与硬实力,硬实力则是自己身为一个大数据系统开发人员,尤其偏向存储方向的开发人员应该掌握的技能。
首先明确自己的主攻方向,大数据处理平台数据收集一环,这一环作为大数据处理平台的源头,虽说看似涉及的绝对核心引擎以及开源组件有限,但是却是相当关键,因为如果数据不存在了,后面的一切能力等于空谈。作为数据收集链路而言,个人将其分为以下的三个环节,分别为上报,介质以及传输通道。对于上报而言,主要还是通过通用的日志上报组件进行上报,对于Java而言,最核心的就是Log4j,因此对于这款组件的掌握需要全面,透彻。而介质可以理解为组件将日志最终打印到那里,是直接通过网络上报,还是缓存在本地磁盘中。这里更像提得是第二种情况,对于磁盘文件的监控,其实是一个非常复杂和困难的,因为这涉及了 linux 系统在文件操作时所做的具体操作,只有抓住这些操作的核心特征,才能够对各种事件进行准确的识别。
完成了收集,需要一个存储引擎最终将日志进行保存,以便后续的消费,这里的存储引擎应特质那些具有时效性的实时存储,例如Kafka,Pulsar,bk等等,自己需要对这些引擎进行探究,以便能够根据实际场景灵活选取。这里之所以将离线存储也放进来,是为了通过对比实时存储以及离线存储找出其中的异同,存储最终都是和存储介质打交道,只不过上层逻辑不同,对存储介质的读写方式有差异。所以试图总结出开发存储系统中的共性问题,对于解决个性问题显然是个利远大于弊的方式。
作为工程师而言,不应将自己的边界定的过于狭窄,需要把边界放的宽一些,作为日志下游的消费方,计算,查询引擎必不可少,作为实时存储来讲,如何针对计算引擎以及部署方式优化存储引擎也十分重要,因此个人认为需要对计算和查询引擎有一些原理上的掌握。
软实力
相比硬实力而言,软实力基本是一些更抽象化的内容,根据提升方面的不同,自己同样分为两块,一块是技术方面的软实力,另一方面则覆盖面更广一些,包括自己的性格,习惯等。这里的技术软实力我还是想具体一点说,基本应该就是如何从系统栈的角度解决问题,代码的运行,尤其是大数据程序的运行一定脱离不开其所在的系统栈,不仅仅是软件栈,还包括操作系统以及硬件的交互,对一个系统的优化或排查问题应当从整体的系统栈出发,从包括代码层,运行时环境层,操作系统层以及硬件层综合考虑,往往比“头疼医头,脚疼医脚”的这种局部治疗方法从长期看能够取得更加好的效果,当然这也是存在代价的,因为从整体考虑问题的方式在最开始一定会比之前的方式考虑时间要长,但在一些优先级不高的问题上,自己认为有必要坚持这种全局的思考问题的方式。
其次就是如何提高自己其他方面的软实力,包括性格,个人职业规划如何思考问题等方面,这些则应该敦促自己多看一些相关书籍时常为自己充电,让自己时刻保持一个积极乐观,对世界充满好奇的方式在自己的职业生涯一步一个脚印的踏踏实实的行走。
写在最后
终于赶在新年之前完成了这篇盘点文,更多的应该是对自己的激励,对比自己期望的技能树与目前的技能树,会发现自己需要补充的太多太多。技术就是这样,要么追求卓越,要不就不要做,不管到什么时候都要提醒自己,做技术不仅是为了挣钱,否则很容易产生惰性,自律永远不是一件容易的事,不过自己还是会努力。希望自己19年能够距离自己期望的技能树越来越近,技术更上一层楼,大家新年快乐~~~
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- WACV 2021 论文大盘点:人脸技术篇
- 盘点2018年十大新兴技术:人体变成“制药工厂”
- PORTSWIGGER:2018年十大Web攻击技术盘点
- CVPR 2019 论文大盘点-人脸技术篇
- 国内十大技术突破盘点,我们也有世界领先的工艺!
- 盘点一下那些不知不觉中已经渗入生活的AI技术…
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java编程思想
埃克尔 / 机械工业出版社 / 2007-5-1 / 79.00元
《Java编程思想(英文版•第4版)》内容简介:特色:1.适合初学者与专业人员的经典的面向对象的叙述方式;为更新的Java SE5/6的相关内容增加了新的示例和章节。2.测验框架显示程序输出。3.设计模式贯穿于众多示例中:适配器、桥接器、职责链、命令、装饰器、外观、工厂方法、享元、点名、数据传输对象、空对象、代理、单例、状态、策略、模板方法以及访问者。4.为数据传输引入了XML;为用户界面引入了S......一起来看看 《Java编程思想》 这本书的介绍吧!