mirror of
https://github.com/actualbudget/actual.git
synced 2026-05-06 07:01:45 -05:00
[Bug]: Native Install Dependency Issues #1500
Closed
opened 2026-02-28 19:45:30 -06:00 by GiteaMirror
·
2 comments
No Branch/Tag Specified
master
claude/hide-default-categories-1cwBZ
matiss/crdt-source-loading
youngcw/unlock-duplicates
matiss/crdt-protobuf
release/26.5.0
claude/update-issue-template-ykMNn
claude/fix-issue-7667-DPXi3
cursor/formula-feedback-improvements-4223
cursor/resolve-pr-7449-ee11
claude/fix-typescript-build-error-JPtZ5
jfdoming/api-tokens-part-3
jfdoming/api-tokens-part-2
jfdoming/api-tokens-part-1
claude/speed-up-vrt-workflow-ZAyI5
claude/crdt-version-auto-publish-Ph1BH
copilot/add-repository-configs-to-packages
worktree-compressed-drifting-ritchie
worktree-mellow-strolling-dawn
matiss/browser-api
claude/api-consumer-verification-kfz1K
feature/enable-banking
cursor/transaction-table-rewrite-f077
pr-7454
claude/fix-issue-7410-LLLQ4
release/v100.0.0
revert-7350-trim-deps
revert-7220-sankey-report
revert-7242-fix/split-parent-update-corruption
revert-7281-generate-icons
claude/electron-to-tauri-migration-LjBN8
worktree-remotion
release/vv26.4.0-pre
claude/browser-compatible-api-QbhHh
claude/improve-cli-transactions-waTUY
claude/publish-react-native-ios-j8qoT
js-proxy
claude/fix-flaky-ci-job-5gDdz
react-query-rules
react-query-useSchedules
claude/nightly-theme-validation-scan-DzOGD
claude/debug-simplefin-error-ZuKzB
matiss/desktop-client-subpath-imports
claude/fix-simplefin-ssrf-T31gX
claude/release-notes-validation-X7rvR
add-claude-github-actions-1772738270730
cursor/sync-performance-notification-9899
react-query-prefs
matiss/chunked-sync-and-progress-ux
v26.2.1
copilot/sub-pr-6880
fix-react-query-clear-on-close-budget
copilot/sub-pr-6140
feat/auto-note
feat/scoped-bank-sync
cursor/desktop-transactions-react-table-1d0c
fix-exhaustive-deps-App
copilot/fix-find-replace-bug
release/v26.2.0-pre
matiss/browser-tests
mobile-fix-drag-and-drop-across-groups
budget-table-v2
PayeeAutocomplete2
pglite
bugfix/plugins/fix-plugins-sw
feat/plugins/plugins-core-package
prerelease
matiss/unicode-minus-fix
cursor/fix-actual-github-issue-6206-gemini-3-pro-preview-9c37
TransactionFormPage
cursor/implement-mortgage-and-loan-account-type-78ca
tests-update-fill-with-pressSequentially
mobile/link-modal
deps/25.11
cursor/fix-update-vrt-apply-ci-job-dispatch-b324
sync-server-plugins
cursor/propose-patch-for-github-issue-5680-2a18
fix/compiler-preserve-inner-dollar-escapes
cursor/analyze-actual-budget-issue-and-propose-fix-5b70
coderabbitai/docstrings/0c070e5
cursor/add-wip-prefix-and-comment-to-prs-d78d
jfdoming/08-21-auto-focus-on-navigate-in-all-browsers
show-totals-on-mobile-budget-banners
allow-child-transactions-make-transfer
mobile-calculator-keyboard
payee-geolocation
enhance/restore_scroll_position
dm-fix-second-click-on-mobile-new-transaction-2
scrollToLocationBudget
alert-autofix-38
tsconfig-composite
mobile-fix-uncategorized-transactions-on-tracking-budgets
server-budget-handlers
fix-sql-injection-in-cleanup-template
non-chrome-draggable-workaround
mobile-budget-page-swipe-navigation
ts-db-all
stable
dark-theme-with-brand-colors
fix-mobile-delete-group
ts-db-select
UnderKoen/reconcile-context-menu
master-before-server-merge
v25.2.1
ts-runQuery
rename-redux-hooks
UnderKoen/3557-persist-state-in-history
remove-redux-CLOSE_BUDGET
fix-exhaustive-deps-errors-FinancesApp
redux-toolkit-createSlice-backup
accounts-function-component
ts-useSplitsExpanded
loot-core-server-package
useTransactios-in-TransactionEdit
react-aria-input
move-redux-to-desktop-client
QueryState-type
fix-themes-applied-late
mobile-vrts
revert-3295-spendingCardFix
react-aria-button-4
split-payee-on-mobile
twk3/pin-apis-crdt
notes-tag-autocomplete
ts-LoadBackup
dnd-kit
package-upgrades
v26.5.0
v26.4.0
v26.3.0
v26.2.1
v26.2.0
v26.1.0
v25.12.0
v25.11.0
v25.10.0
v25.9.0
v25.8.0
v25.7.1
v25.7.0
v25.6.1
v25.6.0
v25.5.0
v25.4.0
v25.3.1
v25.3.0
v25.2.1
v25.2.0
v25.1.0
v24.12.0
v24.11.0
v24.10.1
v24.10.0
v24.9.0
v24.8.0
v24.7.0
v24.6.0
v24.5.0
v24.4.0
v24.3.0
v24.2.0
v24.1.0
v23.12.0
v23.11.0
v23.10.0
v23.9.0
v23.8.1
v23.8.0
v23.7.2
v23.7.1
v23.7.0
v23.6.0
v23.5.0
v23.4.2
v23.4.1
v23.4.0
v23.3.2
v23.3.0
v23.2.9
v23.2.5
v23.1.12
v22.12.9
Labels
Clear labels
AI generated
API
bank sync
budgeting
bug
can’t replicate
dependencies
docker
documentation
electron
experimental feature
feature
feedback
goal templates
good first issue
help wanted
importers
maintenance
needs info
needs testing
needs triage
needs votes
openid
payees
pull-request
regression
reports
responsive
rules
schedules
server
✨ merged
split transactions
tech debt
theme
transaction import
transaction reconciliation
transactions
translations
upstream
user interface
✅ approved
wontfix
Mirrored from GitHub Pull Request
No Label
bug
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: github-starred/actual#1500
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @weswitt on GitHub (Oct 11, 2024).
Verified issue does not already exist?
What happened?
I'm running AB in docker but thought I'd try to get a native install up and running. I'm seeing the following:
yarn start
Checking if there are any migrations to run for direction "up"...
Rejection: Error: The module '/root/actual-server/node_modules/better-sqlite3/build/Release/better_sqlite3.node'
was compiled against a different Node.js version using
NODE_MODULE_VERSION 108. This version of Node.js requires
NODE_MODULE_VERSION 109. Please try re-compiling or re-installing
the module (for instance, using
npm rebuildornpm install).at Module._extensions..node (node:internal/modules/cjs/loader:1452:18)
at Module.load (node:internal/modules/cjs/loader:1197:32)
at Module._load (node:internal/modules/cjs/loader:1013:12)
at Module.require (node:internal/modules/cjs/loader:1225:19)
at require (node:internal/modules/helpers:177:18)
at bindings (/root/actual-server/node_modules/bindings/bindings.js:112:48)
at new Database (/root/actual-server/node_modules/better-sqlite3/lib/database.js:48:64)
at openDatabase (file:///root/actual-server/src/db.js:57:30)
at getAccountDb (file:///root/actual-server/src/account-db.js:12:18)
at Migration.up (file:///root/actual-server/migrations/1694360479680-create-account-db.js:4:9) {
code: 'ERR_DLOPEN_FAILED'
}
node -v
v18.19.1
npm -v
9.2.0
OS: Ubuntu 22.04
I followed the instructions at https://actualbudget.org/docs/install/local
How can I resolve the better_sqlite3 version problem?
Where are you hosting Actual?
Locally via Yarn
What browsers are you seeing the problem on?
Chrome
Operating System
Linux
@youngcw commented on GitHub (Oct 18, 2024):
Im not sure what would cause this. Maybe reach out on discord for tech support there.
@S3NTYN3L commented on GitHub (May 3, 2025):
Fixing
better-sqlite3Node.js Version Mismatch for Actual Budget on LinuxHi @weswitt, I saw your issue with the
better-sqlite3Node.js mismatch error (Error: The module '.../better_sqlite3.node' was compiled against a different Node.js version) and hit the same problem setting up Actual Budget on my mother’s Linux Mint 22.1 laptop.This guide, based on the official instructions (https://actualbudget.org/docs/install/build-from-source), fixes it with a simple rebuild and includes a
systemdservice and update script for easy maintenance.I’ve attached a
.zipwith all files—tested on Mint, but should work on any Linux distro.Prerequisites
Install
nvm,git, andyarnas needed:nvmin the current session:\. "$HOME/.nvm/nvm.sh". Alternatively, reload the shell (source ~/.bashrc) or restart the terminal.better-sqlite3fix:Build Steps
Follow the guide’s steps, with a fix for
better-sqlite3:actualdirectory toactual-serverfor clarity (mv actual actual-server). Adjust paths if you keepactual.better-sqlite3: Rebuild native modules for your Node.js version (this guide uses v22, but v18, v19, v20, or v21 should work):http://localhost:5006.Systemd Service
To run the server automatically, use the
actual-server.servicefile from the attachedactual-budget-files.zipor create it manually:Using the zipped file:
actual-budget-files.zip(attached below).actual-server.serviceto the system directory:%hwith your home directory (e.g.,/home/john) and%uwith your username (e.g.,john):Creating manually:
Paste:
Note:
%hand%uare systemd specifiers for the user’s home directory and username.If they don’t work (e.g., older distros), replace with your home path and username (e.g.,
/home/johnandjohn).Enable and start the service:
Verify it’s running:
Update Script
To handle updates when Actual Budget prompts, use the
update-actual-server.shfile from the attachedactual-budget-files.zipor create it manually:Using the zipped file:
actual-budget-files.zip(attached below).update-actual-server.shin~/actual-server:Creating manually:
Paste:
Make it executable:
Test it:
Desktop File
For easy updates, use the
Update-Actual-Budget.desktopfile from the attachedactual-budget-files.zipor create it manually:Using the zipped file:
actual-budget-files.zip(attached below).Update-Actual-Budget.desktopon the desktop:Creating manually:
Paste:
Make it executable:
Note:
gnome-terminalis Mint’s default. For other distros, check your desktop environment (echo $XDG_CURRENT_DESKTOP) and replace withxfce4-terminal,konsole,xterm, etc., as needed.Sudoers Setup
The update script uses
sudo systemctl, which requires a password unless configured. Add asudoersrule:Add (replace
YOUR_USERNAMEwith the actual username):Test it:
Instructions for Updates
When Actual Budget prompts for an update:
http://localhost:5006.Troubleshooting
If
better-sqlite3errors persist:If the service or UI fails:
node -v(should be v18 or greater).sudo journalctl -u actual-server.service --since=today -r -n 50 --no-pager.curl http://localhost:5006.This setup assumes a single-user system. For multi-user systems, adjust permissions or run the service as a specific user.
Note to Devs
Feel free to use, adapt, or incorporate this guide into the Actual Budget documentation or troubleshooting resources.
I hope it helps other users avoid the
better-sqlite3issue!actual-budget-files.zip