Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add MSI Support for Azure plugin. #212

Merged
merged 2 commits into from
Oct 16, 2023

Conversation

yanggangtony
Copy link
Contributor

@yanggangtony yanggangtony commented Oct 11, 2023

We had discuss in velero repo , for add msi support.
vmware-tanzu/velero#6938.

Can azure plugin use this pr to validation the functions.

@anshulahuja98
Please help to test it in azure cluster.

@mykolaichuk
Copy link

Awaiting for MSI support so much. As far as I understood there is no other way to do a backup in AKS cluster with Azure AD authentication with Azure RBAC, right? I followed this steps and oidcIssuerProfile.issuerUrl was null.

@yanggangtony
Copy link
Contributor Author

@mykolaichuk Hi , this pr is just for test validation.

future , will update it and go to the release version of velero , when the upstream merged .

@anshulahuja98
Copy link
Collaborator

Awaiting for MSI support so much. As far as I understood there is no other way to do a backup in AKS cluster with Azure AD authentication with Azure RBAC, right? I followed this steps and oidcIssuerProfile.issuerUrl was null.

Hi @mykolaichuk I'll need to go through workload Identity setup before I comment further on it's setup

This PR Is particularly for using MSI without workload identity. This support was already there in velero / azure plugin since very long but got inadvertently removed due to some recent refactoring.

@anshulahuja98
Copy link
Collaborator

Ref Issue: vmware-tanzu/velero#6931

@yanggangtony
Copy link
Contributor Author

@anshulahuja98
Thanks for confirm .
Rebased the latest upstream velero repo.

@anshulahuja98
Copy link
Collaborator

@yanggangtony pl also rename the PR name to be more relevant to the change.

@anshulahuja98
Copy link
Collaborator

Also @yanggangtony the CI is failing, pl check

@yanggangtony yanggangtony changed the title test velero reference repo for msi support . Add MSI Support for Azure plugin. Oct 16, 2023
@yanggangtony
Copy link
Contributor Author

wait.

@yanggangtony yanggangtony reopened this Oct 16, 2023
@github-actions github-actions bot requested a review from qiuming-best October 16, 2023 07:37
Signed-off-by: yanggang <[email protected]>
@yanggangtony
Copy link
Contributor Author

@anshulahuja98
Bump the go version to 1.21 , how to trigger the ci runs?
Is that just you can?

@anshulahuja98
Copy link
Collaborator

Ran it.

@codecov-commenter
Copy link

Codecov Report

Merging #212 (e4f13bb) into main (800a4dd) will not change coverage.
Report is 3 commits behind head on main.
The diff coverage is n/a.

@@           Coverage Diff           @@
##             main     #212   +/-   ##
=======================================
  Coverage   19.80%   19.80%           
=======================================
  Files           3        3           
  Lines         500      500           
=======================================
  Hits           99       99           
  Misses        398      398           
  Partials        3        3           

@ywk253100 ywk253100 merged commit 6e71a56 into vmware-tanzu:main Oct 16, 2023
2 checks passed
@yanggangtony yanggangtony deleted the add-support-msi branch October 16, 2023 14:36
@mykolaichuk
Copy link

Hi @anshulahuja98

You've mentioned that MSI support was in place previously. Is it there now? Is there a usage documentation for this?

Thanks in advance!

@anshulahuja98
Copy link
Collaborator

anshulahuja98 commented Nov 1, 2023

@mykolaichuk
The support is there now in the repo.

For end users to consume MSI - I would recommend using Workload Identity.

There is no public docs for using MSI without workload identity in AKS. I can point you further but would still recommend using WorkloadIdentity.

@mykolaichuk
Copy link

Could you be so kind as to give me snippets or a short guide for MSI without workload identity, please?

I have two AAD enabled clusters in different subscriptions and struggle with workload identity setup.

@anshulahuja98
Copy link
Collaborator

Sure
So firstly in your credentials file only specify these 3 values

AZURE_CLIENT_ID=
AZURE_TENANT_ID=
AZURE_CLOUD_NAME=

you'll notice as compared to ServicePrincipal, we don't need the SECRET field here.

The Client_ID field here will be the client id of the User MSI

Create a user msi and mount it on the nodepools of the AKS cluster. From the portal you can navigate to the NodePool > Identity -> User Assigned -> Then add the MSI here.

I don't know a programmatic way to mount it automatically on all nodepools of cluster, you can search for those.

But at a highlevel you atleast need that identity mounted on the nodepool where the velero pod will run.

You can try the above steps out and let me know if you face issues.

@anshulahuja98
Copy link
Collaborator

Basically by virtue of being mounted on the nodepool, the IMDS endpoint of the VM will return the auth for the MSI client ID.

@mykolaichuk
Copy link

@anshulahuja98 thank you so much! It worked! I had some issues with a storage account, but I was able to deal with it on my own!

@anshulahuja98
Copy link
Collaborator

Glad I could help you out :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants