RETIRED, Fuel UI
Go to file
Andrey Danin af23627ec2 [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
bin agent fix and installation test 2012-09-20 17:56:21 +04:00
binaries@b4f1e9a2f5 wsgilog added & node status fixed 2012-09-14 12:27:03 +00:00
bootstrap [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
cookbooks [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
devops Increase network range 2012-09-26 17:14:46 +04:00
gnupg Added Make rule to build Nailgun installation iso 2012-06-13 11:44:40 +04:00
iso Fixing mirror path for iso images on golden mirror 2012-10-02 15:23:47 +04:00
mcollective [mcollective] Some fixes in mcollective 2012-09-11 08:38:40 +00:00
nailgun [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
os Onsite mirror for binaries 2012-09-10 11:33:43 +00:00
packages/rpm Onsite mirror for binaries 2012-09-10 11:33:43 +00:00
scripts Bugfixing. 2012-09-24 14:14:14 +00:00
test Fix tests 2012-09-21 19:15:23 +04:00
vagrant/cookbooks wsgilog added & node status fixed 2012-09-14 12:27:03 +00:00
.gitignore [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
.gitmodules Removed cooks submodule 2012-09-27 14:10:50 +04:00
Makefile Removed reference to cooks module from Makefile. Fixes integr.test build. 2012-10-02 10:12:34 +04:00
README.md extended instructions for running webapp 2012-08-02 11:22:48 -07:00
Vagrantfile Vagrant: 1024 Mb of RAM for CentOS. Needed to run nova VMs. 2012-08-13 10:08:07 +04:00
config.mk [bootstrap] Add mcollective and net_probe plugin to bootstrap; set it to connect to master node. 2012-10-03 11:26:01 +00:00
requirements-deb.txt [bootstrap] Add MCollective to master-node. Minor fixes. 2012-10-03 11:26:01 +00:00
requirements-eggs.txt 1. Returned nose egg. 2012-09-25 15:34:01 +00:00
requirements-gems.txt Creating a mirror of required gems/eggs (requirements-eggs.txt/requirements-gems.txt) in specified directory. 2012-09-24 14:14:14 +00:00
requirements-rpm.txt [attribute_generation] All in one commit 2012-08-17 21:14:40 +04:00
rules.mk Fixed rule for .dir files 2012-06-20 19:03:39 +04:00

README.md

NAILGUN

How to run Nailgun app from fixtures

Install application dependencies (eggs):

    cd scripts/ci/
    sudo easy_install pip
    sudo chef-solo -c solo.rb -j solo.json
    cd -

Remove old DB:

    cd nailgun
    rm -f nailgun.sqlite

Sync DB:

    ./manage.py syncdb --noinput

Load data from fixtures:

    ./manage.py loaddata sample_environment

Run application:

    ./manage.py runserver

Access Web UI at http://localhost:8000/

Deploying virtual environment

Using vagrant:

Note: uncomment config.vm.forward_port 8000, 8000 in Vagrantfile for working with django webui.

For VM deployment run: vagrant up ubuntu_testbed

The working directory is /vagrant.

W/O vagrant:

Installing chef (source):

~$ echo "deb http://apt.opscode.com/ `lsb_release -cs`-0.10 main" | sudo tee /etc/apt/sources.list.d/opscode.list

~$ sudo mkdir -p /etc/apt/trusted.gpg.d

~$ gpg --keyserver keys.gnupg.net --recv-keys 83EF826A

~$ gpg --export packages@opscode.com | sudo tee /etc/apt/trusted.gpg.d/opscode-keyring.gpg > /dev/null

~$ sudo apt-get update && sudo apt-get install opscode-keyring

~$ sudo apt-get install chef

Installing dependencies

~$ cd scripts/ci && chef-solo -l debug -c solo.rb -j solo.json

Testing

Nailgun:

Unit tests: make test-unit or nailgun/run_tests.sh Integration tests: make test-integration

Layout

Makefile - the global product makefile
Vagrantfile - for the vagrant dev vms
bin/
    create_release - upload a release json file to nailgun (see e.g. scripts/ci/sample-release.json)
    deploy - invoked on a node to deploy; downloads and executes recipes
    install_cookbook - uploads cookbooks to nailgun admin API
binaries/ - submodule for binaries such as packages and ISO-files
bootstrap/ - creating a bootstrap image (aka crowbar sledgehammer) for nodes (initrd, configuration files, packages etc) It needed to be refactored to use clear make without calling additional shell scripts.
cookbooks/ - chef cookbooks to install Nailgun application
    agent/ - node agent. Sends ohai data to admin node.
    nailgun/ - nailgun server (not slave node!)
    others obvious
cooks/ - submodule with Cookbooks to be loaded in Nailgun app. OpenStack cookbooks will be here.
devops/ - Mirantis CI framework, used by integration tests (./test/integration/). Installed on the master, not slave.
gnupg/
iso/ - creating a main iso to install admin node
nailgun/ - server
    manage.py, run_tests.sh - django standard
    monitor.py - restart server when django conf files change
    nailgun/ - django app 
        apps: nailgun.api at api/, nailgun.webui (fully static) at /
        models: recipe, role, release, node, cluster
        tasks.py - django-celery tasks submitted from api/handlers.py: deploy cluster [sub: deploy node]
            MOST IMPORTANT TASK: deploy_cluster
                Create databags for nodes
                Provision node with Cobbler
                ssh node and call /opt/nailgun/bin/deploy
        api/ - nailgun.api django app; JSON API
            main entities in REST API: task, recipe/release/role, node, cluster
            
scripts/
    agent/ - development scripts to test agent cookbook
    ci/ - scripts for CI, sample-cook - cookbook for testing
test/ - integration tests [TODO figure out more]
vagrant/ - cookbooks for use by the vagrant vm
requirements-deb.txt - debian packages needed for Ubuntu slave node repository
requirements-rpm.txt - debian packages needed for CentOS slave node repository
rules.mk - it is just some make macroses