--- author: - Florian Klink date: 2024-10-25 title: "Tvix: Status update" theme: solarized revealOptions: transition: 'fade' --- # Tvix: Status update data:image/s3,"s3://crabby-images/c8b85/c8b857d740f76185ceecbbb965750c9d902b69ff" alt="Tvix Logo" 2023-10-25 Florian Klink (flokli) --- ## Whoami - flokli - nixpkgs contributor since 2018, maintaining systemd, nsncd and more - Freelance Nix/DevOps consultant --- ## What is Tvix? --- data:image/s3,"s3://crabby-images/b79bc/b79bcc397538e594099295dbd4acea6766af1b7a" alt="tvix solves this" --- ## What is Tvix? - A Rust re-implementation of the components of the Nix package manager - Uses different underlying approaches while retaining Nix compatibility "on the surface" - modular architecture, allowing to recombine aspects to solve your usecase - No "end-user CLI" for now, focus on getting the foundational architecture right and 100% correctness with Nix --- ## Topics - Component overview - Recent developments - Next steps Note: Component overview, to understand a bit better how it's different / updates since the last talk / outlook on roadmap --- ## Structure - **tvix-castore**, the granular data storage/syncing engine. - **tvix-store**, the "Nix store implementation" on top of tvix-castore - **nix-compat**, a library providing access to data formats, protocols and concepts - **tvix-eval**, a bytecode interpreter evaluator and core Nix *language* concepts and builtins - **tvix-build**, a generic builder interface - **tvix-glue**, combines tvix-eval with tvix-[ca]store and tvix-build Note: one big cargo workspace / go into detail later! / nix-compat: concepts like output path calculation, doesn't depend on tvix crates tvix-eval: language concepts being Scopes, Thunks, Nix values, "core builtins" ---- data:image/s3,"s3://crabby-images/0af8f/0af8f2d35c9fbfa63ca048f79e1c37e1756814f1" alt="tvix-castore" Note: Nix does do content addressing on a store path level, we're on a per-file/chunk in file. That model allows granular syncing and reuse of parts, which will speedup substitution/copying. Because everything is ca, it'll also allow decentralization and local p2p substitution. Think about everyone in the same room serving chunks. verified streaming. ---- data:image/s3,"s3://crabby-images/a64e7/a64e79c5f95ca839a2c01bf21bd1a96ee5968be2" alt="tvix-store" Note: track all metadata about store paths (think about the sqlite db), and link to castore instead of storing NAR. NarCalculation: this computation, is super nice to cache, as this info never needs to expire, and is reconstructable in a pure CA manner. ---- data:image/s3,"s3://crabby-images/fc49c/fc49c63d326b63d62dfb32adb4b88a45177249ee" alt="tvix-store" Note: kept as a somewhat separate library, Tvix "first consumer". But use from your code, it doesn't depend on Tvix bits. Regularly factoring out Nix concepts into this library ---- data:image/s3,"s3://crabby-images/b50ef/b50efa7e0c3e3103326fc802d645b81ef635c8bc" alt="tvix-eval" Note: only includes basic builtins, like string manipulation, math, …. Other crates can bring their own builtins ---- data:image/s3,"s3://crabby-images/48ae2/48ae228aa5611580bdd803f80d91d87168912641" alt="tvix-build" Note: Not aware of Nix, store paths etc. just flexible enough to express everything in there. Use it for your own build system! ---- data:image/s3,"s3://crabby-images/f54da/f54dab930bb3d26163885930cd06d0925fa9b9cc" alt="tvix-glue" Note: connects the evaluator to store and builders ---- data:image/s3,"s3://crabby-images/466f2/466f23d3e0c9e89963bdcfccf7676feca3e54521" alt="nar-bridge" Note: Example on how to use this: Nix HTTP binary cache lens into tvix-[ca]store, allows Nix to download from and push into. It renders NARs on-the-fly --- ## Updates Rough overview. Check blog posts and `git log` for details! ---- ## Updates (#1) - Fixes on error catchability and context behaviour - More compact Nix Value types (memory-wise) - `tvix-cli` REPL global scope manipulation (assign variables and use them in next command) - `firefox.outPath` and `pkgsCross.aarch64-multiplatform.firefox.outPath` correct and added to CI 🎉 Notes: catchability/context to align behaviour with nix / … / assign variables and use them in the next REPL command ---- ## Updates (#2) - OpenTelemetry integration, trace propagation throughout the entire stack - more backends in tvix-[ca]store (`object_store`/`local fs`/`redb`/`bigtable`/…) - nar-bridge RIIR, was deployed as a fetch-through cache for cache.nixos.org at Bornhack - store composition/combinators - wiring up of builds (without reference propagation yet, but reference scanning) Notes: o11y already proven super helpful for debugging where time is spent / first version of composition / builds waiting on reference propagation ---- ## Other Updates - A lot of the tooling for `cache.nixos.org` usage / closure analysis making use of and contributing to `nix-compat` (`@edef`) 🎉 - "Replit using `tvix-[ca]store` and reporting 10x storage reduction" (`@cbrewster`) 🎉 - "Devenv is switching to Tvix" (Talk on Saturday 12:55, `@domenkozar`) 🎉 --- ## Next steps (in no specific order): - Test suite classification system, to decouple test cases from test runner and share with other Nix impls - (Continuous) Docs deployment, website restructuring - Interactions with the evaluator (LSP, DAP) - Persistent deployment of nar-bridge, as fetch-through cache for `cache.nixos.org` - Blob / Chunking protocol improvements (use local chunks where possible, allow readahead) Note: Allows filtering, reusing test cases in Nixcpp and Lix. Mention some behavorial changes found. Mention fetchTree Make it easier for new contributors to get started LSP / Debug adapter protocol / tvix-eval jobs / … / is gonna improve performance for IO into store paths ---- ## Next steps (in no specific order) (cont.): - "Build/Fetch realization goal engine" (tradeoff network bandwidth and CPU time) - More per-store metrics and instance names - More backends (p2p discovery, ipfs, …) Note: needed for builds / to get better insights into cache hit ratios etc. --- ## Contributing - Join the IRC channel (`#tvix-dev` on `hackint`), bridged to Matrix and XMPP - Check our issue tracker (b.tvl.fyi), as well as `tvix/docs/src/TODO.md` (but ask!) - Try to use it and tell us how you broke it! - Sponsoring Note: make sure to ask in the channel to ensure noone is already working on this --- # Thanks to... - all Tvix contributors - Nix community members for their input on the architecture - Sponsors Note: some drive-by, some sticking around longer / NLNET / Clan ---- # Questions?