1.1.什么是有狀態?
有狀態服務,即服務端需要記錄每次會話的客戶端信息,從而識別客戶端身份,根據用戶身份進行請求的處理,典型的設計如tomcat中的session。
缺點是什么?
-
服務端保存大量數據,增加服務端壓力
-
服務端保存用戶狀態,無法進行水平擴展
-
客戶端請求依賴服務端,多次請求必須訪問同一台服務器
1.2.什么是無狀態?
微服務集群中的每個服務,對外提供的都是Rest風格的接口。而Rest風格的一個最重要的規范就是:服 務的無狀態性,即:
-
服務端不保存任何客戶端請求者信息
-
客戶端的每次請求必須具備自描述信息,通過這些信息識別客戶端身份
帶來的好處是什么呢?
-
客戶端請求不依賴服務端的信息,任何多次請求不需要必須訪問到同一台服務
-
服務端的集群和狀態對客戶端透明
-
服務端可以任意的遷移和伸縮
-
減小服務端存儲壓力
什么是RSA加密?
RSA稱為非對稱加密,加密技術是對信息進行編碼和解碼的技術,編碼是把原來可讀信息(又稱明文)譯成代碼形式(又稱密
文)其逆過程就是解碼(解密)
,加密技術的要點是加密算法,RSA會根據你給的 鹽值
生成私鑰和公鑰:
-
私鑰:通過
私鑰
加密的數據使用私鑰
或者公鑰
來解密。 -
公鑰:通過
公鑰
加密的數據只能使用私鑰
來解密。 -
優點:安全,難以破解
-
缺點:算法比較耗時
什么是JWT?
JWT,全稱是Json Web Token
, 是JSON風格輕量級的授權
和身份認證規范
,可實現無狀態、分布式的 Web應用授權。
看名知意,其實就是一種加密方式,分為三部分:
-
Header(頭部)
:一般只包含兩部分信息:-
聲明加密的算法,這里使用的是HS256的加密算法。
-
聲明Token的類型,這里使用的是JWT的風格類型。
-
-
Payload(載荷)
:存放一些有效數據比如用戶ID、用戶名稱,解密之后可以獲取載荷
中的用戶信息,因為采用Base64編碼格式,所以可以被解碼,不要放敏感信息,例如登錄密碼之類的。 -
Signature(簽名)
:Signature由header
和payload
經過 base64 編碼后加鹽值
得到的。-
生成Signature的算法如下:
-
var encodedString = base64UrlEncode(header) + "." + base64UrlEncode(payload); HMACSHA256(encodedString, '!Q@#$%^%&');
-
在分布式下完成SSO單點登錄
只使用JWT來完成單點登錄
有了JWT為什么還需要RSA?
可以發現,每次鑒權都需要訪問鑒權中心,系統間的網絡請求頻率過高,效率略差,鑒權中心的壓力較大。
這時就用到了前面說的RSA,我們可以把私鑰
留在授權中心,把公鑰
給網關或者其他微服務,那么就可以在網關或其他微服務當中直接解密JWT了,這樣做的好處是減少了授權中心的壓力。
使用JWT+RSA完成單點登錄