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

Som*_*azx 3 ruby-on-rails heroku amazon-web-services elasticsearch searchkick

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

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

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

Amazon Elasticsearch访问选项

Som*_*azx 12

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

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

你还需要这个宝石:

gem 'faraday_middleware-aws-signers-v4'
Run Code Online (Sandbox Code Playgroud)

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
Run Code Online (Sandbox Code Playgroud)

这也适用于使用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
Run Code Online (Sandbox Code Playgroud)