解决单台Elasticsearch 未授权访问漏洞

一、单机部署

1、新增密码

编辑配置文件 bin/elasticsearch.yml,新增配置

Go 复制代码
#开启密码验证
xpack.security.enabled: true
xpack.license.self_generated.type: basic
xpack.security.transport.ssl.enabled: true

如下截图所示:

2、java应用调用ES服务

报错提示没有用户信息:

复制代码
Elasticsearch exception [type=security_exception, reason=missing authentication credentials for REST request [/seproject/_search?typed_keys=true&ignore_unavailable=false&expand_wildcards=open&allow_no_indices=true&ignore_throttled=true&search_type=query_then_fetch&batched_reduce_size=512&ccs_minimize_roundtrips=true]]

3、设置一下用户及密码

ES要先启动才能设置否则报错,如下图:

启动ES:

复制代码
./elasticsearch -d

设置密码:

复制代码
./elasticsearch-setup-passwords interactive

4、访问需要密码,输入刚才设置的密码就正常访问

5、java程序修改,新增用户及密码,密码放到配置里

复制代码
    RestHighLevelClient client() {
        RestClientBuilder build = RestClient.builder(createHosts()).setRequestConfigCallback(new RestClientBuilder.RequestConfigCallback() {
            @Override
            public RequestConfig.Builder customizeRequestConfig(RequestConfig.Builder builder) {
                return builder.setConnectTimeout(5000 * 1000) // 连接超时(默认为1秒)
                        .setSocketTimeout(6000 * 1000);// 套接字超时(默认为30秒)//更改客户端的超时限制默认30秒现在改为100分钟
            }
        });
        //加密码后增加
        CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(username, password));
        build.setHttpClientConfigCallback((HttpAsyncClientBuilder httpAsyncClientBuilder) -> httpAsyncClientBuilder.setDefaultCredentialsProvider(credentialsProvider));
       //加密码后增加
        RestHighLevelClient restHighLevelClient = new RestHighLevelClient(build);
        return restHighLevelClient;
    }

5、重启java应用再次访问,正常

6、Kibana,连不上

7、配置Kibana config/kinana.yml

默认是注释掉的

复制代码
elasticsearch.username: kibana
elasticsearch.password: password

8、使用刚才设置密码的用户登录

相关推荐
serendipity_hky11 小时前
互联网大厂Java面试故事:核心技术栈与场景化业务问题实战解析
java·spring boot·redis·elasticsearch·微服务·消息队列·内容社区
Elastic 中国社区官方博客12 小时前
ES|QL 在 9.2:智能查找连接和时间序列支持
大数据·数据库·人工智能·sql·elasticsearch·搜索引擎·全文检索
知秋正在99613 小时前
ElasticSearch服务端报错:FileSystemException: No space left on device
大数据·elasticsearch·搜索引擎
一个大专生的淘汰之路15 小时前
Elasticsearch 如何确保新增文档立即可见?
elasticsearch
知秋正在99616 小时前
ElasticSearch服务端报错:system call filters failed to install
大数据·elasticsearch·搜索引擎
Elasticsearch17 小时前
Elastic Streams 介绍
elasticsearch
知秋正在99620 小时前
ElasticSearch服务端报错:Unrecognized VM option ‘UseAVX=2‘
大数据·elasticsearch·jenkins
Wang's Blog21 小时前
Elastic Stack梳理: ElasticSearch分页与遍历技术深度解析与工程实践
大数据·elasticsearch·搜索引擎
Elastic 中国社区官方博客1 天前
Elastic 与 Accenture 在 GenAI 数据准备方面的合作
大数据·人工智能·elasticsearch·搜索引擎·ai·全文检索·aws
武子康1 天前
大数据-173 Elasticsearch 映射与文档增删改查实战(基于 7.x/8.x)JSON
大数据·后端·elasticsearch