mirror of
https://github.com/frappe/bench.git
synced 2025-01-10 00:37:51 +00:00
26059c06fa
* Add new bench logo to the readme
* add spacing to the title
* Revert "add spacing to the title"
This reverts commit 86880d6456
.
192 lines
6.7 KiB
Markdown
Executable File
192 lines
6.7 KiB
Markdown
Executable File
<div align="center">
|
|
<img src="https://github.com/frappe/design/blob/master/logos/bench-logo.svg" height="128">
|
|
<h2>Frappe Bench</h2>
|
|
</div>
|
|
|
|
[![Build Status](https://travis-ci.org/frappe/bench.svg?branch=master)](https://travis-ci.org/frappe/bench)
|
|
|
|
The bench is a command-line utility that helps you to install apps, manage multiple sites and update Frappe / ERPNext apps on */nix (CentOS 6, Debian 7, Ubuntu, etc) for development and production. Bench will also create nginx and supervisor config files, setup backups and much more.
|
|
|
|
If you are using on a VPS make sure it has >= 1Gb of RAM or has swap setup properly.
|
|
|
|
To do this install, you must have basic information on how Linux works and should be able to use the command-line. If you are looking easier ways to get started and evaluate ERPNext, [download the Virtual Machine](https://erpnext.com/download) or take [a free trial on erpnext.com](https://erpnext.com/pricing).
|
|
|
|
If you have questions, please ask them on the [forum](https://discuss.erpnext.com/).
|
|
|
|
## Installation
|
|
|
|
## Manual Install
|
|
|
|
To manually install frappe/erpnext here are the steps
|
|
|
|
#### 1. Install Pre-requisites
|
|
|
|
- Python 2.7
|
|
- MariaDB 10+
|
|
- Nginx (for production)
|
|
- Nodejs
|
|
- Redis
|
|
- cron (crontab is required)
|
|
- wkhtmltopdf with patched Qt (for pdf generation)
|
|
|
|
#### 2. Install Bench
|
|
|
|
Install bench as a *non root* user,
|
|
|
|
git clone https://github.com/frappe/bench bench-repo
|
|
pip install --user -e bench-repo
|
|
|
|
Note: Please do not remove the bench directory the above commands will create
|
|
|
|
#### Basic Usage
|
|
|
|
* Create a new bench
|
|
|
|
The init command will create a bench directory with frappe framework
|
|
installed. It will be setup for periodic backups and auto updates once
|
|
a day.
|
|
|
|
bench init frappe-bench && cd frappe-bench
|
|
|
|
* Add a site
|
|
|
|
Frappe apps are run by frappe sites and you will have to create at least one
|
|
site. The new-site command allows you to do that.
|
|
|
|
bench new-site site1.local
|
|
|
|
* Add apps
|
|
|
|
The get-app command gets remote frappe apps from a remote git repository and installs them. Example: [erpnext](https://github.com/frappe/erpnext)
|
|
|
|
bench get-app erpnext https://github.com/frappe/erpnext
|
|
|
|
* Install apps
|
|
|
|
To install an app on your new site, use the bench `install-app` command.
|
|
|
|
bench --site site1.local install-app erpnext
|
|
|
|
* Start bench
|
|
|
|
To start using the bench, use the `bench start` command
|
|
|
|
bench start
|
|
|
|
To login to Frappe / ERPNext, open your browser and go to `[your-external-ip]:8000`, probably `localhost:8000`
|
|
|
|
The default username is "Administrator" and password is what you set when you created the new site.
|
|
|
|
|
|
---
|
|
|
|
## Easy Install
|
|
|
|
- This is an opinionated setup so it is best to setup on a blank server.
|
|
- Works on Ubuntu 14.04 to 16.04, CentOS 7+, Debian 7 to 8 and MacOS X.
|
|
- You may have to install Python 2.7 (eg on Ubuntu 16.04+) by running `apt-get install python-minimal`
|
|
- You may also have to install build-essential and python-setuptools by running `apt-get install build-essential python-setuptools`
|
|
- This script will install the pre-requisites, install bench and setup an ERPNext site
|
|
- Passwords for Frappe Administrator and MariaDB (root) will be asked
|
|
- MariaDB (root) password may be `password` on a fresh server
|
|
- You can then login as **Administrator** with the Administrator password
|
|
- If you find any problems, post them on the forum: [https://discuss.erpnext.com](https://discuss.erpnext.com)
|
|
|
|
Open your Terminal and enter:
|
|
|
|
#### 1. Download the install script
|
|
|
|
For Linux:
|
|
|
|
wget https://raw.githubusercontent.com/frappe/bench/master/playbooks/install.py
|
|
|
|
For Mac OSX:
|
|
|
|
Install X Code (from App store) and HomeBrew (http://brew.sh/) first
|
|
|
|
brew install python
|
|
brew install git
|
|
|
|
Download the Script
|
|
|
|
curl "https://raw.githubusercontent.com/frappe/bench/master/playbooks/install.py" -o install.py
|
|
|
|
#### 2. Run the install script
|
|
|
|
If you are on a fresh server and logged in as root, use --user flag to create a user and install using that user
|
|
|
|
python install.py --develop --user frappe
|
|
|
|
For developer setup:
|
|
|
|
sudo python install.py --develop
|
|
|
|
For production:
|
|
|
|
sudo python install.py --production
|
|
|
|
#### What will this script do?
|
|
|
|
- Install all the pre-requisites
|
|
- Install the command line `bench`
|
|
- Create a new bench (a folder that will contain your entire frappe/erpnext setup)
|
|
- Create a new ERPNext site on the bench
|
|
|
|
#### How do I start ERPNext
|
|
|
|
1. For development: Go to your bench folder (`frappe-bench` by default) and start the bench with `bench start`
|
|
2. For production: Your process will be setup and managed by `nginx` and `supervisor`. [Setup Production](https://frappe.io/docs/user/en/bench/guides/setup-production.html)
|
|
|
|
---
|
|
|
|
## Docker Install - For Developers (beta)
|
|
|
|
1. For developer setup, you can also use the official [Frappé Docker](https://github.com/frappe/frappe_docker/).
|
|
2. The app, mariadb and redis run on individual containers
|
|
3. This setup supports multi-tenancy and exposes the frappe-bench volume as a external storage.
|
|
4. For more details, [read the instructions on the Frappé Docker README](https://github.com/frappe/frappe_docker/)
|
|
|
|
Help
|
|
====
|
|
|
|
For bench help, you can type
|
|
|
|
bench --help
|
|
|
|
Updating
|
|
========
|
|
|
|
To manually update the bench, run `bench update` to update all the apps, run
|
|
patches, build JS and CSS files and restart supervisor (if configured to).
|
|
|
|
You can also run the parts of the bench selectively.
|
|
|
|
`bench update --pull` will only pull changes in the apps
|
|
|
|
`bench update --patch` will only run database migrations in the apps
|
|
|
|
`bench update --build` will only build JS and CSS files for the bench
|
|
|
|
`bench update --bench` will only update the bench utility (this project)
|
|
|
|
`bench update --requirements` will only update dependencies (python packages) for the apps installed
|
|
|
|
Guides
|
|
=======
|
|
- [Configuring HTTPS](https://frappe.io/docs/user/en/bench/guides/configuring-https.html)
|
|
- [Using Let's Encrypt to setup HTTPS](https://frappe.io/docs/user/en/bench/guides/lets-encrypt-ssl-setup.html)
|
|
- [Diagnosing the Scheduler](https://frappe.io/docs/user/en/bench/guides/diagnosing-the-scheduler.html)
|
|
- [Change Hostname](https://frappe.io/docs/user/en/bench/guides/adding-custom-domains)
|
|
- [Manual Setup](https://frappe.io/docs/user/en/bench/guides/manual-setup.html)
|
|
- [Setup Production](https://frappe.io/docs/user/en/bench/guides/setup-production.html)
|
|
- [Setup Multitenancy](https://frappe.io/docs/user/en/bench/guides/setup-multitenancy.html)
|
|
- [Stopping Production](https://github.com/frappe/bench/wiki/Stopping-Production-and-starting-Development)
|
|
|
|
|
|
Resources
|
|
=======
|
|
|
|
- [Background Services](https://frappe.io/docs/user/en/bench/resources/background-services.html)
|
|
- [Bench Commands Cheat Sheet](https://frappe.io/docs/user/en/bench/resources/bench-commands-cheatsheet.html)
|
|
- [Bench Procfile](https://frappe.io/docs/user/en/bench/resources/bench-procfile.html)
|