使用託管識別在 Azure 中實現安全的跨服務通信
託管身分對於 Azure 中的安全跨服務通訊至關重要。它們消除了管理秘密、金鑰或連接字串的需要,從而實現了應用程式元件的無縫整合。在本部落格中,我將示範如何使用託管識別碼將 Azure SQL 資料庫連接到在 Azure 應用程式服務上執行的 Python 後端。
微軟身份驗證庫
要使用 Entra 身分連接到 Azure 服務,您需要 Microsoft 驗證程式庫 (MSAL)。在此範例中,我使用的是 Python 庫,但不用擔心,每種主要程式語言都存在 MSAL。
這是一個連接到 Azure SQL 資料庫的簡單函數:
滿足這些先決條件後,您可以在程式碼中建立資料庫連線並執行查詢,而無需處理機密或連接字串。
示範 Python 後端
為了演示,我創建了一個簡單的 Python Flask API,它會傳回員工數據,例如姓名、職位和薪水。注意如何使用 get_db_connection() 函數開啟資料庫連線並查詢資料。
這種簡單的方法可確保您的後端使用託管身分與資料庫安全地互動。
Dockerfile
如果您要在 Docker 容器中部署應用程序,這裡是用於安裝 SQL Server 的 ODBC 驅動程式的 Dockerfile:
此設定可確保您的容器已準備好安全連線至 Azure SQL。
SQL Server 與資料庫部署
部署 Azure SQL 伺服器時,設定僅 Azure AD 驗證。這是託管身分的要求。以下是部署 SQL 伺服器和資料庫的 Bicep 範本:
此範本確保資料庫已安全配置並可供使用。
授予託管身分資料庫角色
要讓您的應用程式服務能夠在沒有機密的情況下存取資料庫,請將必要的資料庫角色指派給託管識別碼。您無法使用 Bicep 或 Terraform 執行此步驟。建立自訂腳本或透過 Azure 入口網站存取資料庫。
這些角色允許託管身分根據需要執行讀取、寫入和架構更改操作。
GitHub 上的公開模板
有關完整的程式碼,包括 CI/CD 集成,請查看 GitHub 上的公開模板。此儲存庫包含複製本部落格中所述的設定所需的一切。
拉佐克斯
/
帶有 sql 資料庫的快速啟動後端
用於測試新應用程式功能的輕量級後端環境。它包括從託管應用程式到管理資料持久性的所有內容,並整合 CI/CD 以方便測試和迭代。
使用 SQL 資料庫連線快速啟動後端
此用例涉及使用 Azure SQL 資料庫部署 Azure 應用程式服務,以提供用於測試新應用程式功能的輕量級後端環境。它包括從託管應用程式到管理資料持久性的所有內容,並整合 CI/CD 以方便測試和迭代。
目標
- 在 Azure 上部署可擴充且安全的 Web 後端,用於測試新的應用程式功能。
- 使用 Bicep 自動設定基礎架構。
- 整合應用程式的持續部署,以便頻繁測試和輕鬆更新。
組件概述
- Azure 應用程式服務 - 部署簡單的後端 API。
- Azure SQL 資料庫 - 設定 SQL 資料庫以實現持久性。
- Azure 容器註冊表(可選)- 儲存容器映像以進行版本控制(如果您使用的是容器化版本)。
- 持續整合/持續部署 (CI/CD) - 使用 GitHub Actions 自動部署。
使用託管身分可以簡化跨服務通信,並透過消除對機密的需求來增強安全性。強烈建議任何在 Azure 中建立安全且可擴展的應用程式的人使用此方法。
以上是使用託管識別在 Azure 中實現安全的跨服務通信的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。
