CMDB

As far as possible to achieve more universal g and maintenance of IT resources
[![License](https://img.shields.io/badge/License-GPLv2-brightgreen)](https://github.com/pycook/cmdb/blob/master/LICENSE) [![UI](https://img.shields.io/badge/UI-Ant%20Design%20Pro%20Vue-brightgreen)](https://github.com/sendya/ant-design-pro-vue) [![API](https://img.shields.io/badge/API-Flask-brightgreen)](https://github.com/pallets/flask)
[English](README.md) / [中文](README_cn.md) ## Overview CMDB is a universal project that can define and manage almost all IT resource, even every resource as long as you want to, which treat all IT resources as resource objects. objects has both attributes and relationship. CMDB's main distinguishing features as compared to other resource systems are: - define attributes of resource objects dynamically,you don't need to define all the attributes at the beginning. - define relationship of resource objects dynamically and simply, even you can draw the relationship through the web. - three view:resource view,tree view,relational view - authority management ## Install There are various ways of installing CMDB. ### Install by Docker - prepare: install docker and docker-compose - in directory cmdb ``` docker-compose up -d ``` - view: [http://127.0.0.1:8000](http://127.0.0.1:8000) ### Environment and dependency - database: mysql - cache: redis - python: python2.7, >=python3.6 ### install - start mysql, redis - create mysql database: cmdb - pull code ```bash git clone https://github.com/pycook/cmdb.git cd cmdb cp cmdb-api/settings.py.example cmdb-api/settings.py ``` **set database in config file cmdb-api/settings.py** - install library - backend: ```cd cmdb-api && pipenv run pipenv install && cd ..``` - frontend: ```cd cmdb-ui && yarn install && cd ..``` - create tables of cmdb database: in **cmdb-api** directory: ```pipenv run flask db-setup && pipenv run flask init-cache``` - suggest step: (default: user:demo,password:123456) ``` source docs/cmdb.sql``` - start service - backend: in **cmdb-api** directory: ```pipenv run flask run -h 0.0.0.0``` - frontend: in **cmdb-ui** directory: ```yarn run serve``` - worker: in**cmdb-api**directory: ```pipenv run celery worker -A celery_worker.celery -E -Q cmdb_async --concurrency=1``` - homepage: [http://127.0.0.1:8000](http://127.0.0.1:8000) - if not run localhost: please change ip address(**VUE_APP_API_BASE_URL**) in config file **cmdb-ui/.env** into backend your ip ### Install by Makefile - start mysql,redis - create mysql database: cmdb - pull code ```bash git clone https://github.com/pycook/cmdb.git cd cmdb cp cmdb-api/settings.py.example cmdb-api/settings.py ``` **set database in config file cmdb-api/settings.py** - in cmdb directory,start in order as follows: - enviroment: ```make env``` - start API: ```make api``` - start UI: ```make ui``` - start worker: ```make worker``` ## DEMO ##### resource view ![resource view](https://raw.githubusercontent.com/pycook/cmdb/master/cmdb-ui/public/cmdb-ci.jpeg) ##### tree view ![tree view](https://raw.githubusercontent.com/pycook/cmdb/master/cmdb-ui/public/cmdb-tree.jpeg) ##### relationship view ![relationship view](https://raw.githubusercontent.com/pycook/cmdb/master/cmdb-ui/public/cmdb-relation.jpeg) ##### user subscription ![user subscription](https://raw.githubusercontent.com/pycook/cmdb/master/cmdb-ui/public/cmdb-preference.jpeg) ##### define relationship view ![define relationship view](https://raw.githubusercontent.com/pycook/cmdb/master/cmdb-ui/public/cmdb-relation-define.jpeg) ## DEMO ONLINE - preview online: [CMDB](http://121.42.12.46:8000) - username: demo - password: 123456 ## ATTENTION > **ATTENTION**: branch `master` may be unstable as the result of continued development, please pull code from [releases](https://github.com/pycook/cmdb/releases) ---- _**welcome to join us through QQ group(336164978)**_ ![QQgroup](cmdb-ui/public/qr_code.jpg)