01 簡介

IAM系統(tǒng)是什么

IAM(Identity and Access Management桌肴,身份識別與訪問管理)系統(tǒng)是用Go語言編寫的一個Web服務(wù),用于給第三方用戶提供訪問控制服務(wù)水醋。

IAM系統(tǒng)可以幫用戶解決的問題:在特定的條件下,誰能夠/不能夠?qū)δ切┵Y源做哪些操作蝇恶。即完成資源的授權(quán)功能撮弧。

IAM系統(tǒng)如何進(jìn)行資源授權(quán)呢耀盗?
  1. 用戶需要提供用戶名、密碼舌厨、郵箱等信息注冊登錄到 IAM 系統(tǒng)裙椭。以用戶名署浩、密碼作為唯一身份標(biāo)識訪問 IAM 系統(tǒng),并且完成認(rèn)證炊汤。
  2. 因?yàn)樵L問 IAM 的 資源授權(quán)接口 是通過密鑰(secretKey)的方式進(jìn)行認(rèn)證的弊攘,所以用戶需要在 IAM 中創(chuàng)建屬于自己的密鑰資源襟交。
  3. 因?yàn)?IAM 通過 授權(quán)策略 完成授權(quán)捣域,所以用戶需要在 IAM 中創(chuàng)建授權(quán)策略。
  4. 請求 IAM 提供的 授權(quán)接口 迹鹅,IAM 會根據(jù)用戶的 請求內(nèi)容授權(quán)策略 來決定一個授權(quán)請求是否被允許丘侠。
    功能示意圖

IAM系統(tǒng)架構(gòu)

IAM架構(gòu)中包括9大組件和3大數(shù)據(jù)庫:

  • 3大數(shù)據(jù)庫
    Mariadb蜗字、Redis、MongoDB
  • 5個核心組件
    iamctl粗梭、marmotedu-sdk-go、iam-apiserver断医、iam-authz-server滞乙、iam-pump
  • 4個旁路組件
    app、iam-webconsole鉴嗤、iam-operating-system斩启、Loadbalance

IAM系統(tǒng)使用到的3中系統(tǒng)資源

  • 用戶(User)
  • 密鑰(Secret)
  • 策略(Policy)

整個架構(gòu)可以拆分為三部分:

  1. 控制流 - 用戶、密鑰醉锅、授權(quán)策略的管理
    涉及組件及數(shù)據(jù)庫為:
    iamctl兔簇、iam-webconsole、iam-apiserver硬耍、marmotedu-sdk-go垄琐、Mariadb

    • iam-webconsole
      IAM系統(tǒng)的前端经柴,通過 RESTful API 調(diào)用 iam-apiserver 實(shí)現(xiàn)用戶狸窘、密鑰、策略的CURD
    • iamctl
      IAM系統(tǒng)的客戶端坯认,通過 marmotedu-sdk-go 訪問 iam-apiserver翻擒。iam-ctl 封裝了 iam-apiserver 的所有 RESTful API,還封裝了其它功能牛哺【麓纾可以通過命令行的方式訪問 iam-apiserver。
    • marmotedu-sdk-go
      IAM系統(tǒng)的 golang sdk荆隘,封裝了 iam-apiserver 和 iam-authz-server 的所有 RESTful API。
    • iam-apiserver
      核心組件赴背,通過 RESTful API 完成用戶椰拒、密鑰、授權(quán)策略的CURD
    • Mariadb
      持久性存儲用戶凰荚、密鑰燃观、授權(quán)策略


      控制流
  2. 數(shù)據(jù)流

    • APP
      第三方應(yīng)用,IAM系統(tǒng)的使用方便瑟。通過 RESTful API 或者 marmotedu-sdk-go 調(diào)用 iam-authz-server 提供的 /v1/authz 接口缆毁,完成資源的授權(quán)。

    • iam-authz-server
      授權(quán)服務(wù)
      為了提高 /v1/authz 接口的性能到涂, iam-authz-server 通過調(diào)用 iam-apiserver 提供的 gRPC接口脊框,將 密鑰和授權(quán)策略 信息緩存在 Redis 中颁督,以便實(shí)現(xiàn)快速查詢。

      同時浇雹,為了使 Redis 中的緩存信息和 iam-apiserver 中的信息 保持一致 沉御,當(dāng) iam-apiserver 中有密鑰或策略被更新時, iam-apiserver 會往特定的 Redis Channel 中發(fā)送 PolicyChanged 和 SecretChanged 消息昭灵。當(dāng) iam-authz-server 監(jiān)聽到有新消息時就會獲取并解析消息吠裆,根據(jù)消息內(nèi)容判斷是否需要重新調(diào)用 gRPC 接口來獲取密鑰和授權(quán)策略信息。

      iam-authz-server 會將授權(quán)日志上報到 Redis中

    • Redis
      用來緩存密鑰烂完、授權(quán)策略试疙,降低訪問延時;
      用來緩存授權(quán)日志抠蚣,作為運(yùn)營系統(tǒng)的數(shù)據(jù)來源祝旷。

數(shù)據(jù)流
  1. 運(yùn)營平臺

    • iam-pump
      從 Redis 中拉取緩存的授權(quán)日志,分析后存入 Mongo 數(shù)據(jù)庫中柱徙。

    • iam-operating-system
      IAM營運(yùn)系統(tǒng)缓屠,可以用來展示運(yùn)營數(shù)據(jù),或者對IAM系統(tǒng)進(jìn)行運(yùn)營類管理护侮。

    • MongoDB
      存儲授權(quán)日志敌完,供后期運(yùn)營系統(tǒng)展示和分析


      運(yùn)營平臺
  2. 架構(gòu)全貌

    IAM

Referance

騰訊云 > 訪問管理

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市羊初,隨后出現(xiàn)的幾起案子滨溉,更是在濱河造成了極大的恐慌,老刑警劉巖长赞,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晦攒,死亡現(xiàn)場離奇詭異,居然都是意外死亡得哆,警方通過查閱死者的電腦和手機(jī)脯颜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來贩据,“玉大人栋操,你說我怎么就攤上這事”チ粒” “怎么了矾芙?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長近上。 經(jīng)常有香客問我剔宪,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任葱绒,我火速辦了婚禮感帅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘哈街。我一直安慰自己留瞳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布骚秦。 她就那樣靜靜地躺著她倘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪作箍。 梳的紋絲不亂的頭發(fā)上硬梁,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機(jī)與錄音胞得,去河邊找鬼荧止。 笑死,一個胖子當(dāng)著我的面吹牛阶剑,可吹牛的內(nèi)容都是我干的跃巡。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼牧愁,長吁一口氣:“原來是場噩夢啊……” “哼素邪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起猪半,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤兔朦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后磨确,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沽甥,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年乏奥,在試婚紗的時候發(fā)現(xiàn)自己被綠了摆舟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡邓了,死狀恐怖盏檐,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情驶悟,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布材失,位于F島的核電站痕鳍,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜笼呆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一熊响、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧诗赌,春花似錦汗茄、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至叼屠,卻和暖如春瞳腌,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背镜雨。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工嫂侍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人荚坞。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓挑宠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親颓影。 傳聞我的和親對象是個殘疾皇子各淀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容