generated from sueszli/python-template
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmakefile
164 lines (138 loc) · 4.84 KB
/
makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
# --------------------------------------------------------------- venv
.PHONY: init # initialize venv
init:
# get requirements.in
pip install pip --upgrade
pip install pipreqs
rm -rf requirements.txt requirements.in
pipreqs . --mode no-pin --encoding utf-8
mv requirements.txt requirements.in
# get requirements.txt
pip install pip-tools
pip-compile requirements.in -o requirements.txt -vvv
# install everything in venv
rm -rf .venv
python3 -m venv .venv
@bash -c "source .venv/bin/activate && pip install -r requirements.txt"
.PHONY: lock # freeze pip and lock reqs
lock:
@bash -c "source .venv/bin/activate && pip freeze > requirements.in"
pip-compile requirements.in -o requirements.txt
# --------------------------------------------------------------- nohup
.PHONY: monitor # create nohup with restart on failure
monitor:
@if [ "$(filepath)" = "" ]; then echo "missing 'path' argument"; exit 1; fi
@bash -c '\
monitor() { \
while true; do \
if ! ps -p $$(cat "monitor-process.pid" 2>/dev/null) > /dev/null 2>&1; then \
echo "$$(date): process not running or died, (re)starting..." >> monitor.log; \
nohup ./.venv/bin/python3 "$(filepath)" > "monitor-process.log" 2>&1 & \
echo $$! > "monitor-process.pid"; \
echo "$$(date): started process with PID $$(cat monitor-process.pid)" >> monitor.log; \
fi; \
sleep 5; \
done; \
}; \
monitor >> "monitor.log" 2>&1 & \
echo $$! > "monitor.pid"; \
echo "$$(date): monitor started" >> "monitor.log"; \
'
.PHONY: monitor-tail # tail log of nohup process
monitor-tail:
while true; do clear; tail -n 100 monitor-process.log; sleep 0.1; done
# watch -n 0.1 "tail -n 100 monitor-process.log"
.PHONY: monitor-kill # kill nohup process
monitor-kill:
-kill -9 $$(cat monitor.pid)
rm -rf monitor.pid
rm -rf monitor.log
-kill -9 $$(cat monitor-process.pid)
rm -rf monitor-process.pid
rm -rf monitor-process.log
# --------------------------------------------------------------- conda
.PHONY: conda-get-yaml # convert requirements.txt to env.yaml file (idempotent)
conda-get-yaml:
conda update -n base -c defaults conda
# conda config --env --set subdir osx-64
# conda config --env --set subdir osx-arm64
conda config --set auto_activate_base false
conda info
@bash -c '\
source $$(conda info --base)/etc/profile.d/conda.sh; conda activate base; \
conda create --yes --name con python=3.11; \
source $$(conda info --base)/etc/profile.d/conda.sh; conda activate con; \
\
pip install -r requirements.txt; \
\
conda env export --no-builds | grep -v "prefix:" > env.yml; \
source $$(conda info --base)/etc/profile.d/conda.sh; conda deactivate; \
conda remove --yes --name con --all; \
'
.PHONY: conda-install # install conda from env.yaml file
conda-install:
@bash -c '\
source $$(conda info --base)/etc/profile.d/conda.sh; conda activate base; \
conda env create --file env.yml; \
'
.PHONY: conda-clean # wipe conda environment
conda-clean:
# conda clean --all
@bash -c '\
source $$(conda info --base)/etc/profile.d/conda.sh; conda activate base; \
conda remove --yes --name con --all; \
source $$(conda info --base)/etc/profile.d/conda.sh; conda deactivate; \
'
# --------------------------------------------------------------- docker
.PHONY: docker-install # run docker container
docker-install:
@echo "to exec into docker container, run: 'docker exec -it main /bin/bash'"
docker-compose up --detach
.PHONY: docker-clean # wipe everything in docker
docker-clean:
docker-compose down
-docker stop $$(docker ps -a -q)
-docker rm $$(docker ps -a -q)
-docker rmi $$(docker images -q)
yes | docker container prune
yes | docker image prune
yes | docker volume prune
yes | docker network prune
yes | docker system prune
docker ps --all
docker images
docker system df
docker volume ls
docker network ls
# --------------------------------------------------------------- utils
.PHONY: fmt # format codebase
fmt:
# pip install isort
# pip install ruff
# pip install autoflake
isort .
autoflake --remove-all-unused-imports --recursive --in-place .
ruff format --config line-length=500 .
.PHONY: sec # check for vulns
sec:
pip install bandit
pip install safety
bandit -r .
safety check --full-report
.PHONY: up # pull and push changes
up:
git pull
git add .
if [ -z "$(msg)" ]; then git commit -m "up"; else git commit -m "$(msg)"; fi
git push
.PHONY: help # generate help message
help:
@echo "Usage: make [target]\n"
@grep '^.PHONY: .* #' Makefile | sed 's/\.PHONY: \(.*\) # \(.*\)/\1 \2/' | expand -t20
# quick setup:
# python3 -m venv .venv && source .venv/bin/activate
# pip install -r requirements.txt
# pip install git+https://github.com/openai/CLIP.git
# pip install open-clip-torch
# python -m spacy download en_core_web_sm
# pip install clip diffusers matplotlib numpy opencv_python opencv_python_headless Pillow Requests spacy torch transformers accelerate