-
Notifications
You must be signed in to change notification settings - Fork 390
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
Consider updating all current container images #186
Comments
Actually, we may not want to do this, because of #85 |
@jamesmunns this is clearly a problem. rust-lang/rust is using ubuntu 16.04 but compiles toolchains from scratch that target glibc 2.14. If we move our images to 16.04 and use the packaged (cross) toolchain then our glibc will be 2.23 and all the binaries produced with cross will have that glibc requirement (2.23) instead of being compatible with 2.14+. We should do what rust-lang/rust is doing but that will pretty much make all CI build time out because crosstool-ng takes like 30+ mins to run on a fast machine. It will take way longer on Travis machines. An option here may be to produce binaries for the toolchain locally (e.g. on my laptop), push the binaries somewhere and have our images simply pull that. That should save us the toolchain build time. I expect that toolchain versions will change rarely so this semi-automatic process of producing binaries shouldn't be too onerous. We will need to rebuild the toolchains everytime we bump the ubuntu version of the images though. |
but still within a docker container whose version matches the one we are using in our images |
@japaric I can also add a If you can set up the |
Also, doing what rust-lang/rust does pretty much kills the chance of ever having #149 working, I think. The reason is that anything provided by the distribution has been compiled with the newer toolchain and linking that into the binary could potentially introduce newer GLIBC symbols and kill the portability gained by compiling our own toolchain. |
@japaric is there any way to make this "opt-in"? e.g. provide max compat by default, but have an escape hatch for users who don't care about it, and just want their stuff to work for their specific use case? |
It will be pretty much the same as the what rust-lang/rust does. Relevant scripts are: |
No idea. Mixing stuff compiled using different toolchains sounds like a recipe for disaster. I'd rather not recommend doing that in any official manner. Let people try it if they want but they'll have to deal with the problems they encounter themselves. |
could a toolchain from https://toolchains.free-electrons.com be used? |
@gnzlbg AFAICT, the glibc shipped with those toolchain is even newer (glibc 2.24) than ubuntu 16.04's (2.23). rust-lang/rust is using 2.14. (these versions are for ARMv7). |
Just a note on the *-pc-windows-gnu images: They should be updated independently from the Linux targeting images to 18.04 LTS when it is available, because of the wine version. The 17.04 version is not available on the ubuntu download archives anymore. Maybe the other non-Linux targeting images should use the newest LTS as well as the glibc version does not matter for them. Edit: Available as #199 |
I would suggest using Debian Jessie (glibc 2.19) for the -linux-gnu targets. The only popular, supported distribution with 2.14 <= glibc < 2.19 is RedHat/CentOS 7. As Debian also uses apt/dpkg, chances are that there are only a few package names to change in the build system. |
We may need to revisit this, I am not sure all of the existing images based on old ubuntu distros still build at the moment, so the cached docker images will still work, but someone trying to modify the existing images will get an unexpected build failure. |
I think the considerations vary per architecture. In the case of ARM architectures, glibc 2.15 vs glibc 2.16 is significant because glibc 2.16 introduced |
Having said this, rust-lang/libc has shifted its libc support policy from "the oldest libc possible" to "only supporting the newest libc". This is because some/most libc/system library implementations constantly break ABI compatibility with older versions, most users are using the latest version, and we currently don't have any way to support multiple incompatible versions (e.g. the platform version is not part of the target triple). |
FWIW, my project avoids using
Thanks. Do you have a link to some documentation or discussion about that change, so I can learn more about it? |
Please open an issue. We have refactored the run-time feature detection support of
rust-lang/libc#1142 but basically the policy shift has been happening in PRs since currently there isn't an alternative. If most users use a newer system library version with a backwards incompatible change, we can currently either fix libc by doing a breaking change or leave it as is. We typically roll these breaking changes very slowly, particularly on weird platforms without much testing. But libc doesn't currently have a way to distinguish two OS versions, so it has to pick one, which often means things are broken in the other. |
What is the current status of a container update? |
@rust-embedded/tools As per discussion on the 21/03 meeting we need to make a decision how we would like to continue with cross. The current state is very much broken while at the same time a lot of crates (for embedded most prominently svd2rust) depend on cross for CI. Any opinions? |
Maybe we could maintain two sets of images, one using the most recent versions of everything, and one using the oldest version of everything that "works". If the images stop working (e.g. Ubuntu goes EOL or similar) and fixing them requires bumping them, then we do so. That would essentially duplicate the number of build jobs / time per build job on cross' CI, and would significantly increase the maintainer burden, but I don't think there is a way to make cross usable for both types of users: those who want to use newer glibc / kernel features, and those who want super-backward-compatible binaries. |
i’ve been thinking for a while it’d be good to refactor the images so we have a common base image with all the standard utilities and the platform specific images all extend this (which i think will help build times). docker supports piping in configuration files, so one way would be to create a build matrix and programmatically generate i’d also propose that we run image building (and maybe even CI) for cross outside of travis-ci because it’s so demanding compared to almost everything else. |
I'm also working on an experimental alternative to Cross called Naught. The idea would be to split the maintenance of the tool from the images, largely leaving the images to community maintenance status, and no longer publishing pre-built versions of the containers. I have some of my design goals up here, I'm planning on working on this over the next week or so. |
@jamesmunns maybe a discussion issue over there would be good, but, why not skip the repo listing and just take arbitrary image names (which presumably you could drop into |
Considering that dependencies such P.s. For these who will find need I published fresh build for armv7-unknown-linux-musleabihf but without OpenSSL |
@jamesmunns Could you maybe share your thoughts on whether we can expect some decision or should we start making own images/options instead of relying on cross? |
FWIW most rust-lang/ crates like libc, stdarch, etc. use Ubuntu 19.04 to be able to test newer APIs. |
Azure Pipelines provides 10 concurrent jobs and up to 6 hour jobs I think. |
I'm also facing issue with images being too old (need newer version C libraries) making |
So ideally we should provide images based on:
Does that make sense? Would you consider expanding the set of provided images to include those? |
All images have been updated to 16.04, and the update to 20.04 is tracked in #517. |
For consistency, we should update all of the currently existing container images to the current LTS environment when possible (I believe that is ubuntu 16 04), and try to update any other component as well, such as openssl.
The text was updated successfully, but these errors were encountered: