elasticsearch,logstash,kibana,kibana-4,Nginx,elasticsearch,Logstash,Kibana,Kibana 4" /> elasticsearch,logstash,kibana,kibana-4,Nginx,elasticsearch,Logstash,Kibana,Kibana 4" />

Kibana 4,Logstash dashboard:保存时如何要求Nginx身份验证,但允许匿名查看?

Kibana 4,Logstash dashboard:保存时如何要求Nginx身份验证,但允许匿名查看?,nginx,elasticsearch,logstash,kibana,kibana-4,Nginx,elasticsearch,Logstash,Kibana,Kibana 4,我想要求使用auth_basic nginx身份验证来保存所有kibana 4仪表板,但允许任何人在没有身份验证的情况下查看仪表板。 我最近使用DigitalOcean在Ubuntu14.04上安装了ELK(Elasticsearch 1.4.5、Logstash 1:1.5.2-1和Kibana 4.1.1)堆栈 因为kibana使用基于浏览器的javascript向elasticsearch发送查询,所以我不确定如何确定要保护哪些内容 DigitalOcean提供了一个nginx配置来完全保

我想要求使用auth_basic nginx身份验证来保存所有kibana 4仪表板,但允许任何人在没有身份验证的情况下查看仪表板。

我最近使用DigitalOcean在Ubuntu14.04上安装了ELK(Elasticsearch 1.4.5、Logstash 1:1.5.2-1和Kibana 4.1.1)堆栈

因为kibana使用基于浏览器的javascript向elasticsearch发送查询,所以我不确定如何确定要保护哪些内容

DigitalOcean提供了一个nginx配置来完全保护对kibana 4的访问

FILE:/etc/nginx/sites-available/default
server {
    listen      80;
    return 301 https://logstash.nyc.3top.com;
}
server {
    listen 443;

    ssl on;
    ssl_certificate /etc/nginx/ssl/server.crt;
    ssl_certificate_key /etc/nginx/ssl/server.key;

    server_name logstash.example.com;
    access_log /var/log/nginx/kibana.access.log;

    auth_basic "Restricted Access";
    auth_basic_user_file /etc/nginx/htpasswd.users;

    location / {
        proxy_pass http://localhost:5601;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
    }
}
Elastic为Kibana 3而非Kibana 4提供了一个nginx来实现这一点:

server {
  listen                *:80 ;

  server_name           kibana.myhost.org;
  access_log            /var/log/nginx/kibana.myhost.org.access.log;

  location / {
    root  /usr/share/kibana3;
    index  index.html  index.htm;
  }

  location ~ ^/_aliases$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
  }
  location ~ ^/.*/_aliases$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
  }
  location ~ ^/_nodes$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
  }
  location ~ ^/.*/_search$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
  }
  location ~ ^/.*/_mapping {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
  }

  # Password protected end points
  location ~ ^/kibana-int/dashboard/.*$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
    limit_except GET {
      proxy_pass http://127.0.0.1:9200;
      auth_basic "Restricted";
      auth_basic_user_file /etc/nginx/conf.d/kibana.myhost.org.htpasswd;
    }
  }
  location ~ ^/kibana-int/temp.*$ {
    proxy_pass http://127.0.0.1:9200;
    proxy_read_timeout 90;
    limit_except GET {
      proxy_pass http://127.0.0.1:9200;
      auth_basic "Restricted";
      auth_basic_user_file /etc/nginx/conf.d/kibana.myhost.org.htpasswd;
    }
  }
}
有人知道如何为Kibana 4这样做吗?

以下是我的elasticsearch和kibana配置文件:

/etc/elasticsearch/elasticsearch.yml

network.host: localhost
/opt/kibana/config/kibana.yml

port: 5601
host: "localhost"
elasticsearch_url: "http://localhost:9200"
elasticsearch_preserve_host: true
kibana_index: ".kibana"
default_app_id: "discover"
request_timeout: 300000
shard_timeout: 0
verify_ssl: true
bundled_plugin_ids:
 - plugins/dashboard/index
 - plugins/discover/index
 - plugins/doc/index
 - plugins/kibana/index
 - plugins/markdown_vis/index
 - plugins/metric_vis/index
 - plugins/settings/index
 - plugins/table_vis/index
 - plugins/vis_types/index
 - plugins/visualize/index

您可能需要利用nginx的条件能力来实现这一点。这可能是一个很好的起点。让我知道这是否适合您。

谢谢,链接很有用。虽然它使整个站点成为只读的,并且似乎限制了应用新过滤器的能力,但它给了我一个$request\u uri来进行实验。我将看看是否可以根据此查找/猜测仪表板保存、配置保存等的$request\u uri。我可能要到本周晚些时候才能看到这一点,但我会在有更新的时候发布。