微服務是一種架構風格,一個大型復雜軟件應用由一個或多個微服務組成。系統中的各個微服務可被獨立部署,各個微服務之間是松耦合的。每個微服務僅關注于完成一件任務并很好地完成該任務。在所有情況下,每個任務代表著一個小的業務能力。
問題:微服務有什么用?
解答:解決單體應用規模增加時帶來的問題。
微服務 vs 單體應用
- 單體應用將所有功能放在一個單一進程中
- 微服務把每個功能元素放進一個獨立的服務中,在多個服務器復制,跨服務器統一管理
- 單體應用優點:穩定,性能,部署
- 單體應用缺點:中心化,耦合,學習成本,伸縮性,持續交付
- 適情況選擇單體應用或微服務,不要為了技術而技術
分布式系統如何解釋?
簡單來說,分布式系統就是一群獨立計算機集合共同對外提供服務,但是對于系統的用戶來說,就像是一臺計算機在提供服務一樣。集中式系統集中式系統就是把所有的程序、功能都集中到一臺主機上,從而往外提供服務的方式。比如,我們主機的PC電腦,或者手機,我們把各種軟件都安裝在一臺機子上,當我需要什么功能,我就從這臺機子上去獲取。再比如,我們在學生時代做的課程設計或者開發時的小應用,我們把Web服務器、數據庫等都會安裝到一臺電腦上。好處是,易于理解、方便維護,想要的東西我都放到了一個地方,東西好找啊。當然弊端也是顯而易見的,如果這臺機子崩了,或者硬盤壞了,那相當與整個系統就奔潰了,而且如果備份也是在這個硬盤上,那相當于招了滅頂之災。
Web 編程基礎
靜態Web
概述:靜態web內容由web服務器文件系統提供,路徑為文件系統的路徑,常見的靜態web內容有,html,css,js,jpeg等
常用的靜態web服務器
- Apache Http Server
- Nginx
- Micrsoft lls
靜態web優化
- http資源變化,如 last-modified<--->if-modified-since
- http資源緩存,如ETag<---> if-None-Match
動態Web
概述: 與靜態web不同,請求內容通過服務器計算而來的
流行的JAVA web服務器
- servlet容器(Tomcat,jetty)
- 非servlet容器(undertow)
動態技術/架構演變
- CGI (common gateway interface)
- Servlet (server Applet)
- JSP (java server page)
- MVC (model - view - controller)
問題:mvc 的執行流程?
- 用戶通過客戶端發送HTTP請求,傳至web服務器如tomcat
- servlet(實際是dispacherservlet)充當controller處理分發請求,傳至model層
- model層包括了一系列的邏輯處理,包括數據庫操作,最后返回一個java beans
- dispachersevlet將結果返回給服務器,服務器返回處理好的view給客戶端
- 客戶端渲染展示給用戶
模板引擎
velocity: apache 產品,現已不維護
jsp: 使用較廣泛,編譯流程:.jsp-->.java -->.class 。內部可嵌入java語法,導致耦合度較高
themleaf: 新模板引擎
freemarker: 較穩定的一類
REST理論基礎
- 來源:來自于Roy Thomas Fielding 2000年的博士論文 - 《Architectural Styles and the Design of Network-based Software Architectures》
- 概念:REST = RESTful =Representational State Transfer,一種軟件架構風格
- 架構屬性:性能,可伸縮性,統一接口簡化性,組件可修改性,可靠性等等
Springboot Rest 核心接口
定義相關
- @Controller
- @RestController
映射相關
- @RequestMapping(path={映射路徑}, produces = {返回response的類型}, consumes={接收request的類型})
- @PathVariable
請求相關
- @RequestParam
- @RequestBody
- @RequestHeader
- @CookieValue
- RequestEntity
響應相關
- @ResponseBody
- ResponseEntity
接口默認返回xml只需添加maven節點
<dependency> <groupId>com.fasterxml.jackson.dataformat</groupId> <artifactId>jackson-dataformat-xml</artifactId> </dependency>
Servlet 的在web中應用
什么是servlet?
是一種基于java技術的web組件,由容器管理,用于生成動態內容,由java web 服務器加載執行
什么是servlet容器?
Servlet 容器,有時候也稱作為 Servlet 引擎,作為Web服務器或應用服務器的一部分。通過請求和響應對話,提供Web 客戶端與 Servlets 交互的能力。容器管理Servlets實例以及它們的生命周期。
Servlet 歷史發展如何?
1997年六月,Servlet 1.0 版本發行,最新版本 Servlet 4.0 處于研發狀態。
Servlet生命周期
- 初始化:當容器第一次執行時,servlet### init(servletConfig) 方法執行
- 請求處理:Http請求到達容器時,servlet### service(ServletRequest req,ServletResponse rep)方法執行
- 銷毀:當容器關閉時,容器將會調用Servlet### destroy() 方法被執行,銷毀當前Servlet
Fileter生命周期
- 初始化:當容器啟動時,Filter#init(FilterConfig)方法被執行,初始化當前Filter
- 請求處理:當http請求到達容器是,Filter#doFilter(ServletRequest,ServletResponse,FilterChain) 方法被執行,可用來攔截請求,所以會在servlet請求處理之前調用
- 銷毀: 當容器關閉時,容器將會調用Filter#destroy 方法被執行,銷毀當前Filter
Listener 生命周期
- 監聽請求:當監聽到Http請求時,Listener## requestInitialized(ServletRequestEvent sre)方法執行一次
- 銷毀:當請求執行完畢,并返回結果時,Listener## requestDestroyed(ServletRequestEvent sre) 執行一次
Http請求生命周期大致為:
- Listner--> requestInitialized 方法
- Filter --> init 初始化方法
- Filter --> doFilte 處理方法
- Servlet --> init 初始化方法
- servlet --> service 方法
- listener --> destroy 方法