mirror of https://gitee.com/bigwinds/arangodb
64 lines
2.2 KiB
JavaScript
64 lines
2.2 KiB
JavaScript
'use strict';
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief initialize a new database
|
|
// /
|
|
// / @file
|
|
// /
|
|
// / DISCLAIMER
|
|
// /
|
|
// / Copyright 2014 ArangoDB GmbH, Cologne, Germany
|
|
// /
|
|
// / 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.
|
|
// /
|
|
// / Copyright holder is ArangoDB GmbH, Cologne, Germany
|
|
// /
|
|
// / @author Dr. Frank Celler
|
|
// / @author Copyright 2014, ArangoDB GmbH, Cologne, Germany
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief initialize a new database
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
(function () {
|
|
var internal = require('internal');
|
|
|
|
// do not overwrite arguments set from the calling C++ code
|
|
if (!global.UPGRADE_ARGS) {
|
|
global.UPGRADE_ARGS = {};
|
|
}
|
|
|
|
// merge in our arguments
|
|
global.UPGRADE_ARGS.isCluster = true;
|
|
global.UPGRADE_ARGS.isCoordinator = true;
|
|
global.UPGRADE_ARGS.isRelaunch = false;
|
|
|
|
// run the local upgrade-database script
|
|
var res = internal.loadStartup('server/bootstrap/local-database.js');
|
|
|
|
// Wait for synchronous replication to settle:
|
|
// We do not do this for performance reasons and because it should not
|
|
// be necessary. We leave the code here in case we need it again.
|
|
//var db = require('internal').db;
|
|
//var dbName = db._name();
|
|
//if (dbName !== '_system') {
|
|
// // for _system we run this already at bootstrap
|
|
// var colls = db._collections();
|
|
// colls = colls.filter(c => c.name()[0] === '_');
|
|
// require('@arangodb/cluster').waitForSyncRepl(dbName, colls);
|
|
//}
|
|
|
|
return res;
|
|
}());
|