This commit is contained in:
pycook 2019-11-11 09:20:07 +08:00
commit 66e93e73af
17 changed files with 79 additions and 80 deletions

View File

@ -19,7 +19,7 @@ redis = "==3.2.1"
Flask-Migrate = "==2.5.2" Flask-Migrate = "==2.5.2"
# Deployment # Deployment
gevent = "==1.4.0" gevent = "==1.4.0"
gunicorn = ">=19.1.1" gunicorn = "==19.5.0"
supervisor = "==4.0.3" supervisor = "==4.0.3"
# Auth # Auth
Flask-Login = "==0.4.1" Flask-Login = "==0.4.1"

View File

@ -56,9 +56,11 @@ cp api/settings.py.example api/settings.py
- 浏览器打开: [http://127.0.0.1:8000](http://127.0.0.1:8000) - 浏览器打开: [http://127.0.0.1:8000](http://127.0.0.1:8000)
- 如果是非本机访问, 要修改**ui/.env****VUE_APP_API_BASE_URL**里的IP地址为后端服务的ip地址 - 如果是非本机访问, 要修改**ui/.env****VUE_APP_API_BASE_URL**里的IP地址为后端服务的ip地址
docker运行 docker 一键构建和运行
---- ----
进入主目录 - 进入主目录首次镜像的构建需要**10分钟**左右视网络情况而定
``` ```
docker-compose up -d docker-compose up -d
``` ```
- 浏览器打开: [http://localhost:8000](http://localhost:8000)

View File

@ -15,4 +15,3 @@ RUN yum install -y epel-release && yum clean all\
&& pip install --no-cache-dir -r docs/requirements.txt && pip install --no-cache-dir -r docs/requirements.txt
CMD ["bash", "-c", "cp api/settings.py.example api/settings.py && sed -i 's#{user}:{password}@127.0.0.1:3306/{db}#:@127.0.0.1:3306/cmdb#g' api/settings.py && flask run"] CMD ["bash", "-c", "cp api/settings.py.example api/settings.py && sed -i 's#{user}:{password}@127.0.0.1:3306/{db}#:@127.0.0.1:3306/cmdb#g' api/settings.py && flask run"]

View File

@ -1,5 +1,8 @@
# -*- coding:utf-8 -*- # -*- coding:utf-8 -*-
from __future__ import unicode_literals
import datetime import datetime
import six import six
@ -37,8 +40,8 @@ type_map = {
'deserialize': { 'deserialize': {
Attribute.INT: string2int, Attribute.INT: string2int,
Attribute.FLOAT: float, Attribute.FLOAT: float,
Attribute.TEXT: escape, Attribute.TEXT: lambda x: escape(x).encode('utf-8').decode('utf-8'),
Attribute.TIME: escape, Attribute.TIME: lambda x: escape(x).encode('utf-8').decode('utf-8'),
Attribute.DATETIME: str2datetime, Attribute.DATETIME: str2datetime,
Attribute.DATE: str2datetime, Attribute.DATE: str2datetime,
}, },

View File

@ -1,6 +1,8 @@
# -*- coding:utf-8 -*- # -*- coding:utf-8 -*-
from __future__ import unicode_literals
import markupsafe import markupsafe
from flask import abort from flask import abort

View File

@ -1,24 +1,6 @@
version: '3.4' version: '3.4'
services: services:
cmdb-ui:
build:
context: ./ui
dockerfile: Dockerfile
image: cmdb-ui:0.1
container_name: cmdb-ui
command: ["sh", "-c", "sed -i 's#http://127.0.0.1:5000##g' .env && yarn run serve"]
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:5000"]
interval: 5s
timeout: 5s
retries: 100
start_period: 10s
depends_on:
- cmdb-api
networks:
- new
cmdb-api: cmdb-api:
build: build:
context: . context: .
@ -67,17 +49,16 @@ services:
aliases: aliases:
- redis - redis
cmdb-proxy: cmdb-ui:
image: nginx:latest build:
container_name: cmdb-proxy context: ./ui
dockerfile: Dockerfile
image: cmdb-ui:0.1
container_name: cmdb-ui
depends_on: depends_on:
- cmdb-api - cmdb-api
- cmdb-ui
volumes:
- "$PWD/conf.d:/etc/nginx/conf.d"
environment: environment:
CMDB_API_HOST: cmdb-api:5000 CMDB_API_HOST: cmdb-api:5000
CMDB_UI_HOST: cmdb-ui:8000
NGINX_PORT: 80 NGINX_PORT: 80
volumes: volumes:
- ./docs/nginx.cmdb.conf.example:/etc/nginx/conf.d/nginx.cmdb.conf.example - ./docs/nginx.cmdb.conf.example:/etc/nginx/conf.d/nginx.cmdb.conf.example
@ -85,14 +66,14 @@ services:
- /bin/bash - /bin/bash
- -c - -c
- | - |
envsubst '$$CMDB_API_HOST $$CMDB_UI_HOST $$NGINX_PORT' < /etc/nginx/conf.d/nginx.cmdb.conf.example > /etc/nginx/conf.d/cmdb.conf envsubst '$$CMDB_API_HOST $$NGINX_PORT' < /etc/nginx/conf.d/nginx.cmdb.conf.example > /etc/nginx/conf.d/cmdb.conf
rm -f /etc/nginx/conf.d/default.conf rm -f /etc/nginx/conf.d/default.conf
curl http://cmdb-api:5000/api/v0.1/ci/flush
nginx -g 'daemon off;' nginx -g 'daemon off;'
curl http://localhost/api/v0.1/ci/flush
networks: networks:
- new - new
ports: ports:
- "80:80" - "8000:80"
volumes: volumes:
db-data: db-data:

View File

@ -25,9 +25,12 @@ server {
application/xml application/xml
application/rss+xml application/rss+xml
image/svg+xml; image/svg+xml;
root /etc/nginx/html;
location / { location / {
proxy_pass http://${CMDB_UI_HOST}; root /etc/nginx/html;
proxy_set_header Host $host; index index.html;
try_files $uri $uri/ /index.html;
} }
location /api { location /api {
proxy_pass http://${CMDB_API_HOST}; proxy_pass http://${CMDB_API_HOST};
@ -41,4 +44,11 @@ server {
proxy_set_header Upgrade $http_upgrade; proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade"; proxy_set_header Connection "upgrade";
} }
location ~* \.(css|js)$ {
access_log off;
add_header Pragma public;
add_header Cache-Control "public, max-age=7776000";
#add_header Cache-Control "public,no-cache, max-age=0";
add_header X-Asset "yes";
}
} }

View File

@ -14,7 +14,7 @@ redis ==3.2.1
Flask-Migrate == 2.5.2 Flask-Migrate == 2.5.2
# Deployment # Deployment
gevent ==1.4.0 gevent ==1.4.0
gunicorn>=19.1.1 gunicorn == 19.5.0
supervisor ==4.0.3 supervisor ==4.0.3
# Auth # Auth
Flask-Login ==0.4.1 Flask-Login ==0.4.1

View File

@ -1,13 +1,18 @@
FROM alpine:3.9 FROM node:alpine as builder
LABEL description="cmdb-ui" LABEL description="cmdb-ui"
RUN mkdir -p /data/apps/cmdb-ui/logs
COPY . /data/apps/cmdb-ui COPY . /data/apps/cmdb-ui
WORKDIR /data/apps/cmdb-ui WORKDIR /data/apps/cmdb-ui
RUN apk add yarn && yarn install RUN sed -i 's#http://127.0.0.1:5000##g' .env && yarn install && yarn build
CMD ["sh", "-c", "yarn run serve"]
FROM nginx:latest
RUN apt-get update && apt-get install -y curl && apt-get clean
RUN mkdir /etc/nginx/html
COPY --from=builder /data/apps/cmdb-ui/dist /etc/nginx/html/

View File

@ -51,7 +51,6 @@ export function logout() {
} }
}) })
} }
} }
/** /**

View File

@ -1,7 +1,7 @@
// eslint-disable-next-line // eslint-disable-next-line
import store from '@/store' import store from '@/store'
import { UserLayout, BasicLayout, RouteView, PageView } from '@/layouts' import { UserLayout, BasicLayout, RouteView } from '@/layouts'
import { getPreference } from '@/api/cmdb/preference' import { getPreference } from '@/api/cmdb/preference'
const cmdbRouter = [ const cmdbRouter = [

View File

@ -7,7 +7,7 @@ import 'nprogress/nprogress.css' // progress bar style
import notification from 'ant-design-vue/es/notification' import notification from 'ant-design-vue/es/notification'
import { setDocumentTitle, domTitle } from '@/utils/domUtil' import { setDocumentTitle, domTitle } from '@/utils/domUtil'
import config from '@/config/defaultSettings' import config from '@/config/defaultSettings'
import { ACCESS_TOKEN } from './store/mutation-types'; import { ACCESS_TOKEN } from './store/mutation-types'
NProgress.configure({ showSpinner: false }) // NProgress Configuration NProgress.configure({ showSpinner: false }) // NProgress Configuration
@ -44,15 +44,13 @@ router.beforeEach((to, from, next) => {
store.dispatch('Logout') store.dispatch('Logout')
}, 3000) }, 3000)
}) })
} else if (to.path === '/user/login' && !config.useSSO && store.getters.roles.length !== 0) { } else if (to.path === '/user/login' && !config.useSSO && store.getters.roles.length !== 0) {
next({ path: '/' }) next({ path: '/' })
NProgress.done() NProgress.done()
} else if (!config.useSSO && !Vue.ls.get(ACCESS_TOKEN) && to.path !== "/user/login") { } else if (!config.useSSO && !Vue.ls.get(ACCESS_TOKEN) && to.path !== '/user/login') {
next({ path: '/user/login', query: { redirect: to.fullPath } }) next({ path: '/user/login', query: { redirect: to.fullPath } })
NProgress.done() NProgress.done()
} } else {
else {
next() next()
} }
}) })

View File

@ -322,9 +322,9 @@ export default {
this.loadTip = '正在下载 ...' this.loadTip = '正在下载 ...'
const promises = this.selectedRowKeys.map(ciId => { const promises = this.selectedRowKeys.map(ciId => {
return searchCI(`q=_id:${ciId}`).then(res => { return searchCI(`q=_id:${ciId}`).then(res => {
let ciMap = {} const ciMap = {}
Object.keys(res.result[0]).forEach(k => { Object.keys(res.result[0]).forEach(k => {
if (!["ci_type", "_id", "ci_type_alias", "_type"].includes(k)) { if (!['ci_type', '_id', 'ci_type_alias', '_type'].includes(k)) {
ciMap[k] = res.result[0][k] ciMap[k] = res.result[0][k]
} }
}) })

View File

@ -130,7 +130,7 @@ export default {
this.form.validateFields((err, values) => { this.form.validateFields((err, values) => {
Object.keys(values).forEach(k => { Object.keys(values).forEach(k => {
if (typeof values[k] === 'object') { if (typeof values[k] === 'object') {
values[k] = values[k].format("YYYY-MM-DD HH:mm:ss") values[k] = values[k].format('YYYY-MM-DD HH:mm:ss')
} }
}) })
if (!err) { if (!err) {