You need to sign in or sign up before continuing.
未验证 提交 24135c4b 编写于 作者: P Peter Pan 提交者: GitHub

add demo docker (#766)

* bump to 2.0.1

* update demo

* bump fe to 2.0.0

* update demo

* add ping url
上级 35e1252f
FROM nikolaik/python-nodejs:python3.8-nodejs14 AS builder
WORKDIR /home/visualdl
COPY . .
RUN apt-get update && apt-get -y --no-install-recommends install cmake && rm -rf /var/lib/apt/lists/*
RUN ["pip", "install", "--disable-pip-version-check", "-r", "requirements.txt"]
RUN ["python", "setup.py", "bdist_wheel"]
FROM python:3-alpine as opencv FROM python:3-alpine as opencv
WORKDIR /opt WORKDIR /opt
...@@ -109,24 +119,14 @@ RUN cp -p $(find `python -c "from distutils.sysconfig import get_python_lib; pri ...@@ -109,24 +119,14 @@ RUN cp -p $(find `python -c "from distutils.sysconfig import get_python_lib; pri
RUN tar zcf packages.tar.gz -C $(python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())") . RUN tar zcf packages.tar.gz -C $(python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())") .
FROM nikolaik/python-nodejs:python3.8-nodejs14 AS builder
WORKDIR /home/visualdl
COPY . .
RUN apt-get update && apt-get -y --no-install-recommends install cmake && rm -rf /var/lib/apt/lists/*
RUN ["pip", "install", "-r", "requirements.txt"]
RUN ["python", "setup.py", "bdist_wheel"]
FROM python:3-alpine FROM python:3-alpine
WORKDIR /home/visualdl WORKDIR /home/visualdl
COPY --from=builder /home/visualdl/dist/* dist/
COPY --from=opencv /usr/local/include/opencv* /usr/local/include/ COPY --from=opencv /usr/local/include/opencv* /usr/local/include/
COPY --from=opencv /usr/local/lib/* /usr/local/lib/ COPY --from=opencv /usr/local/lib/* /usr/local/lib/
COPY --from=opencv /usr/local/lib64/* /usr/local/lib64/ COPY --from=opencv /usr/local/lib64/* /usr/local/lib64/
COPY --from=opencv /opt/packages.tar.gz . COPY --from=opencv /opt/packages.tar.gz .
COPY --from=builder /home/visualdl/dist/* dist/
COPY requirements.txt . COPY requirements.txt .
RUN tar zxf packages.tar.gz -C $(python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())") RUN tar zxf packages.tar.gz -C $(python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())")
...@@ -136,4 +136,4 @@ RUN sed -i -e '/opencv-python/d' requirements.txt ...@@ -136,4 +136,4 @@ RUN sed -i -e '/opencv-python/d' requirements.txt
RUN ["pip", "install", "--disable-pip-version-check", "-r", "requirements.txt"] RUN ["pip", "install", "--disable-pip-version-check", "-r", "requirements.txt"]
RUN ["pip", "install", "--disable-pip-version-check", "--no-deps", "--find-links=dist", "visualdl"] RUN ["pip", "install", "--disable-pip-version-check", "--no-deps", "--find-links=dist", "visualdl"]
ENTRYPOINT ["visualdl", "--logdir", "/home/visualdl/log"] ENTRYPOINT ["visualdl", "--logdir", "/home/visualdl/log", "--host", "0.0.0.0"]
FROM nikolaik/python-nodejs:python3.8-nodejs14 AS builder
WORKDIR /home/visualdl
COPY . .
RUN apt-get update && apt-get -y --no-install-recommends install cmake libgl1-mesa-glx && rm -rf /var/lib/apt/lists/*
RUN ["pip", "install", "--disable-pip-version-check", "-r", "requirements.txt"]
RUN ["python", "setup.py", "bdist_wheel"]
RUN ["pip", "install", "--disable-pip-version-check", "--find-links=dist", "visualdl"]
WORKDIR frontend
ENV SCOPE server
ENV PUBLIC_PATH /paddle/visualdl/demo
ENV API_URL /paddle/visualdl/demo/api
RUN ["./scripts/install.sh"]
RUN ["./scripts/build.sh"]
FROM node:14-alpine
WORKDIR /home/visualdl
COPY --from=builder /home/visualdl/frontend/ ./
ENV NODE_ENV production
ENV PUBLIC_PATH /paddle/visualdl/demo
ENV API_URL /paddle/visualdl/demo/api
ENV PING_URL /ping
ENV DEMO true
ENV HOST 0.0.0.0
ENV PORT 8999
RUN ["yarn", "install", "--frozen-lockfile"]
ENTRYPOINT ["yarn", "workspace" , "@visualdl/server", "start"]
version: '3.8'
services:
demo:
build:
context: .
dockerfile: Dockerfile.demo
ports:
- "8999:8999"
environment:
PING_URL: /ping
PORT: 8999
...@@ -6,7 +6,7 @@ services: ...@@ -6,7 +6,7 @@ services:
- "8000" - "8000"
volumes: volumes:
- "log:/home/visualdl/log" - "log:/home/visualdl/log"
command: ["--api-only", "--host=0.0.0.0", "--port=8000"] command: ["--api-only", "--port=8000"]
frontend: frontend:
build: ./frontend build: ./frontend
depends_on: depends_on:
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
"packages": [ "packages": [
"packages/*" "packages/*"
], ],
"version": "2.0.0-beta.50", "version": "2.0.0",
"npmClient": "yarn", "npmClient": "yarn",
"useWorkspaces": true, "useWorkspaces": true,
"command": { "command": {
......
{ {
"name": "@visualdl/cli", "name": "@visualdl/cli",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
"dist" "dist"
], ],
"dependencies": { "dependencies": {
"@visualdl/server": "2.0.0-beta.50", "@visualdl/server": "2.0.0",
"open": "7.1.0", "open": "7.1.0",
"ora": "4.0.5", "ora": "4.0.5",
"pm2": "4.4.0", "pm2": "4.4.0",
......
{ {
"name": "@visualdl/core", "name": "@visualdl/core",
"version": "2.0.0-beta.50", "version": "2.0.0",
"title": "VisualDL", "title": "VisualDL",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
...@@ -34,9 +34,9 @@ ...@@ -34,9 +34,9 @@
}, },
"dependencies": { "dependencies": {
"@tippyjs/react": "4.1.0", "@tippyjs/react": "4.1.0",
"@visualdl/i18n": "2.0.0-beta.50", "@visualdl/i18n": "2.0.0",
"@visualdl/netron": "2.0.0-beta.50", "@visualdl/netron": "2.0.0",
"@visualdl/wasm": "2.0.0-beta.50", "@visualdl/wasm": "2.0.0",
"bignumber.js": "9.0.0", "bignumber.js": "9.0.0",
"d3-format": "1.4.4", "d3-format": "1.4.4",
"echarts": "4.8.0", "echarts": "4.8.0",
...@@ -80,7 +80,7 @@ ...@@ -80,7 +80,7 @@
"@types/react-dom": "16.9.8", "@types/react-dom": "16.9.8",
"@types/react-rangeslider": "2.2.3", "@types/react-rangeslider": "2.2.3",
"@types/styled-components": "5.1.2", "@types/styled-components": "5.1.2",
"@visualdl/mock": "2.0.0-beta.50", "@visualdl/mock": "2.0.0",
"babel-plugin-emotion": "10.0.33", "babel-plugin-emotion": "10.0.33",
"babel-plugin-styled-components": "1.11.1", "babel-plugin-styled-components": "1.11.1",
"babel-plugin-typescript-to-proptypes": "1.4.0", "babel-plugin-typescript-to-proptypes": "1.4.0",
......
import type {Worker} from './types'; import type {Data, Worker} from './types';
interface Audio { interface Audio {
step: number; step: number;
...@@ -11,11 +11,11 @@ const worker: Worker = async io => { ...@@ -11,11 +11,11 @@ const worker: Worker = async io => {
return; return;
} }
const tagsMap = await io.save<Record<string, string[]>>('/audio/tags'); const {runs, tags} = await io.save<Data>('/audio/tags');
for (const [run, tags] of Object.entries(tagsMap)) { for (const [index, run] of runs.entries()) {
for (const tag of tags) { for (const tag of tags[index]) {
const list = await io.save<Audio[]>('/audio/list', {run, tag}); const list = (await io.save<Audio[]>('/audio/list', {run, tag})) ?? [];
for (const [index, audio] of Object.entries(list)) { for (const [index, audio] of list.entries()) {
await io.saveBinary('/audio/audio', {run, tag, index, ts: audio.wallTime}); await io.saveBinary('/audio/audio', {run, tag, index, ts: audio.wallTime});
} }
} }
......
import type {Worker} from './types'; import type {Data, Worker} from './types';
const worker: Worker = async io => { const worker: Worker = async io => {
const components = await io.getData<string[]>('/components'); const components = await io.getData<string[]>('/components');
...@@ -6,10 +6,10 @@ const worker: Worker = async io => { ...@@ -6,10 +6,10 @@ const worker: Worker = async io => {
return; return;
} }
const tagsMap = await io.save<Record<string, string[]>>('/histogram/tags'); const {runs, tags} = await io.save<Data>('/histogram/tags');
const q = []; const q = [];
for (const [run, tags] of Object.entries(tagsMap)) { for (const [index, run] of runs.entries()) {
for (const tag of tags) { for (const tag of tags[index]) {
q.push(io.save('/histogram/list', {run, tag})); q.push(io.save('/histogram/list', {run, tag}));
} }
} }
......
import type {Worker} from './types'; import type {Data, Worker} from './types';
interface Image { interface Image {
step: number; step: number;
...@@ -11,11 +11,11 @@ const worker: Worker = async io => { ...@@ -11,11 +11,11 @@ const worker: Worker = async io => {
return; return;
} }
const tagsMap = await io.save<Record<string, string[]>>('/image/tags'); const {runs, tags} = await io.save<Data>('/image/tags');
for (const [run, tags] of Object.entries(tagsMap)) { for (const [index, run] of runs.entries()) {
for (const tag of tags) { for (const tag of tags[index]) {
const list = await io.save<Image[]>('/image/list', {run, tag}); const list = (await io.save<Image[]>('/image/list', {run, tag})) ?? [];
for (const [index, image] of Object.entries(list)) { for (const [index, image] of list.entries()) {
await io.saveBinary('/image/image', {run, tag, index, ts: image.wallTime}); await io.saveBinary('/image/image', {run, tag, index, ts: image.wallTime});
} }
} }
......
...@@ -29,7 +29,7 @@ async function start() { ...@@ -29,7 +29,7 @@ async function start() {
'--logdir', '--logdir',
'.', '.',
'--model', '--model',
'./graph/__model__', './__model__',
'--host', '--host',
host, host,
'--port', '--port',
......
import type {Worker} from './types'; import type {Data, Worker} from './types';
const worker: Worker = async io => { const worker: Worker = async io => {
const components = await io.getData<string[]>('/components'); const components = await io.getData<string[]>('/components');
...@@ -6,10 +6,10 @@ const worker: Worker = async io => { ...@@ -6,10 +6,10 @@ const worker: Worker = async io => {
return; return;
} }
const tagsMap = await io.save<Record<string, string[]>>('/pr-curve/tags'); const {runs, tags} = await io.save<Data>('/pr-curve/tags');
for (const [run, tags] of Object.entries(tagsMap)) { for (const [index, run] of runs.entries()) {
await io.save('/pr-curve/steps', {run}); await io.save('/pr-curve/steps', {run});
for (const tag of tags) { for (const tag of tags[index]) {
await io.save('/pr-curve/list', {run, tag}); await io.save('/pr-curve/list', {run, tag});
} }
} }
......
import type {Worker} from './types'; import type {Data, Worker} from './types';
const worker: Worker = async io => { const worker: Worker = async io => {
const components = await io.getData<string[]>('/components'); const components = await io.getData<string[]>('/components');
...@@ -6,10 +6,10 @@ const worker: Worker = async io => { ...@@ -6,10 +6,10 @@ const worker: Worker = async io => {
return; return;
} }
const tagsMap = await io.save<Record<string, string[]>>('/scalar/tags'); const {runs, tags} = await io.save<Data>('/scalar/tags');
const q = []; const q = [];
for (const [run, tags] of Object.entries(tagsMap)) { for (const [index, run] of runs.entries()) {
for (const tag of tags) { for (const tag of tags[index]) {
q.push(io.save('/scalar/list', {run, tag})); q.push(io.save('/scalar/list', {run, tag}));
} }
} }
......
import type IO from './io'; import type IO from './io';
export type Worker = (io: IO) => Promise<void>; export type Worker = (io: IO) => Promise<void>;
export type Data = {
runs: string[];
tags: string[][];
};
{ {
"name": "@visualdl/demo", "name": "@visualdl/demo",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
......
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
"moduleResolution": "node", "moduleResolution": "node",
"esModuleInterop": true, "esModuleInterop": true,
"resolveJsonModule": true, "resolveJsonModule": true,
"downlevelIteration": true,
"declaration": true, "declaration": true,
"skipLibCheck": true, "skipLibCheck": true,
"outDir": "dist" "outDir": "dist"
......
{ {
"name": "@visualdl/i18n", "name": "@visualdl/i18n",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
......
{ {
"name": "@visualdl/mock", "name": "@visualdl/mock",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
......
{ {
"name": "@visualdl/netron", "name": "@visualdl/netron",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
......
...@@ -63,6 +63,18 @@ async function start() { ...@@ -63,6 +63,18 @@ async function start() {
}); });
} }
if (
process.env.PING_URL &&
process.env.PING_URL !== '/' &&
process.env.PING_URL !== publicPath &&
process.env.PING_URL.startsWith('/')
) {
server.get(process.env.PING_URL, (_req, res) => {
res.type('text/plain');
res.status(200).send('OK!');
});
}
const {default: nextI18Next} = await import('@visualdl/core/utils/i18n'); const {default: nextI18Next} = await import('@visualdl/core/utils/i18n');
await nextI18Next.initPromise; await nextI18Next.initPromise;
server.use(nextI18NextMiddleware(nextI18Next)); server.use(nextI18NextMiddleware(nextI18Next));
......
{ {
"name": "@visualdl/server", "name": "@visualdl/server",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
...@@ -37,9 +37,9 @@ ...@@ -37,9 +37,9 @@
"ecosystem.config.d.ts" "ecosystem.config.d.ts"
], ],
"dependencies": { "dependencies": {
"@visualdl/core": "2.0.0-beta.50", "@visualdl/core": "2.0.0",
"@visualdl/demo": "2.0.0-beta.50", "@visualdl/demo": "2.0.0",
"@visualdl/i18n": "2.0.0-beta.50", "@visualdl/i18n": "2.0.0",
"express": "4.17.1", "express": "4.17.1",
"http-proxy-middleware": "1.0.5", "http-proxy-middleware": "1.0.5",
"next": "9.4.4", "next": "9.4.4",
...@@ -51,7 +51,7 @@ ...@@ -51,7 +51,7 @@
"@types/shelljs": "0.8.8", "@types/shelljs": "0.8.8",
"@types/webpack": "4.41.21", "@types/webpack": "4.41.21",
"@types/webpack-dev-middleware": "3.7.1", "@types/webpack-dev-middleware": "3.7.1",
"@visualdl/mock": "2.0.0-beta.50", "@visualdl/mock": "2.0.0",
"cross-env": "7.0.2", "cross-env": "7.0.2",
"nodemon": "2.0.4", "nodemon": "2.0.4",
"shelljs": "0.8.4", "shelljs": "0.8.4",
......
{ {
"name": "@visualdl/serverless", "name": "@visualdl/serverless",
"version": "2.0.0-beta.50", "version": "2.0.0",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
"visualdl", "visualdl",
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
"devDependencies": { "devDependencies": {
"@types/node": "14.0.27", "@types/node": "14.0.27",
"@types/rimraf": "3.0.0", "@types/rimraf": "3.0.0",
"@visualdl/core": "2.0.0-beta.50", "@visualdl/core": "2.0.0",
"cross-env": "7.0.2", "cross-env": "7.0.2",
"rimraf": "3.0.2", "rimraf": "3.0.2",
"ts-node": "8.10.2", "ts-node": "8.10.2",
......
{ {
"name": "@visualdl/wasm", "name": "@visualdl/wasm",
"version": "2.0.0-beta.50", "version": "2.0.0",
"title": "VisualDL", "title": "VisualDL",
"description": "A platform to visualize the deep learning process and result.", "description": "A platform to visualize the deep learning process and result.",
"keywords": [ "keywords": [
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册