Compare commits
4 Commits
f945eb462a
...
109e06a5d6
Author | SHA1 | Date | |
---|---|---|---|
109e06a5d6 | |||
2b844a899f | |||
d4b43b364a | |||
46eb1e0045 |
@ -1,3 +1,4 @@
|
|||||||
env
|
env
|
||||||
.git
|
.git
|
||||||
**/__pycache__
|
**/__pycache__
|
||||||
|
q
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,2 +1,3 @@
|
|||||||
env
|
env
|
||||||
**/__pycache__
|
**/__pycache__
|
||||||
|
q
|
||||||
|
@ -13,4 +13,4 @@ RUN apt update && apt install -y ffmpeg libsm6 libxext6
|
|||||||
COPY src .
|
COPY src .
|
||||||
COPY best.pt /best.pt
|
COPY best.pt /best.pt
|
||||||
|
|
||||||
CMD [ "gunicorn", "-b 0.0.0.0:80", "app:app" ]
|
CMD [ "gunicorn", "-b 0.0.0.0:80", "--workers", "1", "app:app" ]
|
||||||
|
@ -5,4 +5,4 @@ services:
|
|||||||
build: .
|
build: .
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
- 8759:8000
|
- 8759:80
|
||||||
|
19
index.html
19
index.html
@ -1,17 +1,29 @@
|
|||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<link rel="stylesheet" type="text/css" href="https://alv.cx/styles.css" />
|
||||||
|
<title>glass | alv.cx</title>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<h1>find glass in an image!</h1>
|
||||||
<img id="img" src="" />
|
<img id="img" src="" />
|
||||||
|
|
||||||
<p id="statusline">submit an image to get started!</p>
|
<p id="statusline">submit an image to get started!</p>
|
||||||
<form id="form" action="http://localhost:5000/submit" method="post">
|
<form id="form" action="http://localhost:8759/submit" method="post">
|
||||||
<input type="file" id="job" name="image" accept="image/png,image/jpeg" /><br>
|
<input type="file" id="job" name="image" accept="image/png,image/jpeg" /><br>
|
||||||
<button type="submit" id="submit">submit</button>
|
<button type="submit" id="submit">submit</button>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
<p> built with ❤ and adequate amounts of care by <a href="https://alv.cx">alv</a></p>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
const form = document.getElementById("form");
|
const form = document.getElementById("form");
|
||||||
const img = document.getElementById("img");
|
const img = document.getElementById("img");
|
||||||
const statusline = document.getElementById("statusline");
|
const statusline = document.getElementById("statusline");
|
||||||
|
|
||||||
async function handleSubmit(ev) {
|
async function handleSubmit(ev) {
|
||||||
|
statusline.innerHTML = "SUBMITTING"
|
||||||
ev.preventDefault();
|
ev.preventDefault();
|
||||||
const form = ev.currentTarget;
|
const form = ev.currentTarget;
|
||||||
const data = new FormData(form);
|
const data = new FormData(form);
|
||||||
@ -26,11 +38,11 @@
|
|||||||
console.log(id);
|
console.log(id);
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
const resp = await fetch('http://localhost:5000/state/' + id);
|
const resp = await fetch('http://localhost:8759/state/' + id);
|
||||||
const state = (await resp.json()).state;
|
const state = (await resp.json()).state;
|
||||||
statusline.innerHTML = state;
|
statusline.innerHTML = state;
|
||||||
if (state == "READY") {
|
if (state == "READY") {
|
||||||
img.src = 'http://localhost:5000/result/' + id
|
img.src = 'http://localhost:8759/result/' + id
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -38,3 +50,4 @@
|
|||||||
|
|
||||||
form.addEventListener('submit', handleSubmit)
|
form.addEventListener('submit', handleSubmit)
|
||||||
</script>
|
</script>
|
||||||
|
</body>
|
||||||
|
@ -6,6 +6,7 @@ contourpy==1.2.0
|
|||||||
cycler==0.12.1
|
cycler==0.12.1
|
||||||
filelock==3.9.0
|
filelock==3.9.0
|
||||||
Flask==3.0.0
|
Flask==3.0.0
|
||||||
|
Flask-Cors==4.0.0
|
||||||
fonttools==4.47.0
|
fonttools==4.47.0
|
||||||
fsspec==2023.4.0
|
fsspec==2023.4.0
|
||||||
gunicorn==21.2.0
|
gunicorn==21.2.0
|
||||||
|
14
src/app.py
14
src/app.py
@ -33,7 +33,8 @@ def process():
|
|||||||
print("created model")
|
print("created model")
|
||||||
last = 0
|
last = 0
|
||||||
while True:
|
while True:
|
||||||
if time.time() < last + 10:
|
# wait x seconds before processing another task
|
||||||
|
if time.time() < last + 2:
|
||||||
print("aa")
|
print("aa")
|
||||||
time.sleep(0.5)
|
time.sleep(0.5)
|
||||||
continue
|
continue
|
||||||
@ -43,7 +44,7 @@ def process():
|
|||||||
print("waiting for/getting job")
|
print("waiting for/getting job")
|
||||||
job = q.get()
|
job = q.get()
|
||||||
filepath = root.joinpath(job)
|
filepath = root.joinpath(job)
|
||||||
print("got job")
|
print("got job", flush=True)
|
||||||
state[job] = {
|
state[job] = {
|
||||||
'state': QUEUE_STATE_PROCESSING,
|
'state': QUEUE_STATE_PROCESSING,
|
||||||
}
|
}
|
||||||
@ -61,6 +62,12 @@ def process():
|
|||||||
|
|
||||||
filepath.unlink()
|
filepath.unlink()
|
||||||
|
|
||||||
|
last = time.time()
|
||||||
|
|
||||||
|
|
||||||
|
p = Thread(target=process)
|
||||||
|
p.start()
|
||||||
|
|
||||||
|
|
||||||
@app.route("/submit", methods=['POST'])
|
@app.route("/submit", methods=['POST'])
|
||||||
def render():
|
def render():
|
||||||
@ -84,7 +91,4 @@ def get_result(i):
|
|||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
p = Thread(target=process)
|
|
||||||
p.start()
|
|
||||||
app.run(debug=True)
|
app.run(debug=True)
|
||||||
p.join()
|
|
||||||
|
Loading…
Reference in New Issue
Block a user