首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mongoosastic -{ [Error: No Living connections]消息:'No Living connections‘}

Mongoosastic -{ [Error: No Living connections]消息:'No Living connections‘}
EN

Stack Overflow用户
提问于 2015-11-23 18:40:42
回答 3查看 2.2K关注 0票数 4

我正在尝试使用mongoosastic进行搜索,但我一直收到'No Living connections‘错误和映射问题

下面是代码

代码语言:javascript
复制
var mongoose = require('mongoose');
var mongoosastic = require('mongoosastic');
var Schema = mongoose.Schema;


var JobSchema = Schema({
  category: { type: Schema.Types.ObjectId, ref: 'Category', es_indexed:true},
  title: { type: String, es_indexed:true },

});

JobSchema.plugin(mongoosastic);
module.exports = mongoose.model('Job', JobSchema);

routes.js

代码语言:javascript
复制
var Job = require('../models/job');

Job.createMapping(function(err, mapping) {
  if (err) {
    console.log('error creating mapping (you can safely ignore this)');
    console.log(err);
  } else {
    console.log('mapping created!');
    console.log(mapping);
  }
});

app.post('/search', function(req, res, next) {
    Job.search({query_string: {query: req.body.q}}, function(err, results) {
        if (err) return next(err);
        res.send(results);
    });
});

我一直收到这个错误,

有使用mongoosastic经验的人能告诉我,我如何解决这个问题吗?

EN

回答 3

Stack Overflow用户

发布于 2015-11-24 12:37:13

当将插件添加到你的JobSchema模型中时,你需要传递第二个关于如何连接到Elasticsearch的参数:

代码语言:javascript
复制
JobSchema.plugin(mongoosastic, {
  hosts: [
    'localhost:9200'
  ]
});

您还可以重用Elasticsearch客户端对象(如果已准备好)。

代码语言:javascript
复制
var esClient = new elasticsearch.Client({host: 'localhost:9200'});
JobSchema.plugin(mongoosastic, {
  esClient: esClient
})
票数 1
EN

Stack Overflow用户

发布于 2015-12-03 19:35:46

我也面临着同样的问题,但我现在用下面的方法解决了

非常简单:您必须在本地或其他任何地方安装elastic search

  1. Download elastic search http://www.elastic.co/downloads/elasticsearch
  2. Extract folder
  3. 从cmd或Treminal http://www.elastic.co/downloads/elasticsearch
  4. Extract文件夹转到文件夹,在文件夹中运行elastic search script
  5. ,默认情况下,在nodejs代码中,它将链接到localhost:9200,因此无需使用e123新elasticsearch.Client({host:‘localhost:9200’})e224,但是如果elastic search在其他位置删除了一些内容,则必须使用上面的e125客户端主机
票数 1
EN

Stack Overflow用户

发布于 2015-12-01 23:38:15

我认为你必须创建一个客户端,并将其传递到插件中,但使用ip地址对我来说是有效的。

代码语言:javascript
复制
// http://127.0.0.1:9200 == http://localhost:9200

var esClient = new elasticsearch.Client({host: 'http://127.0.0.1:9200'});
JobSchema.plugin(mongoosastic, {
    esClient: esClient
})

引用这个答案:https://stackoverflow.com/a/30204512/1146562

根据这个答案,您可以直接将host传递到插件中,而不必创建客户端。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33869013

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档