RETIRED, Congress
Go to file
Eric K 88b0ef4df2 Remove cloudfoundry from congress.conf instructions
Because the instructions do not include installing cloudfoundry,
including it in congress.conf causes error.

Change-Id: I4837b427a56cb1d371cbc44e6f6c0825b060019c
2016-03-21 22:54:28 -07:00
bin Fix relative import path in source tree 2014-07-08 16:25:36 -07:00
congress Merge "Make persistent_insert_rule error on IncompleteSchemaException" 2016-03-21 18:15:59 +00:00
congress_tempest_tests Enable congress HA tests 2016-03-18 10:20:56 +05:30
contrib Add option to specify --kind while creating policy 2016-01-11 16:17:26 +05:30
devstack Fix use of devstack-based branch for congress 2016-03-09 09:22:47 +01:00
doc/source Update congress documentation 2016-03-18 13:26:48 +05:30
etc Moved CORS middleware configuration into oslo-config-generator 2016-03-14 10:55:49 -07:00
examples Remove support for policy snapshot file 2015-04-20 16:49:56 -07:00
scripts Add a script to start and monitor children processes 2015-10-23 14:28:44 -07:00
thirdparty Fix spelling typos and one underline 2016-02-03 21:20:05 +05:30
tools Adds test directory for new architecture 2016-01-28 17:50:09 -08:00
.coveragerc Change ignore-errors to ignore_errors 2015-09-21 14:25:32 +00:00
.gitignore Update .gitignore with .idea 2015-05-24 13:41:12 -07:00
.gitreview Update .gitreview file to reflect repo rename 2015-04-18 00:37:35 +00:00
.mailmap Restructure to follow OpenStack cookiecutter template 2014-01-07 15:31:36 -08:00
.testr.conf.new Adds test directory for new architecture 2016-01-28 17:50:09 -08:00
.testr.conf.old Adds test directory for new architecture 2016-01-28 17:50:09 -08:00
CONTRIBUTING.rst Fix few typos 2015-09-19 00:04:34 +05:30
HACKING.rst Fix few typos 2015-09-19 00:04:34 +05:30
LICENSE Restructure to follow OpenStack cookiecutter template 2014-01-07 15:31:36 -08:00
Makefile Fix Makefile for new congress/datalog directory 2015-03-02 10:36:17 -08:00
README.rst Remove cloudfoundry from congress.conf instructions 2016-03-21 22:54:28 -07:00
babel.cfg Restructure to follow OpenStack cookiecutter template 2014-01-07 15:31:36 -08:00
future-features.txt Fixed some misspellings 2015-07-01 10:36:17 +08:00
openstack-common.conf Clean unused oslo incubator files 2015-07-07 09:10:06 +08:00
requirements.txt Use tempest.lib instead of tempest_lib 2016-03-11 06:44:26 +00:00
run_tests.sh Use lockutils-wrapper 2015-07-07 09:10:06 +08:00
setup.cfg Moved CORS middleware configuration into oslo-config-generator 2016-03-14 10:55:49 -07:00
setup.py Updated from global requirements 2015-09-17 12:11:25 +00:00
test-requirements.txt Add oslosphinx to sphinx conf.py 2016-03-09 12:54:40 +05:30
thirdparty-requirements.txt Fix spelling typos and one underline 2016-02-03 21:20:05 +05:30
tox.ini Adds test directory for new architecture 2016-01-28 17:50:09 -08:00

README.rst

Congress Introduction and Installation

1. What is Congress

Congress is an open policy framework for the cloud. With Congress, a cloud operator can declare, monitor, enforce, and audit "policy" in a heterogeneous cloud environment. Congress gets inputs from a cloud's various cloud services; for example in OpenStack, Congress fetches information about VMs from Nova, and network state from Neutron, etc. Congress then feeds input data from those services into its policy engine where Congress verifies that the cloud's actual state abides by the cloud operator's policies. Congress is designed to work with any policy and any cloud service.

2. Why is Policy Important

The cloud is a collection of autonomous services that constantly change the state of the cloud, and it can be challenging for the cloud operator to know whether the cloud is even configured correctly. For example,

  • The services are often independent from each other and do not support transactional consistency across services, so a cloud management system can change one service (create a VM) without also making a necessary change to another service (attach the VM to a network). This can lead to incorrect behavior.
  • Other times, we have seen a cloud operator allocate cloud resources and then forget to clean them up when the resources are no longer in use, effectively leaving garbage around the system and wasting resources.
  • The desired cloud state can also change over time. For example, if a security vulnerability is discovered in Linux version X, then all machines with version X that were ok in the past are now in an undesirable state. A version number policy would detect all the machines in that undesirable state. This is a trivial example, but the more complex the policy, the more helpful a policy system becomes.

Congress's job is to help people manage that plethora of state across all cloud services with a succinct policy language.

3. Using Congress

Setting up Congress involves writing policies and configuring Congress to fetch input data from the cloud services. The cloud operator writes policy in the Congress policy language, which receives input from the cloud services in the form of tables. The language itself resembles datalog. For more detail about the policy language and data format see Policy <policy>.

To add a service as an input data source, the cloud operator configures a Congress "driver", and the driver queries the service. Congress already has drivers for several types of service, but if a cloud operator needs to use an unsupported service, she can write a new driver without much effort and probably contribute the driver to the Congress project so that no one else needs to write the same driver.

Finally, when using Congress, the cloud operator must choose what Congress should do with the policy it has been given:

  • monitoring: detect violations of policy and provide a list of those violations
  • proactive enforcement: prevent violations before they happen (functionality that requires other services to consult with Congress before making changes)
  • reactive enforcement: correct violations after they happen (a manual process that Congress tries to simplify)

In the future, Congress will also help the cloud operator audit policy (analyze the history of policy and policy violations).

Congress is free software and is licensed with Apache.

  • Free software: Apache license

4. Installing Congress

There are 2 ways to install Congress.

  • As part of devstack. Get Congress running alongside other OpenStack services like Nova and Neutron, all on a single machine. This is a great way to try out Congress for the first time.
  • Standalone. Get Congress running all by itself. Congress works well with other OpenStack services but can be deployed without them.

4.1 Devstack-install

For integrating congress with DevStack:

  1. Download DevStack:

    $ git clone https://git.openstack.org/openstack-dev/devstack.git
    $ cd devstack
  2. Configure devstack to use Congress and any other service you want. To do that, modify the local.conf file (inside the devstack directory). Here is what our file looks like:

    [[local|localrc]]
    
    enable_plugin congress http://git.openstack.org/openstack/congress
    enable_plugin ceilometer http://git.openstack.org/openstack/ceilometer
    enable_service h-eng h-api h-api-cfn h-api-cw
    disable_service n-net
    enable_service neutron
    enable_service q-svc
    enable_service q-agt
    enable_service q-dhcp
    enable_service q-l3
    enable_service q-meta
    enable_service s-proxy s-object s-container s-account
  3. Run stack.sh. The default configuration expects the passwords to be 'password' without the quotes:

    $ ./stack.sh

4.2 Standalone-install

Install the following software, if you haven't already.

Clone Congress:

$ git clone https://github.com/openstack/congress.git
$ cd congress

Install requirements:

$ sudo pip install .

Install Source code:

$ sudo python setup.py install

Configure congress:

(Assume you put config files in /etc/congress)

$ sudo mkdir -p /etc/congress
$ sudo mkdir -p /etc/congress/snapshot
$ sudo cp etc/api-paste.ini /etc/congress
$ sudo cp etc/policy.json /etc/congress
$ sudo touch /etc/congress/congress.conf

Add drivers in /etc/congress/congress.conf [DEFAULT] section:

drivers = congress.datasources.neutronv2_driver.NeutronV2Driver,congress.datasources.glancev2_driver.GlanceV2Driver,congress.datasources.nova_driver.NovaDriver,congress.datasources.keystone_driver.KeystoneDriver,congress.datasources.ceilometer_driver.CeilometerDriver,congress.datasources.cinder_driver.CinderDriver,congress.datasources.swift_driver.SwiftDriver,congress.datasources.plexxi_driver.PlexxiDriver,congress.datasources.vCenter_driver.VCenterDriver,congress.datasources.murano_driver.MuranoDriver,congress.datasources.ironic_driver.IronicDriver

Modify [keystone_authtoken] and [database] according to your environment.

For setting congress with "noauth":
  Add the following line to [DEFAULT] section in /etc/congress/congress.conf

  auth_strategy = noauth

  Also, might want to delete/comment [keystone_authtoken] section in
  /etc/congress/congress.conf

If you need a sample of congress.conf, please follow README-congress.conf.txt

Create database:

$ mysql -u root -p
$ mysql> CREATE DATABASE congress;
$ mysql> GRANT ALL PRIVILEGES ON congress.* TO 'congress'@'localhost' \
         IDENTIFIED BY 'CONGRESS_DBPASS';
$ mysql> GRANT ALL PRIVILEGES ON congress.* TO 'congress'@'%' \
         IDENTIFIED BY 'CONGRESS_DBPASS';

(Configure congress.conf with db information)

Push down schema
$ sudo congress-db-manage --config-file /etc/congress/congress.conf upgrade head

Setup congress accounts:

(You should change parameters according to your environment)

$ ADMIN_ROLE=$(openstack role list | awk "/ admin / { print \$2 }")
$ SERVICE_TENANT=$(openstack project list | awk "/ admin / { print \$2 }")
$ CONGRESS_USER=$(openstack user create --password password --project admin \
  --email "congress@example.com" congress | awk "/ id / {print \$4 }")
$ openstack role add $ADMIN_ROLE --user $CONGRESS_USER --project \
  $SERVICE_TENANT
$ CONGRESS_SERVICE=$(openstack service create congress --type "policy" \
  --description "Congress Service" | awk "/ congress / { print \$2 }")
$ openstack endpoint create $CONGRESS_SERVICE \
  --region RegionOne \
  --publicurl http://127.0.0.1:1789/ \
  --adminurl http://127.0.0.1:1789/ \
  --internalurl http://127.0.0.1:1789/

Configure datasource drivers:

First make sure you have congress client (project python-congressclient) installed.
Run this command for every service that congress will poll for data:

$ openstack congress datasource create $SERVICE "$SERVICE" \
  --config username=$OS_USERNAME \
  --config tenant_name=$OS_TENANT_NAME \
  --config password=$OS_PASSWORD \
  --config auth_url=http://$SERVICE_HOST:5000/v2.0

Please note that the service name $SERVICE should match the id of the datasource driver,
e.g. "neutronv2" for Neutron and "glancev2" for Glance. $OS_USERNAME, $OS_TENANT_NAME,
$OS_PASSWORD and $SERVICE_HOST are used to configure the related datasource driver
so that congress knows how to talk with the service.

Start congress:

$ sudo /usr/local/bin/congress-server --debug

Install test harness:

$ pip install 'tox<1.7'

Run unit tests:

$ tox -epy27

Read the HTML documentation:

$ make docs
Open doc/html/index.html in a browser