-
Notifications
You must be signed in to change notification settings - Fork 10
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
async IO support via kqueue and epoll #216
Comments
Probably a related issue that solves this problem for all native gems: #72 |
Thank you, @bradgessler I will look at async-websockets when I close current PR |
Interesting, I completely missed the purpose of that gem from the docs. I'm certain the issue is actually in the |
Hi @bradgessler I adopted an example from async-websockets: Gemfile
binance.rb
placed them in resulting tebako package worked:
|
So there may be an issue with tebako and this gem of course but it does not look easily reproducable |
I pushed that code up to https://github.com/terminalwire/tebako-async so I could run it and link to stuff; however I ran into an issues with the Here's the error: dyld[77545]: Library not loaded: /opt/homebrew/opt/boost/lib/libboost_chrono-mt.dylib
Referenced from: <24FA4B4B-D617-39C9-8AE8-C440CC85DE26> /Users/bradgessler/.tebako/deps/bin/mkdwarfs
Reason: tried: '/opt/homebrew/opt/boost/lib/libboost_chrono-mt.dylib' (no such file), '/System/Volumes/Preboot/Cryptexes/OS/opt/homebrew/opt/boost/lib/libboost_chrono-mt.dylib' (no such file), '/opt/homebrew/opt/boost/lib/libboost_chrono-mt.dylib' (no such file), '/opt/homebrew/Cellar/boost/1.87.0/lib/libboost_chrono-mt.dylib' (no such file), '/System/Volumes/Preboot/Cryptexes/OS/opt/homebrew/Cellar/boost/1.87.0/lib/libboost_chrono-mt.dylib' (no such file), '/opt/homebrew/Cellar/boost/1.87.0/lib/libboost_chrono-mt.dylib' (no such file)
make[3]: *** [CMakeFiles/packaged_filesystem] Abort trap: 6
make[2]: *** [CMakeFiles/packaged_filesystem.dir/all] Error 2
make[1]: *** [CMakeFiles/tebako.dir/rule] Error 2
make: *** [tebako] Error 2 Here's the contents of the terminalwire/tebako-async [main] → ls /opt/homebrew/Cellar/boost/1.87.0/lib
cmake libboost_locale.a libboost_regex.a
libboost_atomic.a libboost_locale.dylib libboost_regex.dylib
libboost_atomic.dylib libboost_log.a libboost_serialization.a
libboost_charconv.a libboost_log.dylib libboost_serialization.dylib
libboost_charconv.dylib libboost_log_setup.a libboost_stacktrace_addr2line.a
libboost_chrono.a libboost_log_setup.dylib libboost_stacktrace_addr2line.dylib
libboost_chrono.dylib libboost_math_c99.a libboost_stacktrace_basic.a
libboost_container.a libboost_math_c99.dylib libboost_stacktrace_basic.dylib
libboost_container.dylib libboost_math_c99f.a libboost_stacktrace_noop.a
libboost_context.a libboost_math_c99f.dylib libboost_stacktrace_noop.dylib
libboost_context.dylib libboost_math_c99l.a libboost_system.a
libboost_contract.a libboost_math_c99l.dylib libboost_system.dylib
libboost_contract.dylib libboost_math_tr1.a libboost_test_exec_monitor.a
libboost_coroutine.a libboost_math_tr1.dylib libboost_thread.a
libboost_coroutine.dylib libboost_math_tr1f.a libboost_thread.dylib
libboost_date_time.a libboost_math_tr1f.dylib libboost_timer.a
libboost_date_time.dylib libboost_math_tr1l.a libboost_timer.dylib
libboost_exception.a libboost_math_tr1l.dylib libboost_type_erasure.a
libboost_fiber.a libboost_nowide.a libboost_type_erasure.dylib
libboost_fiber.dylib libboost_nowide.dylib libboost_unit_test_framework.a
libboost_filesystem.a libboost_prg_exec_monitor.a libboost_unit_test_framework.dylib
libboost_filesystem.dylib libboost_prg_exec_monitor.dylib libboost_url.a
libboost_graph.a libboost_process.a libboost_url.dylib
libboost_graph.dylib libboost_process.dylib libboost_wave.a
libboost_iostreams.a libboost_program_options.a libboost_wave.dylib
libboost_iostreams.dylib libboost_program_options.dylib libboost_wserialization.a
libboost_json.a libboost_random.a libboost_wserialization.dylib
libboost_json.dylib libboost_random.dylib The history of that package on Homebrew shows that it was updated 2 days ago (at the time of this writing): https://github.com/Homebrew/homebrew-core/commits/87ed609740968c1904035263d621c13d1451e1c4/Formula/b/boost.rb Finally, when I try to install an older version I get this message from brew: terminalwire/tebako-async [main] → brew install [email protected]
Error: [email protected] has been disabled because it is a versioned formula! It was disabled on 2024-12-14. |
One question I have that might help me better debug and troubleshoot issues: when an application is running inside of Tebako, is it completely containerized? In other words, does my Ruby code have full access to the outside world? I read the docs for DwarFS, but as far as I could tell that's a binary blob of read-only files that a running program reads. What's unclear to me is what Tebako looks like when it's actually running. The diagram at https://github.com/tamatebako/tebako-runtime is my mental model of what the program looks like at rest, but I'm not sure what it looks like when it's running. I think it looks like this:
I assume this runtime has some sort of boundary between the Ruby code that's running and a view of the outside world. I thought this was true for files when I looked at the PATH patches in Note that I might be applying what I know about Docker too heavily towards Tebako. I know they're very very different, but I don't know to what degree. |
No, the application is not containerized at all. Your Ruby code has full access to the outside world, no boundaries. The application is patched Ruby interpreter. When it starts it mounts user-space device that contains your code and executes your code. Practically it is achieved by implementation of ~10 functions. This implementation is aware of dwarfs filesystem and routes requested either to dwarfs or to the original versions. Have a look at the code snippets, nothing to be really proud of :) Ruby is compiled and linked against these functions |
Yesterday I saw this issue as well and it does not make any sense. boost library on MacOS is |
I'll run press again after you release the gem and see how far I get. |
Thanks @bradgessler , we are definitely missing some explanatory documentation on how Tebako works. As @maxirmx explained, the goal of Tebako is to allow interpreted executables run with an interpreter runtime "just like" if it was available on the system, so there are no boundaries enforced. It is certainly possible to implement a "chroot"-style jail with explicit host mounts (locking the interpreter inside the DwarfFS volume), but so far we haven't had that use case (and whether that use case is something we should invest in is another question). |
The issue with async not reproducable at least not with version 0.12. I guess you hit several days of Homebrew boost instability If you experience this issue again and need resolution pls feel free to reopen this issue. |
Thanks! I'm going to give it a go. The tutorial link you provided wasn't found, but I managed to locate it at https://github.com/tamatebako/tebako-samples/tree/maxirmx-tutorial-1/tutorial/2_packaging_scenarios |
I can confirm that I have async up and running on macOS arm64 👍 Can't wait to try different architectures and operating systems. |
Thank you, @bradgessler |
I'm working with async-websockets to make a connection from a tebako app to a server. When the connection starts, the application halts on https://github.com/socketry/async/blob/367745ddf9494698327971b7f843f01a053a3662/lib/async/scheduler.rb#L386.
I'm pressing the binary with the latest version of ruby via
-R 3.3.6
to make sure it's using the latest Ruby has to offer for Fibers, but it still halts on that LOC.I don't know enough about epoll, kqueue, and compiling native apps to add much beyond that, but I'll keep updating this as I go deeper and find out more.
The text was updated successfully, but these errors were encountered: