Набор реплик MongoDB запускается на DESKTOP вместо localhost - PullRequest
0 голосов
/ 08 апреля 2020

Я хочу использовать транзакции с mon goose, поэтому я установил run-rs для тестирования на этапе разработки. В соответствии с подобными руководствами https://medium.com/cashpositive/the-hitchhikers-guide-to-mongodb-transactions-with-mongoose-5bf8a6e22033 run-rs запускает его на локальном хосте. Когда я запускаю run-rs -v 4.2.5 --keep --shell для запуска набора реплик через терминал, он говорит: «Запущен набор реплик на« mongodb: // DESKTOP-U9IDO6F: 27017, DESKTOP-U9IDO6F: 27018, DESKTOP-U9IDO6F: 27019? ReplicaSet = rs ». Почему он говорит DESKTOP для меня вместо localhost и как мне подключиться к нему в mon goose .connect ()?

В своем индексе я попробовал следующее. js:

const app = express();
const PORT = 27017;
const dbUri = 'mongodb://DESKTOP-U9IDO6F:27017,DESKTOP-U9IDO6F:27018,DESKTOP-U9IDO6F:27019?replicaSet=rs'

mongoose.Promise = global.Promise;
mongoose.connect(dbUri, {
    replicaSet: 'rs',
    useNewUrlParser: true,
    useUnifiedTopology: true
});

Также, как мне добавить имя базы данных?

ОБНОВЛЕНИЕ:

PS C:\Users\Workstation\project> npm start

> project@1.0.0 start C:\Users\Workstation\project
> nodemon ./index.js --exec babel-node -e js

[nodemon] 2.0.2
[nodemon] to restart at any time, enter `rs`
[nodemon] watching dir(s): *.*
[nodemon] watching extensions: js
[nodemon] starting `babel-node ./index.js`
Your server is running on Port 4000
(node:7436) UnhandledPromiseRejectionWarning: MongooseServerSelectionError: connect ECONNREFUSED 127.0.0.1:27018
    at new MongooseServerSelectionError (C:\Users\Workstation\project\node_modules\mongoose\lib\error\serverSelection.js:22:11)
    at NativeConnection.Connection.openUri (C:\Users\Workstation\ project\node_modules\mongoose\lib\connection.js:823:32)
    at Mongoose.connect (C:\Users\Workstation\ project\node_modules\mongoose\lib\index.js:333:15)
    at Object.<anonymous> (C:/Users/Workstation/project/index.js:22:10)
    at Module._compile (internal/modules/cjs/loader.js:936:30)
    at loader (C:\Users\Workstation\project\node_modules\babel-register\lib\node.js:144:5)
    at Object.require.extensions.<computed> [as .js] (C:\Users\Workstation\project\node_modules\babel-register\lib\node.js:154:7)
    at Module.load (internal/modules/cjs/loader.js:790:32)
    at Function.Module._load (internal/modules/cjs/loader.js:703:12)
    at Function.Module.runMain (internal/modules/cjs/loader.js:999:10)
    at Object.<anonymous> (C:\Users\Workstation\project\node_modules\babel-cli\lib\_babel-node.js:154:22)
    at Module._compile (internal/modules/cjs/loader.js:936:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:947:10)
    at Module.load (internal/modules/cjs/loader.js:790:32)
    at Function.Module._load (internal/modules/cjs/loader.js:703:12)
    at Function.Module.runMain (internal/modules/cjs/loader.js:999:10)
(node:7436) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
(node:7436) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

ОБНОВЛЕНИЕ Я принял ответ ниже, потому что строка для соединения работает, следовательно, оригинальный вопрос решен. Однако я переключился на Linux и теперь он работает без дальнейшей настройки. Кажется, на моей Windows машине не работали.

1 Ответ

0 голосов
/ 08 апреля 2020

заменить:

const dbUri = 'mongodb://DESKTOP-U9IDO6F:27017,DESKTOP-U9IDO6F:27018,DESKTOP-U9IDO6F:27019?replicaSet=rs'

на:

const dbUri = 'mongodb://localhost:27017,localhost,localhost:27019/databasenaeme'

Также необходимо вручную запустить mongoDb на этих портах. используйте ссылку для ссылки:

ссылка

...