actualizacion de readme.md

francisco/photos
Francisco Sandoval 2023-12-20 12:35:48 -03:00
parent 09ce9cc8a8
commit ad740af3d0
1 changed files with 196 additions and 69 deletions

265
readme.md
View File

@ -1,64 +1,177 @@
# Dependencias # Estructura de carpetas
* **Django**: framework django Se recomienda la siguiente estructura de carpeta para iniciar proyecto
* **psycopg2-binary**: permite uso de base datos postgres
* **djangorestframework**: permite crear rest api json ~~~txt
* **django-cors-headers**: requerido para desarrollo de frontend, permite acceso desde una dominio distinto al backend /app
* **django-filter**: permite filtrar resultado usando paraquetros en querystring |-- /transporte
* **coreapi**: genera documentación de rest api | |-- (codigo del proyecto backend)
* **python-decouple**: lee archivo .env para variables de ambiente |
* **PyJWT**: permite generar json-web-token |-- /dumps
* **pymongo**: permite conectarse a base datos mongo | |-- (respaldos de la base de datos transporte)
* **Pillow**: permite imagenar imagenes |
* **openpyxl**: permite generar archivos excel |-- /proto
| |-- (codigo del proyecto)
|
|-- docker-compose.yml
|-- restore_db.sh
~~~
<br>
<br>
<br>
# Docker # Docker
Para iniciar la aplicacion usando docker Para iniciar la aplicacion usando docker
~~~bash ~~~bash
cd <carpeta del proyecto>/docker cd /app
docker compose up -d docker compose up -d
~~~ ~~~
<br>
<br>
<br>
# Proyectos involucrados
# Script para levantar aplicacion python ## Transporte
**start.sh** Ref: https://gitlab.com/m3f_usm/admin_transporte/backend
~~~bash ## Proto
Ref: https://gitlab.com/m3f_usm/proto
## Respaldos de base de datos
Ver información en:
https://gitlab.com/m3f_usm/admin_transporte/backend/-/wikis/Databases
<br>
<br>
<br>
# archivo: restore_db.sh
~~~sh
#!/bin/sh #!/bin/sh
cd /app
# si no existe directorio de ambiente, se crea # obtener el ultimo respaldo de la carpeta
if [ ! -d /app/libs ]; then LASTFILEDUMP=$(ls -t /dumps/*.sql.gz | sort -r | head -n 1)
python -m venv libs echo "FILE: $LASTFILEDUMP"
. ./libs/bin/activate
pip install -r requirements.txt
fi
# activar ambiente con dependencias # restaurar la base datos
. ./libs/bin/activate gunzip -c "$LASTFILEDUMP" | psql -U postgres "$POSTGRES_DB"
# si no existe un proyecto inicial, lo crea
if [ ! -d /app/project ]; then
django-admin startproject project
fi
# iniciar servidor con puerto 8000
python /app/project/manage.py runserver 0.0.0.0:8000
~~~
# Extraer models de base de datos
~~~bash
python manage.py inspectdb > api/models.py
~~~ ~~~
# file: docker-compose.yml # archivo produccion: docker-compose.yml
~~~yml
version: '3'
name: transporte
services:
backend:
image: python:3.11-alpine
depends_on:
- db
environment:
- PORT=4000
- DBHOST=db
- DBPORT=5432
- DBNAME=transporte
- DBSCHEMA=public
- DBUSER=postgres
- DBPASS=password
- DB_REDIS_HOST=dbproto
- DB_REDIS_PORT=6379
- SECRET_JWT="kf6Jc!f30Z!1k1N0#!%#"
ports:
- 4000:4000
volumes:
- ./transporte:/app
- venv:/root/venv
working_dir: /app
command: sh -c "
[ -d /root/venv/bin ] || ( \
python -m venv /root/venv/ \
&& . /root/venv/bin/activate \
&& pip install -r requirements.txt \
) ;
. /root/venv/bin/activate ;
cd /app ;
[ -d project ] || django-admin startproject project ;
[ -f .env ] || ( [ -f .env.develop ] && cp .env.develop .env ) ;
chmod -R o+w project/ ;
python project/manage.py runserver 0.0.0.0:$$PORT
"
db:
image: postgis/postgis:14-3.4-alpine
volumes:
- db:/var/lib/postgresql/data
- ./dumps:/dumps
- ./restore_db.sh:/docker-entrypoint-initdb.d/02_restore_db.sh
ports:
- 5432:5432
environment:
POSTGRES_PASSWORD: password
POSTGRES_DB: transporte
PGDATA: /var/lib/postgresql/data/pgdata
proto:
image: python:3.11-alpine
environment:
- DB_REDIS_HOST=dbproto
- DB_REDIS_PORT=6379
- TZ=America/Santiago
volumes:
- ./proto:/app
- venv_proto:/root/venv
working_dir: /app
command: sh -c "
[ -d /root/venv/bin ] || ( \
python -m venv /root/venv/ \
&& . /root/venv/bin/activate \
&& pip install -r requirements.txt \
) ;
. /root/venv/bin/activate ;
cd /app ;
[ -f .env ] || ( [ -f .env.develop ] && cp .env.develop .env ) ;
watch -n 30 -t python main.py
"
dbproto:
image: redis:7.2-alpine
volumes:
db:
venv:
venv_proto:
~~~
<br>
<br>
<br>
# tunnel para desarrollo
Ver información en:
https://gitlab.com/m3f_usm/admin_transporte/backend/-/wikis/home
# archivo desarrollo: docker-compose.yml
~~~yml ~~~yml
version: '3' version: '3'
@ -74,7 +187,7 @@ services:
- 3000:3000 - 3000:3000
environment: environment:
- VITE_PORT=3000 - VITE_PORT=3000
- VITE_BACKEND=/api - VITE_BACKEND=http://localhost:4000/api
working_dir: /app working_dir: /app
command: sh -c " command: sh -c "
[ ! -d node_modules ] && npm install ; [ ! -d node_modules ] && npm install ;
@ -84,22 +197,24 @@ services:
backend: backend:
image: python:3.11-alpine image: python:3.11-alpine
depends_on:
- db
environment: environment:
- PORT=4000 - PORT=4000
- DBHOST=db - DBHOST=db
- DBPORT=5432 - DBPORT=5432
- DBNAME=database - DBNAME=transporte
- DBSCHEMA=desarrollo1 - DBSCHEMA=public
- DBUSER=postgres - DBUSER=postgres
- DBPASS=password - DBPASS=password
- DB_REDIS_HOST=dbproto - DB_REDIS_HOST=dbproto
- DB_REDIS_PORT=6379 - DB_REDIS_PORT=6379
- SECRET_JWT="kf6Jc!f30Z!1k1N0#!%#" - SECRET_JWT="kf6Jc!f30Z!1k1N0#!%#"
volumes:
- ./backend:/app
- venv:/root/venv
ports: ports:
- 4000:4000 - 4000:4000
volumes:
- ./transporte:/app
- venv:/root/venv
working_dir: /app working_dir: /app
command: sh -c " command: sh -c "
[ -d /root/venv/bin ] || ( \ [ -d /root/venv/bin ] || ( \
@ -117,31 +232,43 @@ services:
python project/manage.py runserver 0.0.0.0:$$PORT python project/manage.py runserver 0.0.0.0:$$PORT
" "
extra_hosts: extra_hosts:
- dbproto:<IP_TUNNEL> - db:<direccion ip de tu computador>
db:
#image: postgis/postgis:14-3.4-alpine
image: postgres:14-alpine-geometry
volumes:
- db:/var/lib/postgresql/data
- ./backups:/backups
#- ./backend/docs/database/01_create_tables.sql:/docker-entrypoint-initdb.d/01_create_tables.sql
ports:
- 5436:5432
environment:
POSTGRES_PASSWORD: password
POSTGRES_DB: database
PGDATA: /var/lib/postgresql/data/pgdata
adminer:
image: adminer
environment:
ADMINER_DEFAULT_SERVER: db
ADMINER_DEFAULT_USER: postgres
ADMINER_DEFAULT_PASSWORD: password
ADMINER_DESIGN: lucas-sandery
volumes: volumes:
db:
venv: venv:
~~~ ~~~
# Script para levantar aplicacion python sin docker
## file: start.sh
~~~bash
#!/bin/sh
cd /app
# si no existe directorio de ambiente, se crea
if [ ! -d /root/venv ]; then
python -m venv /root/venv
. /root/venv/bin/activate
pip install -r requirements.txt
fi
# activar ambiente con dependencias
. /root/venv/bin/activate
# si no existe un proyecto inicial, lo crea
if [ ! -d /app/project ]; then
django-admin startproject project
fi
# iniciar servidor con puerto 8000
python /app/project/manage.py runserver 0.0.0.0:8000
~~~
# Extraer models de base de datos
~~~bash
python manage.py inspectdb > api/models.py
~~~