TransportClient访问docker中elasticsearch5.x失败的最终解决方案

第一步:修改elasticsearch.yml

                  network.host: 0.0.0.0

第二步:在宿主机执行:sudo sysctl -w vm.max_map_count=262144

第三步:修改docker中jre的java.policy

通过docker命令   docker exec -it myelasticsearch(这个是我的elasticsearch容器的名字) /bin/bash

                             进去后找到java.policy文件并修改                 

       经过研究这是java的权限设置问题,ES5.x之前的版本可以在elasticsearch.yml里设置security.manager.enabled为false。在ES5.x删除了该设置参数,暂时我们可以修改jdk中配置。以jdk8为例,在${JAVA_HOME}/jre/lib/security,修改java.policy,在grant{ }中添加下列内容:

permission java.security.AllPermission;


第四步:java中访问配置

elasticsearch.cluster-name=elasticsearch

elasticsearch.host=172.17.0.2

elasticsearch.port=9300


你可能感兴趣的:(TransportClient访问docker中elasticsearch5.x失败的最终解决方案)