繁体   English   中英

我可以安全地使用Amazon的Elasticsearch和Rails searchkick gem吗?

[英]Can I use Amazon's Elasticsearch with Rails searchkick gem securely?

我想知道我是否以及如何安全地使用searchkick与亚马逊的Elasticsearch。

Bellow是访问选项的图像。 IP地址并不理想,因为服务器IP可能会发生变化。

如果我限制对一个或多个AWS账户或IAM用户的访问,那么我不确定如何从rails应用程序进行身份验证。

Amazon Elasticsearch访问选项

您可以从Ruby向Amazon Elasticsearch发出签名的安全请求。 我使用Heroku上的应用程序执行了以下操作。

确保您拥有elasticsearch gem> = v1.0.15,因为对此的支持仅在2015年12月4日实施。

你还需要这个宝石:

gem 'faraday_middleware-aws-signers-v4'

elasticsearch-ruby / elasticsearch-transport文档中的示例:

您可以在配置块中使用任何标准的法拉第中间件和插件,例如签署AWS Elasticsearch服务的请求:

使用以下代码:

require 'faraday_middleware/aws_signers_v4'

client = Elasticsearch::Client.new(url: ENV['AWS_ENDPOINT_URL']) do |f|
  f.request :aws_signers_v4,
            credentials: Aws::Credentials.new(ENV['AWS_ACCESS_KEY_ID'], ENV['AWS_SECRET_ACCESS_KEY']),
            service_name: 'es',
            region: 'us-east-1'
end

这也适用于使用Rails的searchkick gem。 在初始化程序中使用上面的示例设置Searchkick.client:

# config/initializers/elasticsearch.rb
require 'faraday_middleware/aws_signers_v4'

Searchkick.client = Elasticsearch::Client.new(url: ENV['AWS_ENDPOINT_URL']) do |f|
  f.request :aws_signers_v4,
            credentials: Aws::Credentials.new(ENV['AWS_ACCESS_KEY_ID'], ENV['AWS_SECRET_ACCESS_KEY']),
            service_name: 'es',
            region: 'us-east-1'
end

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM