Skip to content
/ cmdb Public
forked from veops/cmdb

CMDB: As far as possible to achieve more universal configuration and management of IT resources, demo: http://121.42.12.46:8000

License

Notifications You must be signed in to change notification settings

Gentoo-zh/cmdb

 
 

Repository files navigation

CMDB

As far as possible to achieve more universal configuration and management of IT resources

License UI API

English / 中文

DEMO ONLINE

  • Preview online: CMDB
    • username: demo
    • password: 123456

ATTENTION: branch master may be unstable as the result of continued development, please pull code from releases


Overview

The CMDB is a universal project that can define and manage almost all IT resources, 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: model instance data that users can subscribe
    • Tree view: the model is hierarchical by field, shown in a tree diagram, and users can subscribe
    • Relational view: relationships between models, shown in a tree diagram, are configurable by the administrator
  • 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

Environment and dependency

  • database: mysql
  • cache: redis
  • python: python2.7, >=python3.6

Install

  • Start mysql, redis

  • Create mysql database: cmdb

  • Pull code

    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

      • if not run localhost: please change ip address(VUE_APP_API_BASE_URL) in config file cmdb-ui/.env into your backend ip address

Install by Makefile

  • Start mysql,redis

  • Create mysql database: cmdb

  • Pull code

    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

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-feature)
  5. Create new Pull Request

DEMO

resource view

resource view

tree view

tree view

relationship view

relationship view

user subscription

user subscription

define relationship view

define relationship view


Welcome to join us through QQ group(336164978)

QQgroup

About

CMDB: As far as possible to achieve more universal configuration and management of IT resources, demo: http://121.42.12.46:8000

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%