【转】Enabling Managed Identity Authentication on Azure Functions in Data Factory
This blog shows you how to enable Managed Identity on an Azure Function call from ADF, this can help secure the Function by adding a second authentication method on top of the API Key. Enabling these options enforces https on all function calls, ADF handles authentication and so no custom headers, tokens or keys are necessary to be exchanged.
The high level process is:
- Configure Microsoft Identity on Azure Function
- Enable Managed Identity on Data Factory
- Configure Linked Service in Data Factory
- Assign Permissions to the Data Factory in Azure Function
Step 1 – Enable Microsoft Identity on Azure Function
On the Azure function, in the authentication tab, click Add identity provider.
data:image/s3,"s3://crabby-images/dc6d4/dc6d460d816afdebcd8125f5814a2a8a695ba4c0" alt=""
Set the identity provider to Microsoft, you can manually create one in Azure Active Directory (App Registrations) but I recommend choosing to create a new app registration, changing its name to FunctionName-auth / -app and giving it the default permissions.
data:image/s3,"s3://crabby-images/e533b/e533bda771e269a6222af711fde850afe0da0704" alt=""
Use the default permission option
data:image/s3,"s3://crabby-images/a0655/a06559852cdc2cd141828dbf2bfc9ead10445a21" alt=""
Copy the generated App (client) id, as this is used in data factory to handle authorization.
data:image/s3,"s3://crabby-images/50985/5098579e33ad6c4b3f6a61f5fd84da2b715c1884" alt=""
Step 2 – Enable Managed Identity on Data Factory
In the Data Factory’s controls, go to Managed Identities, and enable a system assigned Identity.
data:image/s3,"s3://crabby-images/ac0ec/ac0ecf737ded6685f4acb252c83dd1d153a59c3e" alt=""
Step 3- Configure Linked Service in Data Factory
Enter the Data Factory studio, and then Manage, Linked Services and either create a new or update previous function implementation.
data:image/s3,"s3://crabby-images/a55b9/a55b9405eb1cfe6ad188d5fa65ae130d0fec8839" alt=""
Change authentication method to System Assigned Managed Identity, and paste the copied client ID from Step 1 into Resource ID. This step is necessary as authorization does not work without this.
data:image/s3,"s3://crabby-images/ed7da/ed7da254e1967e6123f42e4ca097a54504d9499f" alt=""
Step 4 – Assign Permissions to the Data Factory in Function
On the function app, go to Access control (IAM), and Add a new role assignment
data:image/s3,"s3://crabby-images/96233/96233e3b8df51f1f2b11efc70aba8b70d042cd33" alt=""
Assign reader role.
data:image/s3,"s3://crabby-images/aefb3/aefb34b274ec4f8b549aab4c7b10289e7b7dd98d" alt=""
Assign the Data Factory’s Managed Identity to that role.
data:image/s3,"s3://crabby-images/eb2aa/eb2aa1d6dffbab4401cf5b3e977c91f8a9697151" alt=""
Here is an example function working.
data:image/s3,"s3://crabby-images/bbd68/bbd689e543230acc3f45000f9d08b601910cdb1a" alt=""
The response below indicates that either the app registration was deleted/ created incorrectly, or the role is not assigned in the Data Factory’s IAM.
data:image/s3,"s3://crabby-images/ce658/ce658f3df4267f1413cef3dc4a55d4f0d2f99ce1" alt=""
Differences to Microsoft Articles
The Microsoft Articles that we could find on this matter don’t include all the steps to get it working end to end. In the fast paced world of azure things get out of date fast
https://docs.microsoft.com/en-us/azure/app-service/configure-authentication-provider-aad
This doesn’t provide an example of linking the resource ID and adding permissions for the data factory on the function.
https://docs.microsoft.com/en-us/azure/spring-cloud/tutorial-managed-identities-functions
This article uses old examples of App Registration and Authentication configuration as well as outdated instructions on permission management.
当在复杂的环境中面临问题,格物之道需:浊而静之徐清,安以动之徐生。 云中,恰是如此!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· DeepSeek本地性能调优
· 一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略
2022-03-08 【Azure Redis 缓存】当使用Azure Redis 集群服务时候,发生了Moved的几点分析
2022-03-08 【Azure API 管理】使用APIM进行XML内容读取时遇见的诡异错误 Expression evaluation failed. Object reference not set to an instance of an object.
2021-03-08 【Azure 应用服务】Azure SignalR 是否可以同时支持近十万人在线互动
2021-03-08 【Azure API 管理】从微信小程序访问APIM出现200空响应的问题中发现CORS的属性[terminate-unmatched-request]功能