1. 程式人生 > >Java進階部分的總結,你們都學會了嗎?

Java進階部分的總結,你們都學會了嗎?

一直說學Java,做Java開發,其實並沒有做一個系統的總結。那麼做一個Java開發,或者是高階Java開發、架構師,到底要會哪些東西,哪些原理,先簡單做一個總結,也希望能監督自己按這個路線一直的學習和總結下去。

基礎知識:

Java反射:Field、Type

Java代理:proxy、cglib

Java執行緒:Thread、Runnable、ExecutorService、Callable、Future、ThreadPoolExecutor

Java資料結構:HashMap ArrayList LinkedList HashSet BlockingQueue ConcurrentHashMap TreeMap

JVM:執行時資料區、堆設定、收集器設定、回收日誌分析

Lambda表示式:stream、filter、collect、map、forEach、

併發與鎖:synchronized、ReentrantLock、ReadWriteLock、Atomic;

通訊協議:HTTP、TCP/IP、NIO、BIO、WebSocket

資料結構:表、棧、佇列、二叉樹、AVL樹、BTree、黑紅數、雜湊、圖。

常用演算法:氣泡排序,選擇排序,插入排序、堆排序,歸併排序、快速排序;二分查詢;布隆過濾器;

設計模式:工廠模式、觀察者模式、單例模式、代理模式、命令模式、策略模式

Web容器:tomcat、jboss、jetty

HTTP服務:httpd、nginx、openResty、kong

工具包:common、poi、gson、guava

構建工具:maven、gradle

通訊框架:netty、mina

序列化:hessian、protostuff、json

服務發現:zookeeper、etcd、eureka、consul

資料庫:mysql、mongoDB、redis、mycat、berkeleyDB

連線池:dbcp、c3o0、druid、jdbc、http

大資料:spark、storm、hadoop、hdfs

容器:docker、k8s

監控:zabbix、prometheus

開源框架:

Spring:IOC、AOP、事務處理

SpringMVC:DispatcherServlet、HandlerMapping、HandlerAdapter、Controller、Intercepter、View

SpringBoot:整合web、hibernate、mybatis、redis、docker下使用

SpringCloud:Netfix、Config、Bus、Eureka、Consul、Stream、Task、Gateway

Hibernate:Configuration、SessionFactory、樂觀鎖、二級快取、高併發、多資料來源

Mybatis:Configuration、SqlSession、Executor 、TypeHandler、動態sql、二級快取

Netty:nio、拆念包、future、pipeline

Guava:限流演算法、布隆過濾器、JVM快取

Hystrix:隔離、熔斷、降級

訊息佇列:rabbitMQ、rocketMQ、kafka

RPC框架:dubbo、motan、thrift、grpc

搜尋隱形:Lucene、Elasticsearch、Solr

資料庫:

Mysql:主備、讀寫分、橫向縱向拆分、調優、語法、索引、優化

Redis:主備、讀寫分離、持久化、命中和過期

MogoDB:集合、文件、檔案、索引、聚合函式、分片

訊息佇列:

概念:topic、message、queue、producer、consumer、broker

訊息型別:順序訊息、定時訊息、延遲訊息、事務訊息

訊息回溯、訊息堆積、訊息拉取、訊息簽收

高併發:

服務拆分:微服務化、分散式事務、資料庫水平垂直拆分

服務治理:zookeeper、rpc

訊息佇列:非同步處理、最終一致性

快取技術:JVM快取、redis快取、nginx快取、CDN快取、瀏覽器快取。快取擊穿、快取雪崩、快取淘汰

高可用:

負載均衡:演算法、動靜分離、切換、檢測

超時重試:超時時間、重試機制和策略

限流:演算法、容器、nginx、防止抖動

隔離:執行緒隔離、程序隔離、機房隔離、讀寫隔離、動靜隔離,採用hystrix、servlet3做隔離熔斷

降級:自動降級、人工降級,控制中心,採用hystrix手段

監控:程序監控、執行緒監控、機器監控,報警

問題解決

1.如何解決單點故障;(lvs、F5、A10、Zookeep、MQ)

2.如何保證資料安全性;(熱備、冷備、異地多活)

3.如何解決檢索難題;(資料庫代理中介軟體:mysql-proxy、Cobar、MaxScale等;)

4.如何解決統計分析問題;(離線、近實時)

喜歡小編輕輕點個關注吧!