2021-03-02 22:17:11 +01:00
# macOS Build Guide
2024-07-24 12:55:19 +02:00
**Updated for MacOS [14.4 ](https://www.apple.com/macos/sonoma/ )**
2021-03-02 22:17:11 +01:00
This guide describes how to build bitcoind, command-line utilities, and GUI on macOS
## Preparation
2019-06-14 13:50:12 +02:00
2016-05-09 10:30:27 +02:00
The commands in this guide should be executed in a Terminal application.
2021-03-02 22:17:11 +01:00
macOS comes with a built-in Terminal located in:
2019-06-14 13:50:12 +02:00
```
/Applications/Utilities/Terminal.app
```
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
### 1. Xcode Command Line Tools
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
The Xcode Command Line Tools are a collection of build tools for macOS.
These tools must be installed in order to build Bitcoin Core from source.
To install, run the following command from your terminal:
``` bash
2019-06-14 13:50:12 +02:00
xcode-select --install
```
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
Upon running the command, you should see a popup appear.
Click on `Install` to continue the installation process.
2016-06-12 06:59:02 +02:00
2021-03-02 22:17:11 +01:00
### 2. Homebrew Package Manager
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
Homebrew is a package manager for macOS that allows one to install packages from the command line easily.
While several package managers are available for macOS, this guide will focus on Homebrew as it is the most popular.
Since the examples in this guide which walk through the installation of a package will use Homebrew, it is recommended that you install it to follow along.
Otherwise, you can adapt the commands to your package manager of choice.
To install the Homebrew package manager, see: https://brew.sh
Note: If you run into issues while installing Homebrew or pulling packages, refer to [Homebrew's troubleshooting page ](https://docs.brew.sh/Troubleshooting ).
### 3. Install Required Dependencies
The first step is to download the required dependencies.
These dependencies represent the packages required to get a barebones installation up and running.
2021-11-19 02:52:48 +01:00
See [dependencies.md ](dependencies.md ) for a complete overview.
2021-03-02 22:17:11 +01:00
To install, run the following from your terminal:
``` bash
2024-07-24 12:55:19 +02:00
brew install cmake boost pkg-config libevent
2019-06-14 13:50:12 +02:00
```
2012-12-12 17:52:38 +01:00
2024-04-29 10:33:21 +02:00
For macOS 11 (Big Sur) and 12 (Monterey) you need to install a more recent version of llvm.
``` bash
brew install llvm
```
And append the following to the configure commands below:
``` bash
CC=$(brew --prefix llvm)/bin/clang CXX=$(brew --prefix llvm)/bin/clang++
```
Try `llvm@17` if compilation fails with the default version of llvm.
2021-03-02 22:17:11 +01:00
### 4. Clone Bitcoin repository
2017-07-09 13:15:45 +02:00
2021-03-02 22:17:11 +01:00
`git` should already be installed by default on your system.
Now that all the required dependencies are installed, let's clone the Bitcoin Core repository to a directory.
All build scripts and commands will run from this directory.
``` bash
git clone https://github.com/bitcoin/bitcoin.git
2019-06-14 13:50:12 +02:00
```
2016-12-23 09:52:08 +01:00
2021-03-02 22:17:11 +01:00
### 5. Install Optional Dependencies
#### Wallet Dependencies
It is not necessary to build wallet functionality to run `bitcoind` or `bitcoin-qt` .
2022-03-16 13:25:01 +01:00
###### Descriptor Wallet Support
2021-03-02 22:17:11 +01:00
2022-03-16 13:25:01 +01:00
`sqlite` is required to support for descriptor wallets.
2021-03-02 22:17:11 +01:00
2022-03-16 13:25:01 +01:00
macOS ships with a useable `sqlite` package, meaning you don't need to
install anything.
2021-01-08 22:55:33 +01:00
2022-03-16 13:25:01 +01:00
###### Legacy Wallet Support
2020-12-04 12:14:37 +01:00
2022-03-16 13:25:01 +01:00
`berkeley-db@4` is only required to support for legacy wallets.
Skip if you don't intend to use legacy wallets.
2020-12-04 12:14:37 +01:00
2021-03-02 22:17:11 +01:00
``` bash
2022-03-16 13:25:01 +01:00
brew install berkeley-db@4
2020-12-04 12:14:37 +01:00
```
2021-03-02 22:17:11 +01:00
---
2020-12-04 12:14:37 +01:00
2021-03-02 22:17:11 +01:00
#### GUI Dependencies
2020-12-04 12:14:37 +01:00
2021-03-02 22:17:11 +01:00
###### Qt
2020-12-04 12:14:37 +01:00
2024-07-24 12:55:19 +02:00
Bitcoin Core includes a GUI built with the cross-platform Qt Framework. To compile the GUI, we need to install
the necessary parts of Qt, the libqrencode and pass `-DBUILD_GUI=ON` . Skip if you don't intend to use the GUI.
2017-11-16 08:36:08 +01:00
2021-03-02 22:17:11 +01:00
``` bash
brew install qt@5
2017-11-16 08:36:08 +01:00
```
2021-03-02 22:17:11 +01:00
Note: Building with Qt binaries downloaded from the Qt website is not officially supported.
See the notes in [#7714 ](https://github.com/bitcoin/bitcoin/issues/7714 ).
2017-11-16 08:36:08 +01:00
2024-07-24 12:55:19 +02:00
###### libqrencode
2020-12-04 12:14:37 +01:00
2024-07-24 12:55:19 +02:00
The GUI will be able to encode addresses in QR codes unless this feature is explicitly disabled. To install libqrencode, run:
2021-03-02 22:17:11 +01:00
``` bash
brew install qrencode
2020-12-04 12:14:37 +01:00
```
2024-07-24 12:55:19 +02:00
Otherwise, if you don't need QR encoding support, use the `-DWITH_QRENCODE=OFF` option to disable this feature in order to compile the GUI.
2021-03-02 22:17:11 +01:00
---
#### Port Mapping Dependencies
###### miniupnpc
2017-11-16 08:36:08 +01:00
2021-03-02 22:17:11 +01:00
miniupnpc may be used for UPnP port mapping.
Skip if you do not need this functionality.
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
``` bash
brew install miniupnpc
```
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
###### libnatpmp
2016-05-09 10:30:27 +02:00
2021-03-02 22:17:11 +01:00
libnatpmp may be used for NAT-PMP port mapping.
Skip if you do not need this functionality.
2016-05-09 10:30:27 +02:00
2021-03-02 22:17:11 +01:00
``` bash
brew install libnatpmp
```
2012-12-12 17:52:38 +01:00
2021-03-02 22:17:11 +01:00
Note: UPnP and NAT-PMP support will be compiled in and disabled by default.
Check out the [further configuration ](#further-configuration ) section for more information.
2019-06-14 13:50:12 +02:00
2021-03-02 22:17:11 +01:00
---
2019-06-14 13:50:12 +02:00
2021-03-02 22:17:11 +01:00
#### ZMQ Dependencies
Support for ZMQ notifications requires the following dependency.
Skip if you do not need ZMQ functionality.
``` bash
brew install zeromq
2019-06-14 13:50:12 +02:00
```
2018-09-05 20:57:47 +02:00
2021-03-02 22:17:11 +01:00
ZMQ is automatically compiled in and enabled if the dependency is detected.
Check out the [further configuration ](#further-configuration ) section for more information.
For more information on ZMQ, see: [zmq.md ](zmq.md )
2018-09-05 20:57:47 +02:00
2021-03-02 22:17:11 +01:00
---
2018-09-05 20:57:47 +02:00
2021-03-02 22:17:11 +01:00
#### Test Suite Dependencies
There is an included test suite that is useful for testing code changes when developing.
To run the test suite (recommended), you will need to have Python 3 installed:
``` bash
brew install python
```
---
#### Deploy Dependencies
2024-07-24 12:55:19 +02:00
You can [deploy ](#3-deploy-optional ) a `.zip` containing the Bitcoin Core application.
2022-11-18 13:36:20 +01:00
It is required that you have `python` installed.
2021-03-02 22:17:11 +01:00
## Building Bitcoin Core
### 1. Configuration
There are many ways to configure Bitcoin Core, here are a few common examples:
##### Wallet (BDB + SQlite) Support, No GUI:
2024-07-24 12:55:19 +02:00
If `berkeley-db@4` or `sqlite` are not installed, this will throw an error.
2021-03-02 22:17:11 +01:00
``` bash
2024-07-24 12:55:19 +02:00
cmake -B build -DWITH_BDB=ON
2021-03-02 22:17:11 +01:00
```
##### Wallet (only SQlite) and GUI Support:
2024-07-24 12:55:19 +02:00
This enables the GUI.
If `sqlite` or `qt` are not installed, this will throw an error.
2021-03-02 22:17:11 +01:00
``` bash
2024-07-24 12:55:19 +02:00
cmake -B build -DBUILD_GUI=ON
2021-03-02 22:17:11 +01:00
```
##### No Wallet or GUI
``` bash
2024-07-24 12:55:19 +02:00
cmake -B build -DENABLE_WALLET=OFF
2021-03-02 22:17:11 +01:00
```
##### Further Configuration
You may want to dig deeper into the configuration options to achieve your desired behavior.
Examine the output of the following command for a full list of configuration options:
``` bash
2024-07-24 12:55:19 +02:00
cmake -B build -LH
2021-03-02 22:17:11 +01:00
```
### 2. Compile
After configuration, you are ready to compile.
Run the following in your terminal to compile Bitcoin Core:
``` bash
2024-07-24 12:55:19 +02:00
cmake --build build # Use "-j N" here for N parallel jobs.
ctest --test-dir build # Use "-j N" for N parallel tests. Some tests are disabled if Python 3 is not available.
2021-03-02 22:17:11 +01:00
```
### 3. Deploy (optional)
2022-11-18 13:36:20 +01:00
You can also create a `.zip` containing the `.app` bundle by running the following command:
2021-03-02 22:17:11 +01:00
``` bash
2024-07-24 12:55:19 +02:00
cmake --build build --target deploy
2021-03-02 22:17:11 +01:00
```
## Running Bitcoin Core
Bitcoin Core should now be available at `./src/bitcoind` .
If you compiled support for the GUI, it should be available at `./src/qt/bitcoin-qt` .
The first time you run `bitcoind` or `bitcoin-qt` , it will start downloading the blockchain.
This process could take many hours, or even days on slower than average systems.
By default, blockchain and wallet data files will be stored in:
``` bash
/Users/${USER}/Library/Application Support/Bitcoin/
```
2012-12-12 17:52:38 +01:00
2016-06-29 13:13:00 +02:00
Before running, you may create an empty configuration file:
2021-03-02 22:17:11 +01:00
2019-06-14 13:50:12 +02:00
```shell
mkdir -p "/Users/${USER}/Library/Application Support/Bitcoin"
2012-12-12 17:52:38 +01:00
2019-06-14 13:50:12 +02:00
touch "/Users/${USER}/Library/Application Support/Bitcoin/bitcoin.conf"
2016-05-09 10:30:27 +02:00
2019-06-14 13:50:12 +02:00
chmod 600 "/Users/${USER}/Library/Application Support/Bitcoin/bitcoin.conf"
```
2012-12-12 17:52:38 +01:00
2016-05-09 10:30:27 +02:00
You can monitor the download process by looking at the debug.log file:
2021-03-02 22:17:11 +01:00
2019-06-14 13:50:12 +02:00
```shell
tail -f $HOME/Library/Application\ Support/Bitcoin/debug.log
```
2014-02-26 03:35:48 +01:00
2019-06-14 13:50:12 +02:00
## Other commands:
2021-03-02 22:17:11 +01:00
2019-06-14 13:50:12 +02:00
```shell
2024-07-24 12:55:19 +02:00
./build/src/bitcoind -daemon # Starts the bitcoin daemon.
./build/src/bitcoin-cli --help # Outputs a list of command-line options.
./build/src/bitcoin-cli help # Outputs a list of RPC commands when the daemon is running.
./build/src/qt/bitcoin-qt -server # Starts the bitcoin-qt server mode, allows bitcoin-cli control
2019-06-14 13:50:12 +02:00
```