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

Error while trying to install it with armhf arch #113

Open
marianopeck opened this issue Mar 5, 2019 · 50 comments
Open

Error while trying to install it with armhf arch #113

marianopeck opened this issue Mar 5, 2019 · 50 comments

Comments

@marianopeck
Copy link

marianopeck commented Mar 5, 2019

Hi,

I am installing the latest version on a Raspberry Pi 3B+ this way:

# Install Dependencies
RUN apk --no-cache add ca-certificates wget \
	&& wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-2.29-r0.apk \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-bin-2.29-r0.apk \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-i18n-2.29-r0.apk \
	&& apk add glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk glibc-2.29-r0.apk

and I am getting this error:

fetch http://dl-cdn.alpinelinux.org/alpine/v3.9/main/armhf/APKINDEX.tar.gz
fetch http://dl-cdn.alpinelinux.org/alpine/v3.9/community/armhf/APKINDEX.tar.gz
(1/3) Installing glibc (2.29-r0)
(2/3) Installing glibc-bin (2.29-r0)
(3/3) Installing glibc-i18n (2.29-r0)
Executing glibc-bin-2.29-r0.trigger
/usr/glibc-compat/sbin/ldconfig: line 1: syntax error: unexpected "("
ERROR: glibc-bin-2.29-r0.trigger: script exited with error 2
OK: 63 MiB in 61 packages
Removing intermediate container 5d82962062fa
 ---> 524153539aee
Step 6/12 : RUN /usr/glibc-compat/bin/localedef -i en_US -f UTF-8 en_US.UTF-8
 ---> Running in 6640abb3a3db
/usr/glibc-compat/bin/localedef: line 1: syntax error: unexpected ")"
The command '/bin/sh -c /usr/glibc-compat/bin/localedef -i en_US -f UTF-8 en_US.UTF-8' returned a non-zero code: 2

Any idea of what might be wrong? Maybe this is the same case as issue #54 or #81

Thanks

@marianopeck marianopeck mentioned this issue Mar 6, 2019
@marianopeck
Copy link
Author

Looks like there is no pre-compiled binary files for ARM...which is strange considering this is for Alpine...Anyway, I will stick with Debian Slim for the moment. Thanks anyway.

@gorquan
Copy link

gorquan commented Jul 11, 2019

Now I am using the docker on the Raspberry Pi to compile glibc's aarch64 binary package. Later in the day I will try to build an alpine apk package using this binary package.

@marianopeck
Copy link
Author

and armhf? :)

@gorquan
Copy link

gorquan commented Jul 13, 2019

Yes, I will spend some time building glibc for arm64 and armhf

@marianopeck
Copy link
Author

Thanks! That would be awesome. If/whenever you reach to something testeable, share with me the instructions and I can give it a try.

@SaturnusDJ
Copy link

SaturnusDJ commented Jul 24, 2019

Same problem and error here. Using a Dockerfile that detects the architecture (uname -m) and downloads a closed source glibc application, and the glibc from this repo. Works on x86_64, not on armv7l.

@gorquan
Any progress?

@sgerrand
Thanks for this repo, at least x86_64 works, which was a hell until I found this. Any suggestions for arm?

@marianopeck
Copy link
Author

Hi @SaturnusDJ
Honestly, I was quite disappointed. I remember that I eventually found a link from someone that compiled this project for ARM. And I give it a try on Alpine with Docker. It did install correctly but the resulting Docker image size of Alpine + glibc was about the SAME size of an Debian Slime docker image. So...in my case, it was not worth. I was looking for Alpine for having a smaller image but ended up with the same. And not, I cannot update my code to use musl...its a huge effort and risky and we have already found differences in their behaviors..

@SaturnusDJ
Copy link

@marianopeck
Really this project and then the same size as Debian Slim? I think it was just emulation then. Possibly the same as I have seen a few weeks ago: someone using qemu to run glibc applications on Alpine.

@marianopeck
Copy link
Author

Hi @SaturnusDJ
I hope you are right as I really wanted to have it working. I still have the example around in case someone could come with pre-build packages...

@SaturnusDJ
Copy link

@marianopeck
My Docker image that runs a closed source glibc application is 13,5 MB excluding that application and including libstdc++ (0,5-1MB), glibc and glibc-bin and excluding libc-utils, musl-utils and scanelf which were removed upon finalizing the Docker image, because not needed for that application. And it is working on x86_64. So if there would be an ARM version of this glibc, well...game on.

@marianopeck
Copy link
Author

Wow, that would be lovely :) I will re-open the case just to see if we can gain more interest.

@marianopeck marianopeck reopened this Jul 24, 2019
@SaturnusDJ
Copy link

Yes, I don't know what @sgerrand did, but it sure was something good. I am going to have a look at https://github.com/sgerrand/docker-glibc-builder. Maybe building that on ARM results in a glibc for ARM.

@marianopeck
Copy link
Author

If that's the case, I can try to help. I do have ARM and ARM64 devices and Docker already installed on them.. Let me know.

@SaturnusDJ
Copy link

I am trying on ARMv7l (RPi 3B+)

~# docker run --rm --env STDOUT=1 sgerrand/glibc-builder 2.29 /usr/glibc-compat > glibc-bin.tar.gz
Unable to find image 'sgerrand/glibc-builder:latest' locally
latest: Pulling from sgerrand/glibc-builder
6cf436f81810: Pulling fs layer
987088a85b96: Pulling fs layer
b4624b3efe06: Pulling fs layer
d42beb8ded59: Pulling fs layer
29d4e839ed6d: Pulling fs layer
2ccda1bca1a3: Pulling fs layer
028a7df9c282: Pulling fs layer
29d4e839ed6d: Waiting
2ccda1bca1a3: Waiting
028a7df9c282: Waiting
d42beb8ded59: Waiting
b4624b3efe06: Verifying Checksum
987088a85b96: Verifying Checksum
987088a85b96: Download complete
d42beb8ded59: Verifying Checksum
d42beb8ded59: Download complete
2ccda1bca1a3: Verifying Checksum
2ccda1bca1a3: Download complete
028a7df9c282: Verifying Checksum
028a7df9c282: Download complete
6cf436f81810: Verifying Checksum
6cf436f81810: Download complete
6cf436f81810: Pull complete
987088a85b96: Pull complete
b4624b3efe06: Pull complete
d42beb8ded59: Pull complete
29d4e839ed6d: Verifying Checksum
29d4e839ed6d: Download complete
29d4e839ed6d: Pull complete
2ccda1bca1a3: Pull complete
028a7df9c282: Pull complete
Digest: sha256:36cb24e76f751eafa4b40c39331964dff8ff91331ee7db2bbb02f1da7d6964a3
Status: Downloaded newer image for sgerrand/glibc-builder:latest
standard_init_linux.go:190: exec user process caused "exec format error"

@marianopeck
Copy link
Author

Not that I can't help much but I have also a ARMv7l (RPi 3B+) for building/testing as well as other SD with Ubuntu 18.04 compiled for aarch64 that also runs on the same Rpi 3B+ So I have both flavors.

@SaturnusDJ
Copy link

SaturnusDJ commented Jul 24, 2019

I ran it on x86_64 and that results in a 50MB glibc-bin.tar.gz. Cloned the repo on the RPi 3B+, it's running now but the outcome will either be the same (50MB) or it will fail or it will produce a faulty result.

I don't know how @sgerrand managed to generate such small results as on the https://github.com/sgerrand/alpine-pkg-glibc/releases page. Maybe he is selectively packing the resulting files instead of packing all of them.

@SaturnusDJ
Copy link

SaturnusDJ commented Jul 24, 2019

@marianopeck
The good news is...my guess above was at least kind of right. I am down to ~11MB for the glibc ARM package now by removing files that are also not in the glibc-bin.apk from the release page, and the closed source application is running on ARM. This is without the files that are in glibc.apk from the release page. My build result is version 2.28, you can change to 2.29 in the Dockerfile maybe. I did not try yet.
The kind of bad news is that execl (whatever that may be) is missing, also when using the full ~50MB result execl is still missing. This gave an error with the application I am using but it seemed to be working nonetheless. As I only tested one application, much more might be missing or broken. I am not knowledgeable with this kind of stuff.

Anyways...if you dare to try:

git clone https://github.com/sgerrand/docker-glibc-builder.git
docker build --rm -t glibc-builder:1 docker-glibc-builder/ --no-cache
docker run -d --name="glibc-builder_1" glibc-builder:1

Or leave out the -d to get the output in the current command line. The text output will be a lot and it will take at least half an hour. After that the container shuts down. I was unable to extract the tar from the container so I looked for it on the host filesystem.

find / -iname "*glibc*"

Then likely you will find a glibc-bin-2.28.tar.gz somewhere.

Inside it is usr/glibc-compat/
I deleted everything except the bin and sbin directories. When mimicking glibc.apk, more files will have to stay.

@marianopeck
Copy link
Author

Hi @SaturnusDJ
Great, I just fired it up. Will let you know. In the meanwhile, let me ask: once you got the necessary shared libs in usr/glibc-compat/ in your HOST how did you pass it back to the Dockerfile to be run on the Pi? I will need to test that my application. In other words, in the Dockerfile of my app, when I was previously doing:

# Install Dependencies
RUN apk --no-cache add ca-certificates wget \
	&& wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-2.29-r0.apk \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-bin-2.29-r0.apk \
	&& wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-i18n-2.29-r0.apk \
	&& apk add glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk glibc-2.29-r0.apk

I guess you replaced that by mounting from your host (Pi too)? Could you share that?
Finally, you also said:

excluding libc-utils, musl-utils and scanelf which were removed upon finalizing the Docker image

Could you share that as well? I would like to do the same thing.

Thanks!

@marianopeck
Copy link
Author

BTW, the last statement did nothing :(

	pi@marianopi3:~/Instantiations/glibc $ docker run -d --name="glibc-builder_1" glibc-builder:1
	8cfc08630d9955421c6a1e7b265bacca320b6203611c1faa19c17ad683127f64
            pi@marianopi3:~/Instantiations/glibc $

@SaturnusDJ
Copy link

Oh yes I forgot to describe the final step. Just make a volume to share the files with a container. Then copy the generated files into the container root. Thus, move the prepared usr/glibc-compat/ that is on a volume into /.

It's pretty general. You could share the end result .tar.gz, extract it, remove all but bin and sbin and the copy it to /. But when all in error free it would make sense to generate a single .tar.gz that is fully prepared and only needs to be extracted onto /. But first let get it error free.

Why did it not work for you?
Did the git clone work?
Did the build work? (Takes about a minute or 2 to build.)
Are you trying on ARMv7l?

Or maybe it did work, after the last command you should have a container running, it will be generating the file and could take an hour. Try without -d to see what is going on. But now first check if it is running with docker ps.

@marianopeck
Copy link
Author

marianopeck commented Jul 24, 2019

Hi @SaturnusDJ
Grrr crap. Yeah, I am trying on ARMv7l Raspbian Stretch on a Rpi3B+. The docker build does work, but the run fails:

pi@marianopi3:~/Instantiations/glibc $ docker run  glibc-builder:1

gzip: stdin: unexpected end of file
tar: Child returned status 1
tar: Error is not recoverable: exiting now
pi@marianopi3:~/Instantiations/glibc $

Weird...

@marianopeck
Copy link
Author

I did a docker system prune, run the build again and I still have the same issue...I cannot even run interactive with the image:

pi@marianopi3:~/Instantiations/glibc $ docker run -it glibc-builder:1

gzip: stdin: unexpected end of file
tar: Child returned status 1
tar: Error is not recoverable: exiting now
pi@marianopi3:~/Instantiations/glibc $

But the build finishes correct...so I don't know.

@SaturnusDJ
Copy link

That's weird. No hidden errors in the build log or git log? I saw errors here but not severe ones for me.
My host OS is DietPi.

@marianopeck
Copy link
Author

OK, I think the problem is on my end. If I got to my browser and paste "https://ftpmirror.gnu.org/libc/glibc-2.28.tar.gz" it redirects me to "https://espejito.fder.edu.uy/gnu/libc/glibc-2.28.tar.gz" which throws me a nice:

Access forbidden!
You don't have permission to access the requested object. It is either read-protected or not readable by the server.

If you think this is a server error, please contact the webmaster.

Error 403
espejito.fder.edu.uy
Apache

Yeah...I am in Argentina, next to Uruguay. I will change the URL to see if I can use it with another mirror...

@marianopeck
Copy link
Author

OK...working now... I changed the url to "https://ftp.gnu.org/gnu/glibc/glibc-$version.tar.gz" and now it's compiling :)

@SaturnusDJ
Copy link

Good find. 👍

Tomorrow I will have a closer look at https://github.com/sgerrand/docker-glibc-builder/. For example https://github.com/sgerrand/docker-glibc-builder/blob/master/builder where it says --enable-multi-arch. Maybe leaving that out speeds up the process and results in smaller end result. No clue yet.

@marianopeck
Copy link
Author

Yes. I will also check once it finishes compiling what is the result and how to use it from my app... I guess I will need to export LD_LIBRARY_PATH to the mounted volume...but I cannot do more until this thing finishes compiling. BTW... this is NOTHING. Last week I compiled TensorFlow on the Pi3B+. How long? 13 hours. Seriously. hahahah

@SaturnusDJ
Copy link

For what is export LD_LIBRARY_PATH?

@SaturnusDJ
Copy link

Btw my container ends with

test ! -x /glibc-build/elf/ldconfig || LC_ALL=C \
  /glibc-build/elf/ldconfig  \
                        /usr/glibc-compat/lib /usr/glibc-compat/lib
/glibc-build/elf/ldconfig: Warning: ignoring configuration file that cannot be opened: /usr/glibc-compat/etc/ld.so.conf: No such file or directory
make[1]: Leaving directory '/glibc-2.29'

So we might have to fix that.

@SaturnusDJ
Copy link

@marianopeck
Copy link
Author

I also see that warning.
BTW, this worked to copy the zip from the container to the host:
docker cp glibc-builder_1:/glibc-bin-2.28.tar.gz ./

@marianopeck
Copy link
Author

Hmm it just finished.. but it's still huge... See pic. I do need /lib for example. That's already 85MB. This more or less shows my conclusion... Alpine + glibc is almost same size as debian slim...right ?

@SaturnusDJ
Copy link

In my case I only needed bin and sbin to run my application. Total = 11MB. Try if that works for you too.
So extract glibc-bin-2.28.tar.gz. Delete everything except the first bin and sbin. Then copy the remaining tree to your container root.

AMD 64 Alpine + glibc = ~15MB.
ARM...we have to fix it, and then I am sure we reach that low number also without problems.

I cannot yet think of a way to apply the fix at sgerrand/docker-glibc-builder#9. We have to intercept somewhere then. sgerrand/docker-glibc-builder#20 could help us too.

@SaturnusDJ
Copy link

Sorry I read wrong. You need lib. Maybe look if there is something big that can be removed without consequences. Compare to the releases in this repo what has not been put in them. Then mimic that.

@marianopeck
Copy link
Author

Hi @SaturnusDJ
The releases in the repo are as big as my compiling results. .tar.gz is 50MB and uncompressed the whole thing is around 157MB...

@marianopeck
Copy link
Author

marianopeck commented Jul 25, 2019

BTW, the one I said I tried long ago and that worked out of the box was this from @yangxuan8282. The sizes are better but it's a very old glibc version and I cannot find documentation on how he does it.
For more info see this link.
I also remember testing this one which is newer. You can try with something like this:

RUN apk --no-cache add ca-certificates wget \
	&& wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub \
	&& wget https://github.com/yangxuan8282/alpine-pkg-glibc/releases/download/2.27-r0/glibc-2.27-r0.apk \
	&& wget https://github.com/yangxuan8282/alpine-pkg-glibc/releases/download/2.27-r0/glibc-bin-2.27-r0.apk \
	&& wget https://github.com/yangxuan8282/alpine-pkg-glibc/releases/download/2.27-r0/glibc-i18n-2.27-r0.apk \
	&& apk add glibc-bin-2.29-r0.apk glibc-i18n-2.29-r0.apk glibc-2.29-r0.apk

@gorquan
Copy link

gorquan commented Jul 25, 2019

Oh, I am very sorry. I have put the project on hold for a while because I am looking for a job.I have already created a docker that can compile glibc. It works on the arm64 platform and is compiled on my Raspberry Pi 3B. At the same time, I also tried to package the apk of glibc, but there was an error during the packaging process.So I dare not release it. I think you can try my docker, maybe I can help you.
docker-glibc-builder

@marianopeck
Copy link
Author

Hi @gorquan
Good luck with your job hunting!
I was able to get the .tar.gz out of the compilation but I don't know the instructions on how to generate the apk out from them. Do you know?

@gorquan
Copy link

gorquan commented Jul 25, 2019

Please wait.I uploaded my apk packaging container to github, you can try it.

@gorquan
Copy link

gorquan commented Jul 25, 2019

Hi@marianopeck
This is my packaging environment container, you can try it.If you have any questions, please submit an issue.Rpi-alpine-glibc-package

@SaturnusDJ
Copy link

@marianopeck
Ah you are using glibc-dev?
Then it may be true that you will never reach small size with this method. But you can still try to delete things, it is quite likely your application does not require everything from the lib folder. A bit controversial of course, but no other choice at this moment.

The error just before the container finishes, can indeed be fixed at suggested in the topic.
Connect to the running container and execute:

mkdir -p /usr/glibc-compat/etc
touch /usr/glibc-compat/etc/ld.so.conf
echo '/usr/local/lib' >> /usr/glibc-compat/etc/ld.so.conf
echo '/opt/lib' >> /usr/glibc-compat/etc/ld.so.conf

My execl problem is not fixed by this.

@SaturnusDJ
Copy link

...I just tested my application with user config in a 'real' environment and actually, while the logs are okish, the output is not. Simply said: it is not working, even with the full compiled 40MB .tar.gz.
So, for me it also ends here. I have no idea how to get it working on ARM.

@marianopeck
Copy link
Author

Hi @SaturnusDJ @gorquan
Sorry, but for my it also ends up here. I have already spent quite some time on it. I was able to build a docker image with Alpine + glibc. However, my application (VA Smalltalk VM) would not link to glibc but to musl, no matter what I did and so my app would crash. In addition, the docker image of Alpine+glibc+myapp was 60.5MB while debian buster slim + myapp was 87.7MB. That is 27MB of different. But it's worth every byte if I can get debian + glibc.. So, no worth to me continue trying with Alpine.
Here it is my last dockerfile attempt..
Thank you all of you anyway.

@SaturnusDJ
Copy link

In my case I found that a newer version of the application I am trying to run, even runs without glibc. Maybe only libc6 and libstdc++6 are required, and....bash! Installing bash fixed an error for me. This is on ARM. Tested it successfully.

x86_64 likely will continue to have errors etc.

@SaturnusDJ
Copy link

SaturnusDJ commented Sep 11, 2019

@marianopeck
This issue became such a giant mess that I am not sure anymore what we tried and how everything works. As said above, I also did not need it anymore because all of a sudden the application started working with bash installed. But a few days ago I again needed glibc stuff to work in Docker on ARM......

I gave it another try and found: https://github.com/armhf-docker-library/alpine-pkg-glibc/releases
It did what nothing else did before. Two applications that did not want to run at all....are running now. No idea yet about the performance, limitations, etc., but give them a try if you have not yet.

FROM alpine:3.10
RUN wget https://github.com/armhf-docker-library/alpine-pkg-glibc/releases/download/2.22/glibc-2.22-r8.apk https://github.com/armhf-docker-library/alpine-pkg-glibc/releases/download/2.22/glibc-bin-2.22-r8.apk https://github.com/armhf-docker-library/alpine-pkg-glibc/releases/download/2.22/glibc-i18n-2.22-r8.apk && \
apk add --no-cache --allow-untrusted glibc-2.22-r8.apk glibc-bin-2.22-r8.apk glibc-i18n-2.22-r8.apk && \
rm -rf glibc*
ENTRYPOINT ["tail", "-f", "/dev/null"]

Test image: 16,4MB here.

The version, 2.22, is outdated though. I really cannot understand why there is no active development in this. Not sure how that Drone stuff works in the repo linked. Hope to check it out later and hopefully dev into a more recent version of glibc.

@marianopeck
Copy link
Author

marianopeck commented Sep 11, 2019 via email

@SaturnusDJ
Copy link

SaturnusDJ commented Sep 11, 2019

Hmm not sure. How to find out?
When installing the first five of https://pkgs.alpinelinux.org/packages?name=*musl*&branch=edge&arch=armhf, the application is not working.

"pkgdesc = GNU C Library compatibility layer"

@SaturnusDJ
Copy link

@marianopeck
Have you tried it?

@Rjerk
Copy link

Rjerk commented Jan 10, 2020

I build for arm64 version for my own usage:

https://github.com/Rjerk/alpine-pkg-glibc/releases/tag/2.30-r0-arm64

@jvasileff
Copy link

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

No branches or pull requests

5 participants