Java整理3

一.http協議web

二.hibernate緩存模式,級別;Hibernatemybatis的區別和優缺點數據庫

三.SQL優化經驗瀏覽器

四.分佈式集羣和Redis緩存

五.Spring Aop,動態代理;安全

六.多線程安全問題,多線程實現 thread local服務器

 

一.HTTP協議(HyperText Transform protocal 超文本協議)session

1.超文本協議是一個基於請求與響應模式的、無狀態的、應用層的協議,常基於TCP的鏈接方式,http1.1版本是一種連續性鏈接機制,絕大多數web開發都是構建在http協議之上。mybatis

 

2.網頁響應過程:輸入www.baidu.com回車多線程

域名響應-》發起TCP3次握手-》創建TCP的鏈接後發起http請求-》服務器響應http請求,瀏覽器獲得HTML代碼-》瀏覽器解析HTML代碼-》頁面渲染框架

 

3.http 無狀態的

協議對於事務處理沒有記憶能力

 

4. 主要方法getpost請求方法的區別

1 Get方法主要是向服務器獲取資源,post重點是向服務器發送數據;

2.Get傳輸數據經過URL請求,數據可見,用?鏈接。對用戶可見,明文不安全,Post是經過httppost機制,將字段對應封存在請求實體中發送給服務器,對用戶不可見,安全性高;

3.Get方式只支持ASCII字符,中文可能亂碼。Post支持標準字符集,能夠傳輸中文。

4.Get傳輸的數據量小,受URL長度的限制,可是效率高。Post能夠傳輸大量數據,因此上傳文件時只能用post

 

二.Hibernate

1. Hibernate緩存機制和三種狀態

緩存就是要將一些常用的數據緩存到內存或者各類儲存介質中,當再次使用時能夠不用去數據庫中查詢,減小與數據庫的交互,提升性能。
再說明一級與二級緩存的做用:一級緩存是Session級別的,也就是說在一個事務中才會啓做用。好比在一個事務中同時查詢同一個對象,則不會兩次去數據庫中查詢。
而二級緩存是sessionFactory級別的,不一樣的事務之間是能夠共享的,有些權限,當用戶首次登錄後便將關聯的權限放到二級緩存中,這樣每次須要權限時就無需再查詢數據庫了。
最後再說明爲何這樣設計:通常狀況下,咱們查詢的數據通常是實時的,使用二級緩存確定不行,使用一級緩存既利用了緩存又不會影響實時。
使用二級緩存是爲了存儲一些比較穩定的數據,如權限,只有在用戶修改了權限且從新登陸時才能生效。

SessionFactory的緩存分爲內置緩存和外置緩存。內置緩存中存放的是SessionFactory對象的一些集合屬性包含的數據(映射元素據及預約SQL語句等),對於應用程序來講,它是隻讀的。外置緩存中存放的是數據庫數據的副本,其做用和一級緩存相似.二級緩存除了之內存做爲存儲介質外,還能夠選用硬盤等外部存儲設備。二級緩存稱爲進程級緩存或SessionFactory級緩存,它能夠被全部session共享,它的生命週期伴隨着SessionFactory的生命週期存在和消亡。

三種狀態:

1. 零時狀態(瞬時狀態Transient) new對象開闢內存空間 User user=new User();

2. 持久狀態(persistent)

該狀態的對象在數據庫中具備對應的記錄,並擁有一個持久化標識.經過session的 get()、load() 等方法得到的對象都是持久對象。持久化對象被修改變動後,不會立刻同步到數據庫,直到數據庫事務提交。在同步以前,持久化對象是髒的。

3. 遊離狀態(託管狀態Detached)

當與某持久對象關聯的 session 被關閉後,該持久對象轉變爲遊離對象.當遊離對象被從新關聯到session上 時,又再次轉變成持久對象(在Detached其間的改動將被持久化到數據庫中)。遊離對象擁有數據庫的識別值,但已不在持久化管理範圍以內。

 

2Hibernatemybatis區別

Mybatis優點 面向過程

· MyBatis能夠進行更爲細緻的SQL優化,能夠減小查詢字段。

· MyBatis容易掌握,而Hibernate門檻較高。

Hibernate優點 面向對象

· HibernateDAO層開發比MyBatis簡單,Mybatis須要維護SQL和結果映射。

· Hibernate對對象的維護和緩存要比MyBatis好,對增刪改查對象的維護要方便。

· Hibernate數據庫移植性很好,MyBatis的數據庫移植性很差,不一樣的數據庫須要寫不一樣SQL

· Hibernate有更好的二級緩存機制,可使用第三方緩存。MyBatis自己提供的緩存機制不佳

相同點:HibernateMyBatis均可以是經過SessionFactoryBuiderXML配置文件生成SessionFactory,而後由SessionFactory 生成Session,最後由Session來開啓執行事務和SQL語句。其中SessionFactoryBuiderSessionFactorySession的生命週期都是差很少的。

4.Hibernate工做原理

1. 讀取並解析配置文件

2. 讀取並解析映射信息,建立session Factory

3. 打開session

4. 建立事務transation

5. 持久化操做

6. 提交事務

7. 關閉session

8. 關閉session factory

5.爲何要用hibernate

1.對JDBC訪問數據庫的代碼作了封裝,大大簡化了數據訪問層繁瑣的重複性代碼。
2.Hibernate是一個基於JDBC的主流持久化框架,是一個優秀的ORM實現。他能很大程度的簡化DAO層的編碼工做
3.hibernate使用Java反射機制,而不是字節碼加強程序來實現透明性。
4.hibernate的性能很是好,由於它是個輕量級框架。映射的靈活性很出色。它支持各類關係數據庫,從一對一到多對多的各類複雜關係。

6.Hibernate是如何延遲加載

涉及延遲加載的有getload方法,get不會延遲加載,load會延遲加載。另外在many-to-one關係中能夠經過lazy屬性設置是否延遲加載。

延遲加載的解釋是動態代理機制,在設置延遲加載後,hibernate返回給咱們的對象實際上是一個代理對象,並非真正的對象,該對象沒有真實對象的數據,只有在真正用到對象時(調用get方法時)時,纔會觸發hibernate去數據庫查找對象的數據,並且返回的數據不會存儲在代理對象中,是調試窗口查看不到的值。

7. Hibernate類之間的關係

配置many-to-one,one-to-many,many-to-many來實現類之間的關係

 

三.SQL優化經驗

1.exists代替innot exists代替not inin是全表掃描

2.in代替多個or;用union代替or適用於索引列)

3.避免在索引列上進行計算,將會全表掃描;在索引列上使用is nullis not null

4.SQL語句大寫,由於Oracle是將其轉化成大寫再執行的

5.union all效率高,可是會有重複數據;

6. 先用where過濾再group by比用group byhaving效率高

數據庫查詢優化

1. whereorder by後的列添加索引;2.儘可能避免在where中用null值判斷,這樣索引會失效對全表掃描,可添加默認值再過濾。同理where中用<>或!=,函數操做(索引失效)

 

四.分佈式集羣

相關文章
相關標籤/搜索