2
0
mirror of https://github.com/frappe/frappe_docker.git synced 2025-01-25 16:18:32 +00:00

Improve documentation, including new instructions for jupyterlab

This commit is contained in:
Davide Bortolami 2020-04-17 02:57:20 +01:00
parent 5f3c4df4ad
commit 85a824753b

View File

@ -2,10 +2,17 @@
## Prerequisites ## Prerequisites
In order to start deveping you need to satisfy the folowing prerequisites:
- Docker - Docker
- docker-compose - docker-compose
- user added to docker group - user added to docker group
It is recommended you allocate at least 4GB of RAM to docker:
- [Instructions for Windows](https://docs.docker.com/docker-for-windows/#resources)
- [Instructions for MacOOS](https://docs.docker.com/docker-for-mac/#resources)
## Bootstrap Containers for development ## Bootstrap Containers for development
Clone and change directory to frappe_docker directory Clone and change directory to frappe_docker directory
@ -47,7 +54,7 @@ Run the following commands in the terminal inside the container. You might need
```shell ```shell
bench init --skip-redis-config-generation --frappe-branch version-12 frappe-bench bench init --skip-redis-config-generation --frappe-branch version-12 frappe-bench
cd frappe-bench cd frappe-bench
``` ```
### Setup hosts ### Setup hosts
@ -115,14 +122,16 @@ bench --site my.site clear-cache
### Install an app ### Install an app
To install an app we need to fetch it from the appropriate git repo, then install in on the appropriate site To install an app we need to fetch it from the appropriate git repo, then install in on the appropriate site:
You can check [VSCode container remote extension documentation](https://code.visualstudio.com/docs/remote/containers#_sharing-git-credentials-with-your-container) regarding git creedential sharing.
```shell ```shell
bench get-app myapp https://github.com/myusername/myapp.git bench get-app myapp https://github.com/myusername/myapp.git
bench --site my.site install-app myapp bench --site my.site install-app myapp
``` ```
### Start development ### Start Frappe without debugging
Execute following command from the `frappe-bench` directory. Execute following command from the `frappe-bench` directory.
@ -130,6 +139,8 @@ Execute following command from the `frappe-bench` directory.
bench start bench start
``` ```
You can now login with user `Administrator` and the password you choose when creating the site.
Note: To start bench with debugger refer section for debugging. Note: To start bench with debugger refer section for debugging.
### Fixing MariaDB issues after rebuilding the container ### Fixing MariaDB issues after rebuilding the container
@ -178,7 +189,7 @@ And enter the interactive shell for the development container with the following
docker exec -e "TERM=xterm-256color" -w /workspace/development -it devcontainer_frappe_1 bash docker exec -e "TERM=xterm-256color" -w /workspace/development -it devcontainer_frappe_1 bash
``` ```
### Visual Studio Code Python Debugging ### Start Frappe with Visual Studio Code Python Debugging
To enable Python debugging inside Visual Studio Code, you must first install the `ms-python.python` extension inside the container. To enable Python debugging inside Visual Studio Code, you must first install the `ms-python.python` extension inside the container.
@ -199,4 +210,35 @@ honcho start \
worker_default worker_default
``` ```
This command starts all processes with the exception of Redis (which is already running in separate container) and the `web` process. The latter can can finally be started from the debugger tab of VSCode. This command starts all processes with the exception of Redis (which is already running in separate container) and the `web` process. The latter can can finally be started from the debugger tab of VSCode by clicking on the "play" button.
You can now login with user `Administrator` and the password you choose when creating the site.
## Developing using the interactive console
You can launch the interactive shell console with:
```shell
bench console
```
To work with a more advanced interactive environment that supports full Jupyter Notebooks you can run JupyterLab inside the Python Venv, which will already be activated.
First you'll need to foward port 8090 from your debug container. Launch VSCode command palette (cmd+shift+p or ctrl+shift+p), run the command `Forward a port` and type port `8090`.
You can then install and launch jupyterlab appropriately:
```shell
pip install jupyterlab
jupyter lab --ip=0.0.0.0 --no-browser --port=8090
```
Then replace `my.site` with your site and run the following code in a Jupyter cell:
```python
import frappe
frappe.init(site='my.site', sites_path='/workspace/development/frappe-bench/sites')
frappe.connect()
frappe.local.lang = frappe.db.get_default('lang')
frappe.db.connect()
```