Installation

Note: For production deployments or docker based development use frappe_docker.

System Requirements

This guide assumes you are using a personal computer, VPS or a bare-metal server. You also need to be on a *nix system, so any Linux Distribution and macOS is supported. If you're a Windows user, you could use Ubuntu in WSL. We officially support only the following distributions.

  1. macOS
  2. Debian / Ubuntu

Learn more about the architecture here.

Pre-requisites

MariaDB 10.6.6+
Python 3.10/11/12
Node 18 or 20
Redis 6                                       (caching and realtime updates)
yarn 1.12+                                    (js dependency manager)
pip 20+                                       (py dependency manager)
wkhtmltopdf (version 0.12.5 with patched qt)  (for pdf generation)
cron                                          (bench's scheduled jobs: automated certificate renewal, scheduled backups)

macOS

Install command line version of Xcode tools.

xcode-select --install

Install Homebrew. It makes it easy to install packages on macOS.

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

Install wkhtmltopdf

curl -L https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-2/wkhtmltox-0.12.6-2.macos-cocoa.pkg -O

installer -pkg wkhtmltox-0.12.6-2.macos-cocoa.pkg -target ~

Now, you can easily install the required packages by running the following command

brew install python@3.12 git redis mariadb@10.6 node@18

Now, edit the MariaDB configuration file (this step is not required for Frappe v15.21.0 or above).

nano /usr/local/etc/my.cnf

For Apple Silicon (non Intel macs), the path for the MariaDB config is

nano /opt/homebrew/etc/my.cnf

And add this configuration

[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
bind-address = 127.0.0.1

[mysql]
default-character-set = utf8mb4

Now, just restart the mysql service and you are good to go.

brew services restart mariadb@10.6

Install Yarn

Install yarn using npm

npm install -g yarn

Debian / Ubuntu

You should be running Debian 12+ or Ubuntu 22.04+, otherwise you may have issues with some of the packages.

Update your system's package index

sudo apt update

Install git, python, and redis

sudo apt install git python-is-python3 python3-dev python3-pip redis-server

Install MariaDB

sudo apt install mariadb-server mariadb-client

During this installation you'll be prompted to set the MySQL root password. If you are not prompted, you'll have to initialize the MySQL server setup yourself. You can do that by running the command:

mariadb-secure-installation

Remember: only run it if you're not prompted the password during setup.

It is really important that you remember this password, since it'll be useful later on.

Now, edit the MariaDB configuration file (this step is not required for Frappe v15.21.0 or above).

nano /etc/mysql/my.cnf

And add this configuration

[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

[mysql]
default-character-set = utf8mb4

Now, just restart the MariaDB service and you are good to go.

sudo systemctl restart mariadb

Install Node

We recommend installing node using nvm

curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.1/install.sh | bash

After nvm is installed, you may have to close your terminal and open another one. Now run the following command to install node.

nvm install 18

Verify the installed version, by running:

$ node -v
v18.20.4

Finally, install yarn using npm

npm install -g yarn

Install wkhtmltopdf

sudo apt install xvfb libfontconfig

Download and install wkhtmltopdf package from https://wkhtmltopdf.org/downloads.html, then run this command to install the package.

sudo dpkg -i wkhtmltox_file.deb

Install Bench CLI

Install bench via pip3

pip install frappe-bench

Pip discourages system-wide installations, thus you might have to do something equivalent to source rcfile. Will vary depending on your OS. E.g. for Ubuntu

$ source ~/.profile

Depending on your OS version and python/pip version, you may get an error here regarding an externally-managed-environment

You can work around this for now by running or use virtualenv

pip install frappe-bench --break-system-packages

An alternative method to do this is with uv and a shell alias

curl -LsSf https://astral.sh/uv/install.sh | sh

Add alias bench='uvx --from frappe-bench bench' to your shell rc file (.zshrc, .bashrc or similar)

Confirm the bench installation by checking the version

$ bench --version
5.22.9

Create your first bench.

cd ~
bench init <directory name>

Congratulations, you have installed bench onto your system.

Discard
Save
Was this article helpful?

On this page