-
Notifications
You must be signed in to change notification settings - Fork 769
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
Provide prebuilt binaries for ARM in GitHub Releases #1159
Comments
This is a very reasonable ask... We'll keep that in mind and see if we can do it soon (but I don't have a M1 chip laptop yet..) :) |
In the meantime, you could just use (You might need to |
In the Makefile you linked there is no |
Yes.. Thanks for catching.. i meant
Sorry for the confusion :) |
any updates on a PR for this fix? |
This is not a code change so no PR is required. Our next step is to find a M1 chip MacBook to build the binary from :) For now, please use the Makefile to build the plugin as mentioned above. Thanks :) |
@sampajano |
Not sure since i don't have configurations (or know they exists 😂) .. Might have to rely on the community to help test it out once we have a ARM binary :) |
@sampajano I have M1 Apple Silicon, I can build for you and sign&release eventually. I git cloned the repository, but looks like I need to load some google protobuf somewhere? Didn't find instructions
|
Thanks a lot for offering to help! 😃 Unfortunately I can't really take and release your binaries (nothing against you personally but just in general).. for obvious reasons... :)
Yes.. Protobuf lib is required to build. I'll probably update our README to add instructions on building the plugin on your own soon.. :) |
Makes sense :) Maybe Github Actions offers a way to build on cloud.
Yes I did that already, looks like still not enough (another Apple Silicon quirck?) |
having the same problem i faced. same trouble is there any way i can compile the binaries? |
Aha yes that's a great idea! We'll definitely explore that since that's a better way to release our binaries anyways!
Hmmm... sorry I have no idea then... When i do I'm no expert on how
Maybe someone more familiar with M1 and/or |
I had the same issue running CPPFLAGS += -I/opt/homebrew/include -pthread
...
LDFLAGS += -L/opt/homebrew/lib -lprotoc -lprotobuf -lpthread -ldl Once I did that, I was able to run file javascript/net/grpc/web/generator/protoc-gen-grpc-web
# Output should have "arm64" at the end (rather than "x86_64" or the like)
sudo cp javascript/net/grpc/web/generator/protoc-gen-grpc-web /usr/local/bin/
sudo chmod +x /usr/local/bin/protoc-gen-grpc-web And FYI, if you don't know where your homebrew bin is, and the type -a protoc
# Outputs the location of the protoc binary |
@jdahlq Thanks so much for sharing your solution!! 😃 And btw i'm migrating to Github Actions to build release binaries, but so far it seems that Apple M1 is not yet supported: Hopefully that issue will get resolved soon.. so we'll have M1 binary in future releases :) |
After some experiments, now I'm able to cross-compile protoc-gen-grpc-web binaries for x86_64-darwin/aarch64-darwin/x86_64-linux/aarch64-linux/x86_64-windows/aarch64-windows, from a x86_64 Linux machine, by using zig's cross-compile capability. This means even GitHub Actions does not support some targets (e.g. aarch64 macOS), we can still support all 6 platforms by just using the Please let me know if the core team will accept a PR. |
It's a completely different method compared to #1214, so unfortunately I don't have too much to say in that PR. My method does not require docker, qemu, bazel, or anything else, the only thing required is the zig compiler. BTW I didn't even notice there are some Dockerfiles. Are they for local testing purposes only? If I'm going to make a PR, do those Dockerfiles need to be changed (to use my method) as well? |
Aha ok! Personally i don't know enough to decide the pros/cons of both approaches. Maybe you could explain how your approaches differs and what's the pros/cons? CC @strophy for discussion too.
They're used for local testing as well as for CI. And yes.. all of them should be updated if we were to make some changes :) |
I used a Docker-oriented approach for ARM64 builds (1) because it is what I am familiar with and (2) because it matched the existing build process. Zig looks cool but I'm not familiar with it, it looks like a compiler wrapper to make cross-compiling easier? The Docker approach to this would be to use more |
@strophy Yes, zig uses clang internally while compiling C/C++ source code, and zig implements its own mach-o linker so it can target macOS when doing cross-compiling. As far as I know, Docker is based on cgroup of the Linux kernel, so it's limited to using Linux as the operating system when using Docker, so it can only produce Linux binaries. I think one of the biggest reasons that people are asking for ARM binaries is the popularity of the M1 chips, so ARM binaries for Linux only don't really solve the problem. As a comparison, zig is a compiler for compiling c/c++/zig source files, and made cross-compiling for c/c++/zig programs as easy as for go programs(with cgo disabled). Not only for Linux/macOS/Windows, if necessary, we can simply add more targets like FreeBSD, by just adding one line of the configuration file. But like @strophy mentioned, using zig may not match the current build process. There are two approaches:
Personally, I would recommend approach 2, the current build process (in
If they are only for local testing or CI, I don't think they need to be updated, since with zig we don't need to use Docker at all. |
Interesting points, I am learning a lot here! It all depends on the target audience of the software I guess. My understanding of GRPC is that it is usually for inter-process communication in datacenters, where there are mainly Linux servers and fewer macOS devices in play. I explicitly need Not to say that building with Zig isn't the optimal solution here, just as long as one of the resulting target platforms is also |
Make sense for grpc, however, this is grpc-web instead of grpc, which is mainly used by front-end developers, and I believe most front-end developers won't use Docker. BTW, I'm the maintainer of the protoc-gen-grpc-web NPM package. Currently, when you try to install this NPM package on an ARM machine (e.g. the M1 MacBooks), it simply throws an error and kills the install process, which is a really bad experience. |
Hi @sampajano, do you have any comments on which approach we should use as I mentioned in #1159 (comment) |
@hronro Thanks for the ping! Honestly i'm not really knowledgeable enough to make a decision right now whether zig should be adopted across the board. I tend to lean towards the option of "Keep the existing build process, we just use zig to build ARM binaries.", and after we've seen what the code looks like for Mac/ARM (or maybe this will replace #1214 entirely for both Mac and Linux), then we can decide whether to adopt it across the board -- especially if it's a easy copy/paste for the rest :) Either way, i'm definitely excited to provide a solution for M1/Mac! So the contribution here would be very much appreciated! thanks again! :) |
Thanks so much to @hronro's contrib, we now have a workflow able to build the ARM binaries for all 3 platforms (Mac/Windows/Linux)! :) I have tested building the ARM binaries workflow and the binaries can be downloaded from the link below (in the Artifacts section). I cannot verify the binaries since i don't have ARM machines. If someone can help verify them on any of the 3 platforms, it would be helpful! I'll make sure to include these binaries in the next release we cut 😃 Thanks again for the great contrib, @hronro! |
Thanks @hronro for providing this effective build solution! @sampajano will the release also include a multi-arch docker image published to docker hub? |
I'm actually not sure how to do multi-arch docker image (i supposed it's unrelated to the zig binaries?).. could look into that potentially if it's helpful to many :) (For now we don't really keep our docker hub images super up to date so i'd recommend just to build locally.. and it shouldn't take very long either.. :)) |
Yeah, it's unrelated to Zig binaries. I have a Dockerfile repo here that builds multi-arch grpc-web images, would you be interested in a PR to merge this Dockerfile and a GitHub Action to build a multiarch Docker image on a |
Thanks for the initiative! I think it'll be helpful to maintain the docker repo automatically on release! Just to confirm, it'll be uploading to our dockerhub here right? I'm not sure how the credentials stuff work but if you have a good solution i'd be happy to see it! :) (Maybe send a simple POC PR first so we can iterate on it rather than you spending too much time on it and we ended up deciding against the general approach :)) Separately, curious why do you rely much on the docker images? AFAIU they're only used for people who want to test out our demo server/clients. And will not be used for any production, right? Also, it doesn't take that long to build locally too? 😃 |
@sampajano Would it be OK to keep this issue open until the next release including the artifacts? The issue is about providing binaries, so I guess it hasn't been resolved yet and could be good to leave the nag. FWIW, I was able to verify the darwin and linux arm binaries work fine. Couldn't verify windows arm because such machines are very rare and not easily provisionable. |
@anuraaga Yes.. Absolutely fair! Thanks for the comment! Will aim to make a new release in the near future! |
Hi! I've cut a new release at https://github.com/grpc/grpc-web/releases/tag/1.4.0 containing the new ARM binaries (after a long while :P)! Please help test them out! 😃 It works for me on my Macbook Air M2 (interesting even the x86 binaries can run there too.. maybe due to Rosetta?) :) I'll mark this closed now. Thanks everyone for patience! And special thanks for your contributions, @strophy and @hronro! 😃 |
Anyone seeing syntax error when downloading the linux ARM binary on a raspberry PI? This is what I'm seeing:
|
@tabletenniser Which Pi are you using? The ARM binaries shipped in GitHub Releases are all 64-bits, so if you are using a 32-bits Pi, you may have to compile it yourself. |
I have a Raspberry Pi 4 running on Is there any plan to add 32-bits ARM binaries in the release in the future? |
@tabletenniser Hi! It's not a priority for us to support 32-bit ARM as i'd imagine that to be a relatively unpopular platform. But if more people think this is necessary i don't mind taking a PR on adding this to our release. Thanks! :) |
thank you so much!!!!!
…________________________________
From: Eryu Xia ***@***.***>
Sent: Monday, June 26, 2023 6:25 PM
To: grpc/grpc-web ***@***.***>
Cc: C3sarRCDOU ***@***.***>; Comment ***@***.***>
Subject: Re: [grpc/grpc-web] Provide prebuilt binaries for ARM in GitHub Releases (Issue #1159)
@tabletenniser<https://github.com/tabletenniser> Hi! It's not a priority for us to support 32-bit ARM as i'd imagine that to be a relatively unpopular platform. But if more people think this is necessary i don't mind taking a PR on adding this to our release. Thanks! :)
—
Reply to this email directly, view it on GitHub<#1159 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AWCOMBET3DFVLYPMSLJ5J6TXNISA3ANCNFSM5HDPABFQ>.
You are receiving this because you commented.Message ID: ***@***.***>
Caution: Please do not click links or open attachments unless you recognize the sender and know the content is safe.
============================================================================================================================ Disclaimer: This message and the information contained herein is proprietary and confidential and subject to the Tech Mahindra policy statement, you may review the policy at http://www.techmahindra.com/Disclaimer.html externally http://tim.techmahindra.com/tim/disclaimer.html internally within TechMahindra. ============================================================================================================================
|
Since M1 chip becomes more and more popular, it would be great if we can download prebuilt binaries for ARM in GitHub Releases.
The text was updated successfully, but these errors were encountered: