1. 程式人生 > >如何突破JAVA程序員三年的門檻

如何突破JAVA程序員三年的門檻

你會 薪水 網上 情況 linux 性能調優 企業級 res rocketmq

第一階段:三年

我認為三年對於程序員來說是第一個門檻,這個階段將會淘汰掉一批不適合寫代碼的人。這一階段,我們走出校園,邁入社會,成為一名程序員,正式從書本 上的內容邁向真正的企業級開發。我們知道如何團隊協作、如何使用項目管理工具、項目版本如何控制、我們寫的代碼如何測試如何在線上運行等等,積累了一定的 開發經驗,也對代碼有了一定深入的認識,是一個比較純粹的Coder的階段。java學習群669823128

第二階段:五年

五年又是區分程序員的第二個門檻。有些人在三年裏,除了完成工作,在空余時間基本不會研究別的東西,這些人永遠就是個Coder,年紀大一些勢必被 更年輕的人給頂替;有些人在三年裏,除了寫代碼之外,還熱衷於研究各種技術實現細節、看了N多好書、寫一些博客、在Github上分享技術,這些人在五年 後必然具備在技術上獨當一面的能力並且清楚自己未來的發展方向,從一個Coder逐步走向系統分析師或是架構師,成為項目組中不可或缺的人物。

第三階段:十年

十年又是另一個門檻了,轉行或是繼續做一名程序員就在這個節點上。如果在前幾年就抱定不轉行的思路並且為之努力的話,那麽在十年的這個節點上,有些 人必然成長為一名對行業有著深入認識、對技術有著深入認識、能從零開始對一個產品進行分析的程序員,這樣的人在公司基本擔任的都是CTO、技術專家、首席 架構師等最關鍵的職位,這對於自己絕對是一件榮耀的事,當然老板在經濟上也絕不會虧待你。

第一部分總結一下,我認為,隨著你工作年限的增長、對生活對生命認識的深入,應當不斷思考三個問題:

1、我到底適不適合當一名程序員?

2、我到底應不應該一輩子以程序員為職業?

3、我對編程到底持有的是一種什麽樣的態度,是夠用就好呢還是不斷研究?

最終,明確自己的職業規劃,對自己的規劃負責並為之努力。

關於項目經驗

在網上經常看到一些別的朋友有提出項目經驗的問題,依照我面試的感覺來說,面試主要看幾點:項目經驗+基本技術+個人潛力(也就是值不值得培養)。

關於項目經驗,我認為並發編程網的創始人方騰飛老師講的一段話非常好:介紹產品時面試官會考察應聘者的溝通能力和思考能力,我們大部分情況都是做產品的一個功能或一個模塊,但是即使是這樣,自 己有沒有把整個系統架構或產品搞清楚,並能介紹清楚,為什麽做這個系統?這個系統的價值是什麽?這個系統有哪些功能?優缺點有哪些?如果讓你重新設計這個 系統你會如何設計?

我覺得這就已經足以概括了。也許你僅僅工作一年,也許你做的是項目中微不足道的模塊,當然這些一定是你的劣勢且無法改變,但是如何彌補這個劣勢?

從方老師的話中我總結幾點:

1、明確你的項目到底是做什麽的,有哪些功能。

2、明確你的項目的整體架構,在面試的時候能夠清楚地畫給面試官看並且清楚地指出從哪裏調用到哪裏、使用什麽方式調用。

3、明確你的模塊在整個項目中所處的位置及作用。

4、明確你的模塊用到了哪些技術,更好一些的可以再了解一下整個項目用到了哪些技術。

在你無法改變自己的工作年限、自己的不那麽有說服力的項目經驗的情況下(這一定是扣分項),可以通過這種方式來一定程度上地彌補並且增進面試官對你的好感度。

關於專業技能

寫完項目接著寫寫一名3年工作經驗的Java程序員應該具備的技能,這可能是Java程序員們比較關心的內容。我這裏要說明一下,以下列舉的內容不是都要會的東西—-但是如果你掌握得越多,最終能得到的評價、拿到的薪水勢必也越高。

java學習群669823128

01 高可用

負載均衡(負載均衡算法)

反向代理

服務隔離

服務限流

服務降級(自動優雅降級)

失效轉移

超時重試(代理超時、容器超時、前端超時、中間件超時、數據庫超時、NoSql超時)

回滾機制(上線回滾、數據庫版本回滾、事務回滾)

02 高並發

應用緩存

HTTP 緩存

多級緩存

分布式緩存

連接池

異步並發

03 分布式事務

二階段提交(強一致)

三階段提交(強一致)

消息中間件(最終一致性),推薦阿裏的 RocketMQ。

04 隊列

任務隊列

消息隊列

請求隊列

05擴容

單體垂直擴容

單體水平擴容

應用拆分

數據庫拆分

數據庫分庫分表

數據異構

分布式任務

06 網絡安全

SQL 註入

XSS 攻擊

CSRF 攻擊

拒絕服務(DoS,Denial of Service)攻擊

學習方向:

01、maven的使用

maven的使用入門

maven私服的搭建及部署

maven坐標分析/父控設置

02、git版本管理及jenkins自動化構建

git使用入門培訓

git常用命令分析和使用

jenkins環境搭建及插件配置

git+jenkins實現自動化構建

03、NoSql專題-redis高性能緩存

redis使用入門

redis常用命令及客戶端的使用

redis高可用集群搭建

04、NoSql專題-mongodb

mongodb使用入門

mongodb高可用集群搭建

mongodb常用命令及客戶端的使用

05、分布式專題-zookeeper+dubbo服務協調

zookeeper安裝部署及命令分析

zookeeper客戶端的使用

zookeeper實現原理分析

dubbo的使用入門及配置分析

zookeeper+dubbo實現服務註冊和發現

06、分布式專題-消息中間件

activeMq-jms規範及使用

activeMq消息分發機制分析

kafka實現原理剖析

kafka的數據傳輸事務性及實踐練習

07、分布式緩存分析對比

memcache的原理分析及使用

memcache和redis的橫向對比分析

分布式接口技術

webservice/RMI/restful的使用

09、高並發專題-數據庫層面優化

分庫分表的原理及規則講解

數據庫主備及高可用

10、性能調優專題-jvm調優

JVM原理剖析

jvm內存模型及垃圾回收器的分析

11、性能調優專題-容器性能優化

nginx性能優化

tomcat性能優化

12、性能調優專題-數據庫優化

mysql常見優化手段分析及實踐

13、高性能容器的使用

nginx使用入門

nginx負載均衡/反向代理實現

14、雙十一專題-九陽真經

太極聚氣之分布式壓測平臺

氤氳紫氣之分布式緩存體系

盤龍真訣之分布式消息系統

金剛之軀之分布式跟蹤系統

外功輔助之分布式配置系統

15、微服務架構技術棧分析

springboot的使用

16、分布式協調服務zookeeper

zookeeper集群及相關概念分析

zookeeper java api的使用及實踐

17、從集中式到分布式架構

分布式架構的演進過程

分布式架構的基石-TCP/UDP

18、分布式通信協議

分布式通信協議-HTTP及RESTful

分布式通信協議-webservice詳解

分布式通信協議-RMI

分布式通信協議-序列化技術

19、分布式服務治理

dubbo控制臺及監控中心的安裝部署

dubbo常用配置分析

dubbo實戰演練

20、NIO技術之-Netty

NIO基本概念及BIO、AIO的對比分析

NIO核心設計思想剖析(Buffer/Channel..)

Netty產生的背景及優缺點分析

Netty實現IM聊天系統

21、分布式緩存技術-Redis

redis的安裝及數據類型分析

Redis客戶端的使用

Redis高可用方案實戰

Redis+Lua腳本實現原子操作

22、高性能之道-MongoDB

MongoDB高可用部署

MongoDB動態查詢及索引剖析

MongoDB集成spring應用

23、數據庫高性能之道-Mysql

分庫分表深入分析

Mysql主從模型配置/Mycat的使用

24、分布式通信技術

JMS基本概念和模型

ActiveMQ結合Spring開發

ActiveMQ靜態網絡和動態網絡鏈接

Kafka的高可用方案及原理分析

25、SOA架構及微服務架構

什麽是SOA架構/為什麽需要SOA

領域驅動設計方法/典型SOA架構設計

spring boot深入剖析

spring boot+dubbo企業實戰

26、Docker虛擬化技術

Docker虛擬化技術(鏡像/倉庫/容器)

Docker整合spring boot

Docker 服務編排

27、導流技術

Nginx反向代理、負載均衡

Nginx進程模型分析

Nginx+keepalived高可用方案

28、微服務技術

spring boot(mvc)

spring boot(REST)

spring boot(驗證)

29、spring cloud

spring cloud config client

spring cloud config server

spring cloud netflix eureka

spring cloud netflix ribbon

spring cloud hystrix

spring cloud feign

spring cloud stream

spring cloud bus

spring cloud sleuth

30、分布式消息技術-kafka

kafka高可用集群及介紹

kafka底層實現原理分析

31、分布式緩存-redis

redis的數據類型分析

redis高可用集群方案

lua腳本在redis中的應用

32、高性能之道-MongoDB

MongoDB的基本原理

MongoDB常用命令及客戶端使用

手寫基於MongoDB的ORM框架

MongoDB高可用解決方案

33、數據庫高性能-Mysql

分庫分表深入分析及主從模型

數據庫中間件Mycat介紹

34、性能優化專題

從測試的角度解讀如何衡量性能

了解Linux系統

35、虛擬機-JVM

內存模型、運行時數據

垃圾回收、GC日誌

調優實戰

36、容器優化-Tomcat

tomcat架構分析

線程模型分析

tomcat調優實戰

37、Mysql數據庫調優

Mysql底層存儲分析

面試技巧之SQL執行計劃及優化手段

上面知識詞匯是否在你腦海裏呢?

java學習群669823128

如何突破JAVA程序員三年的門檻