-
Notifications
You must be signed in to change notification settings - Fork 219
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
[Question] Any plans for musl based distros? #37
Comments
A better place for this discussion would be the distutils-sig mailing list, since that's where any such plan would need to be discussed and approved, and also would reach a much larger audience of people who might be interested in doing the work. I'll answer below in any case, but that's probably the best place for follow-ups, so I'll also close this bug :-). Anyway: there aren't any concrete plans for a My personal guess is that Docker's announcement about changes to their official images won't affect Python much -- the official Python images have always come in both musl and glibc options, so if you want Obviously having some sort of |
@njsmith is it worth reopening this now that there are official alpine python images? |
@abe-winter: I think everything in my previous reply still applies. I think it would be great if someone wants to work in this, but the text above already says what you need to do to move things forward, and it doesn't involve this repository. |
@njsmith fair enough -- thanks |
Hi folks, sorry to "reopen" this issue, but I would like to know how to help on alpine/musl support for wheel. I'm ok trying to help but I don't known where to start. If someone can guide me I'll be happy to help on that. Thanks |
You'd need to write a PEP defining a new wheel "platform tag" for alpine. The main problems are (1) you need to make sure that pip can look at the system it's running on, and a wheel, and determine whether the wheel and the system are compatible, (2) you need some way to figure out which wheels should receive this tag, (3) you need some way to reliably build these wheels. There are some judgement calls to make along the way -- do you want to target all musl systems, or specifically alpine systems, or ...? How do you recognize when you have a wheel for alpine, but it requires a newer version of alpine than pip is running on? This may require working with the alpine or musl developers to figure out what ABI guarantees they actually make, which libraries you can assume are available, etc. PEPs are discussed on the distutils-sig mailing list; you should probably post drafts regularly to get feedback, but expect that you'll have to do the driving to make this happen. PEP 1 and PEP 12 gives details on how you write a PEP. You'll probably want to refer to PEP 491 for details on wheels, and maybe PEP 513 is a useful example to refer to too. |
@njsmith (1) Is there a way of achieving this without writing new PEP? It seems to be an overkill. Would it be possible to extend platform detecting function instead? Because there few As for (2) and (3), that's quite easily to do – Travis CI with alpine build, creating wheels for all popular packages will work in my opinion. I'm gonna start working on this soon. |
@lyssdod Well, we need to figure out what tag is used for alpine wheels, we need to figure out how pip can tell when it's running on alpine, and we need to figure out a way for auditwheel or similar to create these wheels. Then we need to write down what we've figured out, so that there's a reference and everyone's on the same page. That's what a PEP is. We can't just skip writing it down, no. |
@njsmith OK! I will look into examples |
Also see pypa/packaging-problems#69 |
This might be relevant: https://natemcmaster.com/blog/2016/05/19/nuget3-rid-graph/ |
Kind of resurrecting the topic; I've spent some time and made an MVP, but discussion eventually died without replies from the maintainers. Does anybody know where python packaging discussion is happening for real ? Apparently not in the mailing lists |
@lyssdod - sorry - maybe I missed it - did you point to the MVP / discussion here? |
It's mostly moved to discuss.python.org, in the "packaging" category. It's also appreciated if you can send a ping if you're not getting replies – folks are busy and stuff gets missed sometimes. |
@matthew-brett The distutils-sig thread was back in February at https://mail.python.org/archives/list/[email protected]/thread/H3323AXRRLJAYOY2XZKS74IOUQMJUOYD/ That linked to Alex's musl detection PoC at https://gist.github.com/lyssdod/f51579ae8d93c8657a5564aefc2ffbca However, Alex's last set of questions in that thread never actually got an answer :( |
Thanks - then I think Nathaniel's answer above is the right one - and he is one of the people he's encouraging you to ping, to remind us to answer :) |
@ncoghlan @matthew-brett thanks! that's exactly what I was meaning. I will repost it there then |
FYI there's now a |
Looks like support is becoming more commonplace:
Perhaps it may be time to revisit? |
What are the plans if any for musl based distributions? Musl based distributions are popular in container world because they are much lighter. Docker announced that they will be redoing all their official images to be Alpine Linux based. Will there be a separate tag?
The text was updated successfully, but these errors were encountered: