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

Adding multipath-tools extension #505

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

aaroncirillo-cision
Copy link

This PR adds a new extension for multipath-tools. This is needed in the environment I work in, and probably others as well.

I intend for this PR to be an open conversation about this feature. I tried to implement this in a way that aligns with Talos goals and philosophy, but if there is any feedback on this please let me know.

@aaroncirillo-cision
Copy link
Author

Where can I find the requirements for properly formatting my commit messages?

func main() {
fmt.Println("Starting multipath daemon...")

//setup a chroot environment for the extension
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i don't think we need this, with mountPropogation shared should work as a normal extension service

@@ -0,0 +1,1132 @@
defaults {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should be provided as an ExtensionServiceConfig

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should just compile using base and put all libs under /rootfs/usr/local/lib/containers/multipath-tools/

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ok, sounds good, thanks

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@aaroncirillo-cision Any updates on this PR? I am looking to install multipath-tools as well and this would be very useful.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@lusrmgr
Not quite yet. I am running this extension internally right now and it is working for us. The extension I built was based on me grabbing binaries from Alpine and sticking them into an extension image. The Talos project can't accept that. They need a build from source integrated into their build system. So I do want to go back and clean up what I have and get a build running in their build system.

I've seen a few github threads on this topic actually. It looks like many of the CSI drivers for fiber channel arrays will have this same requirement. So getting this done would benefit everyone.

You may or may not have interest in the thread here as well discussing the same topic: hpe-storage/csi-driver#379

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

there's also work to actually have /etc/iscsi/initiatorname.iscsi here: siderolabs/talos#10162 and some rework of iscsi-tools here: #577

Copy link

@bzub bzub Jan 19, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FWIW I've started working on this too. So far I've got multipath-tools compiling. The work in this PR is a huge help. I can submit a PR soon as well.

https://github.com/bzub/extensions/tree/multipath-tools

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Your branch looks great, much better than what I did. I'm glad someone who had a better understanding of the build system took a look here. This was really my first encounter with Talos extensions and I was missing a lot of detail about how the bldr tool worked and how you could pull in dependencies from the core packages.

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.

4 participants