Version Compatibility Matrix
Master Compatibility Table
| Anchor Version | Release Date | Solana CLI | Rust Version | Platform Tools | GLIBC Req | Node.js | Key Notes |
|---|---|---|---|---|---|---|---|
| 1.0.x | — | 3.x | 1.79–1.85+ (stable) | v1.52 | ≥2.39 | ≥17 | TS pkg → @anchor-lang/core; anchor test defaults to surfpool; IDL in Program Metadata; no solana CLI shell-out; all solana-* deps must be ^3; solana-program removed as project dep; solana-signer replaces solana-sdk for signing |
| 0.32.x | Oct 2025 | 2.1.x+ | 1.79–1.85+ (stable) | v1.50+ | ≥2.39 | ≥17 | Replaces solana-program with smaller crates; IDL builds on stable Rust; removes Solang |
| 0.31.1 | Apr 2025 | 2.0.x–2.1.x | 1.79–1.83 | v1.47+ | ≥2.39 ⚠️ | ≥17 | New Docker image solanafoundation/anchor; published under solana-foundation org. Tested: binary requires GLIBC 2.39, not 2.38 |
| 0.31.0 | Mar 2025 | 2.0.x–2.1.x | 1.79–1.83 | v1.47+ | ≥2.39 ⚠️ | ≥17 | Solana v2 upgrade; dynamic discriminators; LazyAccount; declare_program! improvements. Pre-built binary needs GLIBC 2.39 |
| 0.30.1 | Jun 2024 | 1.18.x (rec: 1.18.8+) | 1.75–1.79 | v1.43 | ≥2.31 | ≥16 | declare_program! macro; legacy IDL conversion; RUSTUP_TOOLCHAIN override |
| 0.30.0 | Apr 2024 | 1.18.x (rec: 1.18.8) | 1.75–1.79 | v1.43 | ≥2.31 | ≥16 | New IDL spec; token extensions; cargo build-sbf default; idl-build feature required |
| 0.29.0 | Oct 2023 | 1.16.x–1.17.x | 1.68–1.75 | v1.37–v1.41 | ≥2.28 | ≥16 | Account reference changes; idl build compilation method; .anchorversion file |
Solana CLI Version Mapping
| Solana CLI | Agave Version | Era | solana-program Crate | Platform Tools | Status |
|---|---|---|---|---|---|
| 3.1.x | v3.1.x | Jan 2026 | N/A (validator only) | v1.52 | Edge/Beta |
| 3.0.x | v3.0.x | Late 2025 | N/A (validator only) | v1.52 | Stable (mainnet) |
| 2.1.x | v2.1.x | Mid 2025 | 2.x | v1.47–v1.51 | Stable |
| 2.0.x | v2.0.x | Early 2025 | 2.x | v1.44–v1.47 | Legacy |
| 1.18.x | N/A (pre-Anza) | 2024 | 1.18.x | v1.43 | Legacy |
| 1.17.x | N/A | 2023 | 1.17.x | v1.37–v1.41 | Deprecated |
| 1.16.x | N/A | 2023 | 1.16.x | v1.35–v1.37 | Deprecated |
Important: Solana CLI v3.x
As of Agave v3.0.0, Anza no longer publishes the agave-validator binary. Operators must build from source. The CLI tools (for program development) remain available via agave-install or the install script.
Platform Tools → Rust Toolchain Mapping
| Platform Tools | Bundled Rust | Bundled Cargo | LLVM/Clang | Target Triple | Notes |
|---|---|---|---|---|---|
| v1.52 | ~1.85 (solana fork) | ~1.85 | Clang 20 | sbpf-solana-solana | Latest; used by Solana CLI 3.x |
| v1.51 | ~1.84 (solana fork) | ~1.84 | Clang 19 | sbpf-solana-solana | |
| v1.50 | ~1.83 (solana fork) | ~1.83 | Clang 19 | sbpf-solana-solana | |
| v1.49 | ~1.82 (solana fork) | ~1.82 | Clang 18 | sbpf-solana-solana | |
| v1.48 | rustc 1.84.1-dev | cargo 1.84.0 | Clang 19 | sbpf-solana-solana | Verified. Used by Solana CLI 2.2.16. ⚠️ Cargo does NOT support edition2024 |
| v1.47 | ~1.80 (solana fork) | ~1.80 | Clang 17 | sbpf-solana-solana | Used by Anchor 0.31.x |
| v1.46 | ~1.79 (solana fork) | ~1.79 | Clang 17 | sbf-solana-solana | |
| v1.45 | ~1.79 (solana fork) | ~1.79 | Clang 17 | sbf-solana-solana | |
| v1.44 | ~1.78 (solana fork) | ~1.78 | Clang 16 | sbf-solana-solana | |
| v1.43 | ~1.75 (solana fork) | ~1.75 | Clang 16 | sbf-solana-solana | Used by Anchor 0.30.x/Solana 1.18.x. ❌ Incompatible with CLI 2.2.16 (sbpf-solana-solana target not found) |
Note: Platform Tools ship a forked Rust compiler from anza-xyz/rust. The version numbers approximate the upstream Rust equivalent. The forked compiler includes SBF/SBPF target support.
⚠️ CRITICAL (Jan 2026): Platform-tools v1.48 bundles cargo 1.84.0 which does NOT support edition = "2024". Multiple crates now require it: blake3 ≥1.8.3, constant_time_eq ≥0.4.2, base64ct ≥1.8.3, indexmap ≥2.13.0. Pin to safe versions: blake3=1.8.2, constant_time_eq=0.3.1, base64ct=1.7.3, indexmap=2.11.4. Always commit Cargo.lock files. See common-errors.md for full details and fix scripts.
GLIBC Requirements by OS
| OS / Distro | GLIBC Version | Compatible Anchor |
|---|---|---|
| Ubuntu 24.04 (Noble) | 2.39 | All (0.29–v1+) |
| Ubuntu 22.04 (Jammy) | 2.35 | 0.29–0.30.x only (build 0.31+ from source) |
| Ubuntu 20.04 (Focal) | 2.31 | 0.29–0.30.x only (build 0.31+ from source) |
| Debian 12 (Bookworm) | 2.36 | 0.29–0.30.x only ⚠️ Tested: 0.31.1 and 0.32.1 pre-built binaries fail. Build from source works for Anchor CLI, but litesvm 0.5.0 native binary also needs GLIBC 2.38+ |
| Debian 13 (Trixie) | 2.40 | All |
| Fedora 39+ | ≥2.38 | All |
| Arch Linux (rolling) | Latest | All |
| macOS 14+ (Sonoma) | N/A (no GLIBC) | All |
| macOS 12-13 | N/A | All |
| Windows WSL2 (Ubuntu) | Depends on distro | See Ubuntu version |
Why GLIBC matters
Anchor 0.31+ and 0.32+ binaries are compiled against newer GLIBC. If your system's GLIBC is too old, you'll get:
anchor: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.38' not found
Solutions:
- Upgrade your OS (recommended)
- Build Anchor from source:
cargo install --git https://github.com/solana-foundation/anchor --tag v1.0.0 anchor-cli(replace tag with desired version) - Use Docker (see install-guide.md)
Anchor ↔ Solana Crate Versions
| Anchor | anchor-lang Crate | Project-level solana-* | Notes |
|---|---|---|---|
| 1.0.x | 1.0.x | ^3 (granular crates) | solana-program removed from project deps; use solana-signer instead of solana-sdk for signing; all solana-* must be ^3 |
| 0.32.x | 0.32.x | 2 (still solana-program or granular v2) | anchor-lang internals use granular crates; solana-program still valid in user Cargo.toml |
| 0.31.x | 0.31.x | 2.x | Upgraded to Solana v2 crate ecosystem |
| 0.30.x | 0.30.x | 1.18.x | Last version using Solana v1 crates |
| 0.29.x | 0.29.x | 1.16.x–1.17.x |
Solana Granular Crate Ecosystem (Anchor 0.31+)
Anchor 0.31+ uses the Solana v2+ crate structure. The monolithic solana-program crate is being split into smaller crates:
solana-pubkey/solana-addresssolana-instructionsolana-account-infosolana-msgsolana-invokesolana-entrypointsolana-signer(use instead ofsolana-sdkin v1+)- etc.
Anchor 0.32+ fully replaces solana-program in its own internals. Anchor v1.0+ goes further: user-facing Cargo.toml files must also drop solana-program and bump any remaining solana-* crates to ^3. The anchor build command warns on mismatched versions.
Anchor CLI ↔ anchor-lang Crate Compatibility
The Anchor CLI checks version compatibility with the anchor-lang crate used in your project. Mismatched versions will produce a warning. Always keep these in sync:
# Cargo.toml (Anchor v1)
[dependencies]
anchor-lang = "1.0.0"
# Must match CLI:
# anchor --version → anchor-cli 1.0.0
# Cargo.toml (Anchor 0.32.x)
[dependencies]
anchor-lang = "0.32.1"
# anchor --version → anchor-cli 0.32.1
SPL Token Crate Versions
| Anchor | anchor-spl | spl-token | spl-token-2022 | spl-associated-token-account |
|---|---|---|---|---|
| 1.0.x | 1.0.x | Latest compatible | Latest compatible | Latest compatible |
| 0.32.x | 0.32.x | Latest compatible | Latest compatible | Latest compatible |
| 0.31.x | 0.31.x | 6.x | 5.x | 4.x |
| 0.30.x | 0.30.x | 4.x–6.x | 3.x–4.x | 3.x |
| 0.29.x | 0.29.x | 4.x | 1.x–3.x | 2.x–3.x |
Node.js / TypeScript Requirements
| Anchor | TS Package | Node.js | TypeScript | Notes |
|---|---|---|---|---|
| 1.0.x | @anchor-lang/core ^1.0.0 | ≥17 | 5.x | Renamed from @coral-xyz/anchor. IDL types now at root of @anchor-lang/core (was @coral-xyz/anchor/dist/cjs/idl) |
| 0.32.x | @coral-xyz/anchor ^0.32.x | ≥17 | 5.x | |
| 0.31.x | @coral-xyz/anchor ^0.31.x | ≥17 | 5.x | |
| 0.30.x | @coral-xyz/anchor ^0.30.x | ≥16 | 4.x–5.x | |
| 0.29.x | @coral-xyz/anchor ^0.29.x | ≥16 | 4.x |
Anchor v1 TypeScript Package Rename
The npm package moved from @coral-xyz/anchor to @anchor-lang/core. Update package.json and all imports:
# Find all occurrences to update
grep -r "@coral-xyz" --include="*.ts" --include="*.js" --include="package.json" .
grep -r "dist/cjs/idl" --include="*.ts" --include="*.js" .
// Before (0.32.x)
import * as anchor from "@coral-xyz/anchor";
import { Program, AnchorProvider, BN } from "@coral-xyz/anchor";
import { Idl } from "@coral-xyz/anchor/dist/cjs/idl";
// After (v1)
import * as anchor from "@anchor-lang/core";
import { Program, AnchorProvider, BN } from "@anchor-lang/core";
import { Idl } from "@anchor-lang/core";
IDL management now uses anchor idl init / anchor idl upgrade (CLI) or @solana-program/program-metadata (npm) — see migrating-v0.32-to-v1.md.
Known Working Combinations (Tested)
🟢 Anchor v1 (Recommended for new projects)
Anchor CLI: 1.0.0
anchor-lang: 1.0.0
anchor-spl: 1.0.0
solana-* crates: ^3
litesvm (dev): 0.8.2 (or 0.9.1 if solana-hash 4.0 / solana-vote-interface 5.0)
anchor-litesvm (dev): 0.3
TS: @anchor-lang/core ^1.0.0
Solana CLI: 3.x
Platform Tools: v1.52
Rust: 1.79–1.85+
Node.js: 20.x LTS
OS: Ubuntu 24.04+ (GLIBC ≥2.39) or macOS 14+
Test runner: surfpool (default in anchor test)
🟢 Modern (Recommended for existing 0.32 projects — Jan 2026)
Anchor CLI: 0.31.1
Solana CLI: 2.1.7 (stable)
Rust: 1.83.0
Platform Tools: v1.50
Node.js: 20.x LTS
OS: Ubuntu 24.04 or macOS 14+
🟢 Latest 0.32.x (Cutting edge pre-v1)
Anchor CLI: 0.32.1
Solana CLI: 2.1.7+
Rust: 1.84.0+
Platform Tools: v1.52
Node.js: 20.x LTS
OS: Ubuntu 24.04+ (GLIBC ≥2.39) or macOS 14+
🟡 Legacy Compatible (For older systems)
Anchor CLI: 0.30.1
Solana CLI: 1.18.26
Rust: 1.79.0
Platform Tools: v1.43
Node.js: 18.x LTS
OS: Ubuntu 20.04+ or macOS 12+
🟡 Transitional (Upgrading from 0.30 → 0.31)
Anchor CLI: 0.31.0
Solana CLI: 2.0.x
Rust: 1.79.0
Platform Tools: v1.47
Node.js: 20.x LTS
OS: Ubuntu 24.04 or macOS 14+
Testing Tools: LiteSVM / Bankrun Compatibility
LiteSVM Rust Crate — Version Selection
Use the row that matches your workspace's resolved solana-* granular crate versions:
| litesvm (Rust) | solana-* era | Key markers | anchor-litesvm |
|---|---|---|---|
| 0.8.2 | ~3.0 | solana-hash ~3.0, solana-vote-interface 4.0, solana-system-interface 2.0 | 0.3 (requires anchor-lang ^1.0.0, litesvm ^0.8.2) |
| 0.9.1 | ~3.1–~3.3 | solana-hash 4.0, solana-vote-interface 5.0, solana-system-interface 3.0 | TBD — anchor-litesvm 0.3 declared litesvm ^0.8.2; check for a newer release |
| >0.10.0 | 3.3+ | follow latest releases | follow litesvm/anchor-litesvm release |
Diagnostic: run cargo tree -d — duplicate solana-* minor versions in the tree means the selected litesvm version is mismatched.
LiteSVM npm Package (TypeScript tests)
| Tool | npm Package | GLIBC Req | Node.js | Notes |
|---|---|---|---|---|
| LiteSVM 0.5.0 | litesvm | ≥2.38 ⚠️ | ≥18 | Tested: native binary (litesvm.linux-x64-gnu.node) fails on Debian 12 (GLIBC 2.36) with undefined symbol: __isoc23_strtol. Works on Ubuntu 24.04+, macOS. |
| LiteSVM 0.3.x | litesvm | ≥2.31 | ≥16 | Older API, may work on older systems |
| solana-bankrun | solana-bankrun | ≥2.28 | ≥16 | Legacy — being replaced by LiteSVM |
| anchor-bankrun | anchor-bankrun | ≥2.28 | ≥16 | Legacy Anchor wrapper for bankrun |
| anchor-litesvm | anchor-litesvm | Same as litesvm | ≥18 | Anchor wrapper for LiteSVM |
LiteSVM on Older Systems
If litesvm 0.5.0 fails with GLIBC errors:
- Upgrade OS to Ubuntu 24.04+ (recommended)
- Use Docker:
FROM ubuntu:24.04base image - Fall back to
solana-bankruntemporarily - Build litesvm from source (requires Rust + napi-rs toolchain)
Verified Test Environment (Jan 2026)
✅ Works: Anchor CLI 0.30.1 (built from source) + Solana CLI 2.2.16 + Rust 1.93.0 + Debian 12
❌ Fails: litesvm 0.5.0 native binary on Debian 12 (GLIBC 2.36)
❌ Fails: Anchor 0.31.1/0.32.1 pre-built binaries on Debian 12 (GLIBC 2.36)
✅ Works: cargo build-sbf (Solana 2.2.16, platform-tools v1.48) on Debian 12
✅ Works: Anchor 0.30.1 built from source with Rust 1.93.0 on Debian 12