从v2.0开始,Elasticsearch默认情况下仅在localhost上侦听,但我想在localhost之外发出请求。
例如,允许这样的请求:
http://localhost:9200/
但这不是:
http://server_name:9200/
(从服务器外部,例如:同一LAN中的本地计算机)。
谢谢你的帮助。
从v2.0开始,Elasticsearch默认情况下仅在localhost上侦听,但我想在localhost之外发出请求。
例如,允许这样的请求:
http://localhost:9200/
但这不是:
http://server_name:9200/
(从服务器外部,例如:同一LAN中的本地计算机)。
谢谢你的帮助。
Answers:
在config/elasticsearch.yml
放
network.host: 0.0.0.0
/etc/elasticsearch/elasticsearch.yml
:与内容network.host: ["0.0.0.0"]
T_T
C:\ProgramData\Elastic\Elasticsearch\config
位置。如果要以编程方式连接到Elasticsearch,则可能需要transport.host: 0.0.0.0
在elasticsearch.yml
文件中进行设置。
默认情况下,http传输和内部elasticsearch传输仅侦听localhost。如果要从本地主机以外的主机访问Elasticsearch,请尝试在以下主机中添加以下配置config / elasticsearch.yml中。
transport.host: localhost
transport.tcp.port: 9300
http.port: 9200
network.host: 0.0.0.0
在此,network.host为0.0.0.0允许从网络内的任何主机进行访问。
elasticsearch.yml
文件中添加这些行之后,终于使它工作了
将config文件夹中的elasticsearch.yml文件重命名为elasticsearch.json并添加:
{
"network" : {
"host" : "10.0.0.4"
}
}
另一个选择是使用ES_JAVA_OPTS或作为elasticsearch命令的参数从外部提供设置,例如:
$ elasticsearch -Des.network.host=10.0.0.4
另一个选项是设置es.default。前缀而不是es。前缀,这意味着仅当未在配置文件中明确设置时才使用默认设置。
另一种选择是${...}
在配置文件中使用表示法,它将解析为环境设置,例如:
{
"network" : {
"host" : "${ES_NET_HOST}"
}
}
可以使用系统属性在外部设置配置文件的位置:
$ elasticsearch -Des.config=/path/to/config/file
有关更多信息,请访问https://www.elastic.co/guide/en/elasticsearch/reference/1.4/setup-configuration.html
elasticsearch.yml
为,elasticsearch.json
因为第一个是hmmm,YAML,第二个是JSON
??。
正如@arsent提到的,将该IP地址添加到配置文件中:
sudo nano /etc/elasticsearch/elasticsearch.yml
杰伊(Jay)还添加了一个要点-如果您使用的是防火墙,请记住添加一条规则,以允许到该端口的流量。
如果要允许主服务器通过http访问ES,请添加一条规则,仅允许从该特定地址访问ES。例如,假设您正在使用ufw,然后运行以下命令添加端口:
sudo ufw allow from xxx.xxx.xxx.xxx to any port zzzz
将xxx.xxx.xxx.xxx替换为您的主服务器IP地址,并将zzzz替换为您在中配置的端口 config/elasticsearch.yml
建议使用自定义端口而不保留默认的9200
要对其进行测试,请通过SSH进入主服务器,并使用正确的端口ping ES ip来查看是否收到响应:
curl -X GET 'http://xxx.xxx.xxx.xxx:zzzz'
您还可以通过使用浏览器尝试验证ES是否可从其他IP访问。
有一篇很棒的文章展示了如何在DigitalOcean的Ubuntu上设置ES
在/etc/elasticsearch/elasticsearch.yml中,设置以下值:
network.host: [ localhost, _site_ ]
此选项允许您从本地主机和本地网络(192.168.XX)上的所有计算机访问,但不能从外部访问。
阅读有关此内容的更多信息以及其他选项,请阅读文档
在/etc/elasticsearch/elasticsearch.yml
:
network.host: 0.0.0.0
network.bind_host: 0.0.0.0
network.publish_host: 0.0.0.0
在中config/elasticsearch.yml
,network.host: 0.0.0.0
如@arsent所说。并在防火墙中为您的ElasticSearch端口添加入站规则(默认为9200)。
它在ElasticSearch 2.3.0版中有效
对于ElasticSearch 7.8及更高版本
检查您是否在单个节点上。添加以下行
cluster.initial_master_nodes: node-1
要从另一台计算机或应用程序访问Elasticsearch服务器,请对该节点的 C:\ProgramData\Elastic\Elasticsearch\config\elasticsearch.yml file:
添加以下行
network.host: ["0.0.0.0", 127.0.0.1", "[::1]"]
network.bind_host: 0.0.0.0
network.publish_host: 0.0.0.0
http.host: 0.0.0.0
有时您可能需要启用CORS
http.cors.enabled : true
http.cors.allow-origin : "*"
http.cors.allow-methods : OPTIONS, HEAD, GET, POST, PUT, DELETE
http.cors.allow-headers : X-Requested-With,X-Auth-Token,Content-Type, Content-Length
这是我完整的yml文件
bootstrap.memory_lock: false
cluster.name: elasticsearch
http.port: 9200
node.data: true
node.ingest: true
node.master: true
node.max_local_storage_nodes: 1
cluster.initial_master_nodes: node-1
node.name: ITDEV
path.data: C:\ProgramData\Elastic\Elasticsearch\data
path.logs: C:\ProgramData\Elastic\Elasticsearch\logs
transport.tcp.port: 9300
xpack.license.self_generated.type: basic
xpack.security.enabled: false
network.host: ["0.0.0.0", 127.0.0.1", "[::1]"]
network.bind_host: 0.0.0.0
network.publish_host: 0.0.0.0
http.host: 0.0.0.0
http.cors.enabled : true
http.cors.allow-origin : "*"
http.cors.allow-methods : OPTIONS, HEAD, GET, POST, PUT, DELETE
http.cors.allow-headers : X-Requested-With,X-Auth-Token,Content-Type, Content-Length