Skip to content

Commit

Permalink
Updated requirements alongside with dockerfile comments and migration…
Browse files Browse the repository at this point in the history
…s bash script
  • Loading branch information
kshitijrajsharma committed Oct 3, 2023
1 parent 95b3b5b commit 08f3402
Show file tree
Hide file tree
Showing 7 changed files with 79 additions and 50 deletions.
10 changes: 7 additions & 3 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,11 @@ frontend/node_modules
frontend/.pnp
frontend/.pnp.js

#standard
.env
**/.vscode/**
postgres-data/

# testing
frontend/coverage
postgres-data/*
Expand All @@ -28,7 +33,7 @@ frontend/package-lock*

frontend/.env

# for
# for backend
backend/static
backend/api_static
backend/env
Expand All @@ -40,8 +45,7 @@ backend/media
backend/data/*
backend/log/*
backend/training/*
trainings/*
backend/.env
backend/config.txt
backend/postgres-data
**/.vscode/**
postgres-data/
44 changes: 25 additions & 19 deletions backend/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,32 +1,38 @@
# Use a specific base image with GPU support
FROM tensorflow/tensorflow:2.9.2-gpu

RUN apt-get update && apt-get install -y python3-opencv
RUN add-apt-repository ppa:ubuntugis/ppa && apt-get update
RUN apt-get update
RUN apt-get install -y gdal-bin
RUN apt-get install -y libgdal-dev
# Update package lists and install necessary dependencies in a single step
RUN apt-get update && \
apt-get install -y python3-opencv gdal-bin libgdal-dev && \
add-apt-repository ppa:ubuntugis/ppa && \
apt-get update && \
rm -rf /var/lib/apt/lists/*

# Set environment variables for GDAL
ENV CPLUS_INCLUDE_PATH=/usr/include/gdal
ENV C_INCLUDE_PATH=/usr/include/gdal

#install numpy before gdal
# Install specific version of NumPy
RUN pip install numpy==1.23.5

# pip install dependencies.
RUN pip install --global-option=build_ext --global-option="-I/usr/include/gdal" GDAL==`gdal-config --version`

COPY docker/ramp/docker-requirements.txt docker-requirements.txt
RUN pip install -r docker-requirements.txt
# Install GDAL with specified options
RUN pip install --global-option=build_ext --global-option="-I/usr/include/gdal" GDAL==$(gdal-config --version)

# pip install solaris -- try with tmp-free build
COPY docker/ramp/solaris /tmp/solaris
RUN pip install /tmp/solaris --use-feature=in-tree-build
# Copy and install Python requirements
COPY docker/ramp/docker-requirements.txt /tmp/docker-requirements.txt
RUN pip install -r /tmp/docker-requirements.txt

RUN pip install scikit-fmm --use-feature=in-tree-build
# Upgrade setuptools
RUN pip install --upgrade setuptools

RUN pip install setuptools --upgrade
COPY requirements.txt /tmp/requirements.txt
RUN pip install -r /tmp/requirements.txt

COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
# Install solaris and scikit-fmm packages
COPY docker/ramp/solaris /tmp/solaris
RUN pip install /tmp/solaris --use-feature=in-tree-build && \
pip install scikit-fmm --use-feature=in-tree-build

# Set working directory and copy the application code
WORKDIR /app
COPY . /app
COPY . /app
45 changes: 26 additions & 19 deletions backend/Dockerfile_CPU
Original file line number Diff line number Diff line change
@@ -1,32 +1,39 @@
# Use a specific base image with the desired TensorFlow version
FROM tensorflow/tensorflow:2.9.2

RUN apt-get update && apt-get install -y python3-opencv
RUN add-apt-repository ppa:ubuntugis/ppa && apt-get update
RUN apt-get update
RUN apt-get install -y gdal-bin
RUN apt-get install -y libgdal-dev
# Update package lists and install necessary dependencies in a single step
RUN apt-get update && \
apt-get install -y software-properties-common python3-opencv && \
add-apt-repository ppa:ubuntugis/ppa && \
apt-get update && \
apt-get install -y gdal-bin libgdal-dev && \
rm -rf /var/lib/apt/lists/*

# Set environment variables for GDAL
ENV CPLUS_INCLUDE_PATH=/usr/include/gdal
ENV C_INCLUDE_PATH=/usr/include/gdal

#install numpy before gdal
# Install specific version of NumPy
RUN pip install numpy==1.23.5

# pip install dependencies.
RUN pip install --global-option=build_ext --global-option="-I/usr/include/gdal" GDAL==`gdal-config --version`

COPY docker/ramp/docker-requirements.txt docker-requirements.txt
RUN pip install -r docker-requirements.txt
# Install GDAL with specified options
RUN pip install --global-option=build_ext --global-option="-I/usr/include/gdal" GDAL==$(gdal-config --version)

# pip install solaris -- try with tmp-free build
COPY docker/ramp/solaris /tmp/solaris
RUN pip install /tmp/solaris --use-feature=in-tree-build
# Copy and install Python requirements
COPY docker/ramp/docker-requirements.txt /tmp/docker-requirements.txt
RUN pip install -r /tmp/docker-requirements.txt

RUN pip install scikit-fmm --use-feature=in-tree-build
# Upgrade setuptools
RUN pip install --upgrade setuptools

RUN pip install setuptools --upgrade
COPY requirements.txt /tmp/requirements.txt
RUN pip install -r /tmp/requirements.txt

COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
# Install solaris and scikit-fmm packages
COPY docker/ramp/solaris /tmp/solaris
RUN pip install /tmp/solaris --use-feature=in-tree-build && \
pip install scikit-fmm --use-feature=in-tree-build

# Set working directory and copy the application code
WORKDIR /app
COPY . /app
COPY . /app
2 changes: 1 addition & 1 deletion backend/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ django_celery_results==2.4.0
flower==1.2.0
validators==0.20.0
gpxpy==1.5.0
hot-fair-utilities
hot-fair-utilities==1.2.2
geojson2osm==0.0.1
osmconflator
orthogonalizer
4 changes: 2 additions & 2 deletions docker-compose-cpu.yml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ services:
backend-api:
build:
context: ./backend
dockerfile: Dockerfile
dockerfile: Dockerfile_CPU
container_name: api
command: python manage.py runserver 0.0.0.0:8000

Expand All @@ -40,7 +40,7 @@ services:
backend-worker:
build:
context: ./backend
dockerfile: Dockerfile
dockerfile: Dockerfile_CPU
container_name: worker
command: celery -A aiproject worker --loglevel=INFO --concurrency=1

Expand Down
18 changes: 12 additions & 6 deletions docs/Docker-installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,11 @@ Docker Compose is created with redis , worker , postgis database , api and fron
3. Check your Graphics
fAIr works best with graphics card. It is highly recommended to use graphics card . It might not work with CPU only . Nvidia Graphics cards are tested
fAIr works best with graphics card. It is highly recommended to use graphics card . It might not work with CPU only (You can setup and test from bottom of this document). Nvidia Graphics cards are tested
You need to make sure you can see your graphics card details and can be accessed through docker by installing necessary drivers
By following command you can see your graphics and graphics driver details
By following command you can see your graphics and graphics driver details & nvidia container toolkit is installed More details [here](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/install-guide.html)
```
nvidia-smi
```
Expand Down Expand Up @@ -75,6 +75,7 @@ Docker Compose is created with redis , worker , postgis database , api and fron
6. Create Env variables
- Create a file ```.env``` in backend with [docker_sample_env](../backend/docker_sample_env) content
```
cd backend
cp docker_sample_env .env
```
- Fill out the details of ```OSM_CLIENT_ID``` &```OSM_CLIENT_SECRET``` in .env file and generate a unique key & paste it to ```OSM_SECRET_KEY``` (It can be random for dev setup)
Expand All @@ -83,6 +84,7 @@ Docker Compose is created with redis , worker , postgis database , api and fron
- Create ```.env``` in /frontend
```
cd frontend
cp .env_sample .env
```
You can leave it as it is for dev setup
Expand All @@ -99,13 +101,17 @@ Docker Compose is created with redis , worker , postgis database , api and fron
8. Run Migrations
See Running containers grab their ID and launch bash to make migrations (This is needed for the first time to set database)
Run directly bash script :
docker container ps
```
bash run_migrations.sh
```
OR
Grab Container ID & Open Bash
Grab API container & Open Bash
docker exec -it CONTAINER_ID bash
docker exec -it api bash
Once Bash is promoted hit following commands
Expand Down
6 changes: 6 additions & 0 deletions run_migrations.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/bin/bash

docker exec -it api bash -c "python manage.py makemigrations"
docker exec -it api bash -c "python manage.py makemigrations login"
docker exec -it api bash -c "python manage.py makemigrations core"
docker exec -it api bash -c "python manage.py migrate"

0 comments on commit 08f3402

Please sign in to comment.