summaryrefslogtreecommitdiff
path: root/ovsdb/TODO.rst
diff options
context:
space:
mode:
authorBen Pfaff <blp@ovn.org>2017-12-31 21:15:58 -0800
committerBen Pfaff <blp@ovn.org>2018-03-24 12:04:53 -0700
commit1b1d2e6daa563cc91f974ffdc082fb3a8b424801 (patch)
tree9cc5df01b7af35962d5f40d0ffd8882fb277e047 /ovsdb/TODO.rst
parent53178986d7fc86bcfc2f297b547a97ee71a21bb7 (diff)
downloadopenvswitch-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.rst63
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