On 12/27/2013 01:21 PM, Jeffrey Walton wrote:
I'm setting up another test installation. I'm working on Ubuntu with
Havana using 
http://docs.openstack.org/havana/install-guide/install/apt/content/.

According to the OpenStack Installation Guide, the example uses a
Controller with Keystone, Glance and Nova. Freat job on those
documents, btw. (See http://postimg.org/image/ct3i150qr/ for a screen
capture of the page with a logical diagram).

I want to move Keystone to its own virtual machine for segregation
(this will eventually be a security requirement). I also want to move
Nova to its own VM (in addition to one VM for a Swift node).

What are the minimum components required for the controller? Does that
leave Glance, MySQL and RabbitMQ? Can Glance be moved somewhere if
desired (or must it remain on the controller)?

Sorry about the basic question. I'm still working though examples to
see what works, what does not, and how I manage to break things ;)

Hi Jeffrey,

We actually originally started off segregating various OpenStack service endpoints into their own nodes -- Glance on one, Keystone on another, Nova/Cinder on another, etc.

We no longer do that; it just wasn't worth the effort, and it meant a whole bunch of wasted resources. There's no real reason to host anything other than Swift and the Neutron L3 and DHCP agents on separate VMs or nodes. All the other endpoints are stateless and can happily live on the same VM/node.

* nova-api-*
* nova-scheduler
* cinder-api
* cinder-scheduler
* keystone-*
* glance-*
* neutron-server
* openstack-dashboard
* apache/nginx/etc
* memcache

All of the above happily live together in a single VM/node, as they are all stateless [1] (other than memcache, but memcache just serves for caching purposes, not end-state).

You can then put your databases/MQ on another set of nodes, since those are the main things that contain state in the system. We personally use Percona XtraDB Cluster for MySQL and clustered RabbitMQ, but you are free to make whatever choices you want in that arena.

Finally, place the Neutron L3 and DHCP agents on a separate node/VM, as these services do manage state in the network namespaces, iptables and other utilities.

All the best,
-jay

[1] glance-api is only stateless if you are using a remote/distribute data store to back images (like Swift or Ceph). If you use local filesystem storage in Glance (not recommended), then glance-api is no longer stateless.

_______________________________________________
Mailing list: http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack
Post to     : openstack@lists.openstack.org
Unsubscribe : http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack

Reply via email to