diff options
author | Ben Pfaff <blp@ovn.org> | 2017-12-31 21:15:58 -0800 |
---|---|---|
committer | Ben Pfaff <blp@ovn.org> | 2018-03-24 12:04:53 -0700 |
commit | 1b1d2e6daa563cc91f974ffdc082fb3a8b424801 (patch) | |
tree | 9cc5df01b7af35962d5f40d0ffd8882fb277e047 /ovsdb/TODO.rst | |
parent | 53178986d7fc86bcfc2f297b547a97ee71a21bb7 (diff) | |
download | openvswitch-1b1d2e6daa563cc91f974ffdc082fb3a8b424801.tar.gz |
ovsdb: Introduce experimental support for clustered databases.
This commit adds support for OVSDB clustering via Raft. Please read
ovsdb(7) for information on how to set up a clustered database. It is
simple and boils down to running "ovsdb-tool create-cluster" on one server
and "ovsdb-tool join-cluster" on each of the others and then starting
ovsdb-server in the usual way on all of them.
One you have a clustered database, you configure ovn-controller and
ovn-northd to use it by pointing them to all of the servers, e.g. where
previously you might have said "tcp:1.2.3.4" was the database server,
now you say that it is "tcp:1.2.3.4,tcp:5.6.7.8,tcp:9.10.11.12".
This also adds support for database clustering to ovs-sandbox.
Acked-by: Justin Pettit <jpettit@ovn.org>
Tested-by: aginwala <aginwala@asu.edu>
Signed-off-by: Ben Pfaff <blp@ovn.org>
Diffstat (limited to 'ovsdb/TODO.rst')
-rw-r--r-- | ovsdb/TODO.rst | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/ovsdb/TODO.rst b/ovsdb/TODO.rst new file mode 100644 index 000000000..3bd4e761c --- /dev/null +++ b/ovsdb/TODO.rst @@ -0,0 +1,63 @@ +.. + Licensed under the Apache License, Version 2.0 (the "License"); you may + not use this file except in compliance with the License. You may obtain + a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + License for the specific language governing permissions and limitations + under the License. + + Convention for heading levels in Open vSwitch documentation: + + ======= Heading 0 (reserved for the title in a document) + ------- Heading 1 + ~~~~~~~ Heading 2 + +++++++ Heading 3 + ''''''' Heading 4 + + Avoid deeper levels because they do not render well. + +=========================== +OVSDB Clustering To-do List +=========================== + +* Ephemeral columns. + +* Unit test snapshotting. + +* Locks. + +* Investigate 100% CPU for long-running triggers + +* Tons of unit tests. + +* Increase exponential backoff cap. Introduce randomization. + +* Include index with monitor update? + +* Back off when transaction fails to commit? Definitely back off until + the eid changes for prereq failures + +* Testing with replication. + +* Handling bad transactions in read_db(). (Kill the database?) + +* Documentation: + + * ACID (and CAP?) explanation. + + * Upgrading OVN to a clustered database + + * Installing OVN with a clustered database + + * Overall diagram explaining the cluster and ovsdb protocol pieces + +* Future work: + + * File format with diff support. + + * Future work: DNS or directory support |