默认情况下,当我们搭建好es集群
后,我们通过http://localhost:9200
就可以直接访问到es集群的一些信息,这显然是不安全的。在同一个局域网中,如果我们启动了多个es节点,且集群的名字相同,那么他们可能会自动加入集群,这显然是不安全的。因此我们要想个办法来解决它。es自带的插件x-pack
就可以解决上述的要求。在高版本的es中,x-pack
插件是默认就集成了。
1、给es增加用户名和密码访问。
2、集群之间的通讯采用TLS通讯。
# 1、修改 ES_HOME/config/elasticsearch.yml
# 增加如下配置
vim config/elasticsearch.yml
xpack.security.enabled: true
此时可以看到访问es集群就需要用户名和密码了,那么我们这个用户名和密码从哪里获取呢?
./bin/elasticsearch-setup-passwords auto
如果执行上面这个语句,那么es会自动设置密码,我们需要自己把这个密码保存下来。
./bin/elasticsearch-setup-passwords interactive
此处为了简单,将每个用户的用户名和密码都设置成 123456
,生产环境需要设置成一个复杂的接口。
注意️:
当我们设置了elastic
用户的密码后,就不可在执行elasticsearch-setup-passwords
命令了。
重新访问es集群,输入用户名和密码之后,就可以访问到集群的信息了。
# 设置用户名和密码
elasticsearch.username: "kibana_system"
elasticsearch.password: "123456"
该用户名和密码,是由上一步设置好的。
此时可以看到,我们的kibana就需要用户名和密码访问了。
1、在es集群的生产模式中
,节点之间的通讯必须要使用TLS通讯,否则集群无法启动。
2、配置集群以TLS通讯,还可以防止不受信任的节点加入es集群。
集群之间的服务发现不可是 single-node discovery 服务发现。
节点之间可以使用非回环地址加入集群。
# 生成证书
bin/elasticsearch-certutil ca
# --ca 指定证书的路径
./bin/elasticsearch-certutil cert --ca elastic-stack-ca.p12
# 1、将证书拷贝到每个节点的 config 目录下
mv elastic-certificates.p12 config
# 2、修改elasticsearch.yml文件,增加如下配置
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate
xpack.security.transport.ssl.client_authentication: required
xpack.security.transport.ssl.keystore.path: elastic-certificates.p12
xpack.security.transport.ssl.truststore.path: elastic-certificates.p12
使用resource.reload.interval.high
参数配置,默认是5s
。
import org.apache.http.HttpHost;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
/**
* @author huan.fu 2021/4/22 - 下午2:48
*/
public class AbstractEsApi {
protected final RestHighLevelClient client;
public AbstractEsApi() {
final CredentialsProvider credentialsProvider =
new BasicCredentialsProvider();
credentialsProvider.setCredentials(AuthScope.ANY,
new UsernamePasswordCredentials("elastic", "123456"));
client = new RestHighLevelClient(
RestClient.builder(
new HttpHost("localhost", 9200, "http"),
new HttpHost("localhost", 9201, "http"),
new HttpHost("localhost", 9202, "http")
)
.setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider))
);
}
}
手机扫一扫
移动阅读更方便
你可能感兴趣的文章