- 存储: mysql, redis
- python 版本: 3.8 <= python <= 3.11
- 启动 mysql 服务, redis 服务
mysql一定要设置sql_mode, root进入mysql执行:
set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
- 创建数据库 cmdb
- 拉取代码
git clone https://github.com/veops/cmdb.git
cd cmdb
cp cmdb-api/settings.example.py cmdb-api/settings.py
设置 cmdb-api/settings.py 里的 database
-
安装库
- 后端:
cd cmdb-api && pipenv run pipenv install && cd ..
- 前端:
cd cmdb-ui && yarn install && cd ..
- 后端:
-
可以将 docs/cmdb.sql 导入到数据库里,登录用户和密码分别是:demo/123456
-
创建数据库表: 进入cmdb-api目录执行
pipenv run flask db-setup && pipenv run flask common-check-new-columns && pipenv run flask cmdb-init-cache
-
启动服务
-
后端: 进入cmdb-api目录执行
pipenv run flask run -h 0.0.0.0
-
前端: 进入cmdb-ui目录执行
yarn run serve
-
worker:
- 进入cmdb-api目录执行
pipenv run celery -A celery_worker.celery worker -E -Q one_cmdb_async --autoscale=5,2 --logfile=one_cmdb_async.log -D
- 进入cmdb-api目录执行
pipenv run celery -A celery_worker.celery worker -E -Q acl_async --autoscale=2,1 --logfile=one_acl_async.log -D
- 进入cmdb-api目录执行
-
浏览器打开: http://127.0.0.1:8000
- 如果是非本机访问, 要修改cmdb-ui/.env里VUE_APP_API_BASE_URL里的 IP 地址为后端服务的 ip 地址
-