Elastic Stack(ELK)-3 安全配置x-pack

在ELK7 以后已经直接将x-pack集成到ELK中不在需要单独安装,但是只有在7.1版本后才免费开放安全配置,否则需要付费使用。
参考网站:
https://www.elastic.co/cn/blog/getting-started-with-elasticsearch-security
https://www.elastic.co/cn/products/stack/security
上述文档只配置elasticsearch和kibana,还需要注意logstash和filebeat的配置。

配置 TLS 和身份验证

使用elasticsearch-certutil 生成证书

find / -name elasticsearch-certutil #找到命令在哪里
/usr/share/elasticsearch/bin/elasticsearch-certutil cert -out elastic-certificates.p12 -pass ""

生成的证书elastic-certificates.p12在/usr/share/elasticsearch下面。需要备份出来,给elasticsearch各个节点使用。将证书放到:/etc/elasticsearch/ 下面
在每个节点的elasticsearch.yml增加如下内容:

xpack.security.enabled: true
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate
xpack.security.transport.ssl.keystore.path: /etc/elasticsearch/elastic-certificates.p12
xpack.security.transport.ssl.truststore.path: /etc/elasticsearch/elastic-certificates.p12

重启所有节点的elasticsearch。
在主节点上生成密码, 主节点开始运行,便可以为集群设置密码:
/usr/share/elasticsearch/bin/elasticsearch-setup-passwords auto
使用auto自动生成类似如下密码
(注意保存好密码后续会使用到) interactive 参数可以手动定义密码:

Changed password for user apm_system
PASSWORD apm_system = 8JuVCoVHL4OzCaitLNQp

Changed password for user kibana
PASSWORD kibana = 3DDh6fGRYp1HvxDfT12D

Changed password for user logstash_system
PASSWORD logstash_system = 6Tow5AxAcmWxSakUyNa4

Changed password for user beats_system
PASSWORD beats_system = 8PtRLrPzOE2te09WVFj4

Changed password for user remote_monitoring_user
PASSWORD remote_monitoring_user = h8HbgQYzut8iOgVuVu7R

Changed password for user elastic
PASSWORD elastic = RRCOfh9UudUIVZ4i954E

为 Kibana 用户添加密码
kibana.yml 文件。找到类似下面的代码行

#elasticsearch.username: "user"
#elasticsearch.password: "pass"

对 username 和 password 字段取消注释,方法是删除代码行起始部分的 # 符号。将 "user" 更改为 "kibana",然后将 "pass" 更改为 setup-passwords 命令告诉我们的任何 Kibana 密码。保存文件,重新启动 Kibana 了。
登录如下界面:输入超级用户和密码elastic = RRCOfh9UudUIVZ4i954E.可以在管理中新建角色和用户用来授权不同账号登录,查看不同内容。


kibana登录

密码和账户管理

设置密码后,之前设置logstash也需要修改output参数,否则是无法写入日志数据的。增加user和passwd字段,此处也可以设置低权限的账户用来写入数据,但需要设置好权限,否则也是无法写入的。

output {  # 定义日志输出
    if "nginx" in [tags]{
    elasticsearch {
    hosts => ["172.16.15.53:9200"]  # 定义es服务器的ip
    index => "nginx-%{+YYYY.MM.dd}" # 定义索引
user => "elastic"
    password => "RRCOfh9UudUIVZ4i954E"
  }}
  else if "system" in [tags]{
    elasticsearch {
    hosts => ["172.16.15.53:9200"]  # 定义es服务器的ip
    index => "system-%{+YYYY.MM.dd}" # 定义索引
    user => "elastic"
    password => "RRCOfh9UudUIVZ4i954E"
  }}
  else if "tomcat-access" in [tags]{
    elasticsearch {
    hosts => ["172.16.15.53:9200"]  # 定义es服务器的ip
    index => "tomcat-access-%{+YYYY.MM.dd}" # 定义索引
    user => "elastic"
    password => "RRCOfh9UudUIVZ4i954E"
  }}
  else if "tomcat-catalina" in [tags]{
    elasticsearch {
    hosts => ["172.16.15.53:9200"]  # 定义es服务器的ip
    index => "tomcat-catalina-%{+YYYY.MM.dd}" # 定义索引
    user => "elastic"
    password => "RRCOfh9UudUIVZ4i954E"
  }}
  else {
  elasticsearch {
    hosts => ["172.16.15.53:9200"]  # 定义es服务器的ip
    index => "mysql-%{+YYYY.MM.dd}" # 定义索引
    user => "elastic"
    password => "RRCOfh9UudUIVZ4i954E"
    }
  }
}

如果设置的是filebeat直接输入到es集群中需要在filebeat.yml修改参数加入用户名和密码:

output.elasticsearch:
  # Array of hosts to connect to.
  hosts: ["172.16.15.53:9200","172.16.15.26:9200"]

  # Optional protocol and basic auth credentials.
  #protocol: "https"
  username: "elastic"
password: "changeme"

内置账户的含义:
elastic内置超级用户。请参阅内置角色。
kibana用户Kibana用于连接Elasticsearch并与之通信。
logstash_system:Logstash用户在Elasticsearch中存储监视信息时使用。
beats_system:eats在Elasticsearch中存储监控信息时使用的用户。
apm_system:APM服务器在Elasticsearch中存储监视信息时使用的用户。
remote_monitoring_user:Metricbeat用户在Elasticsearch中收集和存储监控信息时使用。它具有remote_monitoring_agent和 remote_monitoring_collector内置的角色。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,440评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,814评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,427评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,710评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,625评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,511评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,162评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,311评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,262评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,278评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,989评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,583评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,664评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,904评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,274评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,856评论 2 339