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 /lib/ovsdb-session.c | |
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 'lib/ovsdb-session.c')
-rw-r--r-- | lib/ovsdb-session.c | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/lib/ovsdb-session.c b/lib/ovsdb-session.c new file mode 100644 index 000000000..a8cb90f22 --- /dev/null +++ b/lib/ovsdb-session.c @@ -0,0 +1,76 @@ +/* Copyright (c) 2017 Nicira, Inc. + * + * 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. + */ + +#include <config.h> +#include "ovsdb-session.h" +#include <stdbool.h> +#include <stddef.h> +#include <string.h> +#include "svec.h" +#include "util.h" +#include "uuid.h" + +static const char * +next_remote(const char *s) +{ + for (const char *delimiter = strchr(s, ','); delimiter; + delimiter = strchr(delimiter + 1, ',')) { + const char *p = delimiter + 1; + p += strspn(p, " \t"); + size_t n_letters = strspn(p, "abcdefghijklmnopqrstuvwxyz"); + if (n_letters && p[n_letters] == ':') { + return delimiter; + } + } + return NULL; +} + +/* Parses string 's' into comma-delimited substrings and adds each of them into + * 'remotes'. If one of the substrings is of the form "cid:<uuid>", fills + * '*cid' with the UUID (and omits it from 'remotes'), otherwise initializes + * '*cid' to UUID_ZERO. */ +void +ovsdb_session_parse_remote(const char *s, + struct svec *remotes, struct uuid *cid) +{ + *cid = UUID_ZERO; + for (;;) { + /* Skip white space. */ + s += strspn(s, " \t"); + if (*s == '\0') { + break; + } + + /* Find the start of the next remote */ + const char *delimiter = next_remote(s); + if (!delimiter) { + svec_add(remotes, s); + break; + } + svec_add_nocopy(remotes, xmemdup0(s, delimiter - s)); + s = delimiter + 1; + } + + size_t i; + for (i = 0; i < remotes->n; i++) { + const char *name = remotes->names[i]; + struct uuid uuid; + if (!strncmp(name, "cid:", 4) && uuid_from_string(&uuid, name + 4)) { + *cid = uuid; + svec_del(remotes, name); + break; + } + } +} |