2012-05-17 10 views
7

He intentado que carrierwave trabaje con Amazon s3. en lugar decarrierwave, Excon :: Errors :: MovedPermanently en RegistrationsController # update error

storage :s3 

tengo

storage :fog 

cambiándolo al almacenamiento: s3 da un error inmediata

https://stackoverflow.com/questions/10629827/carrierwave-cant-convert-nil-into-string-typeerror-when-using-s3

así que lo cambié al almacenamiento: niebla como la rdoc abajo dice .

http://rubydoc.info/gems/carrierwave/frames

sin embargo cuando intento subir una imagen, me sale este error loco. Estoy usando la gema del ingenio también.

mi traza completa es

Excon::Errors::MovedPermanently in RegistrationsController#update 

Excon::Errors::MovedPermanently (Expected(200) <=> Actual(301 Moved Permanently) 
    request => {:connect_timeout=>60, :headers=>{"Content-Length"=>95472, "Content-Type"=>"image/jpeg", "x-amz-acl"=>"private", "Cache-Control"=>"max-age=315576000", "Date"=>"Thu, 17 May 2012 05:28:55 +0000", "Authorization"=>"AWS AKIAIN6SC3YSGBSUKV4Q:kZOG9mG01jYn48ImFMYbgxAAQRk=", "Host"=>"user.a.777.s3-eu-west-1.amazonaws.com:443"}, :instrumentor_name=>"excon", :mock=>false, :read_timeout=>60, :retry_limit=>4, :ssl_ca_file=>"/Users/sasha/.rvm/gems/ruby-1.9.3-p125/gems/excon-0.13.4/data/cacert.pem", :ssl_verify_peer=>true, :write_timeout=>60, :host=>"user.a.777.s3-eu-west-1.amazonaws.com", :path=>"/uploads%2Fuser%2Fimage%2F59%2Fidea.jpg", :port=>"443", :query=>nil, :scheme=>"https", :body=>#<File:/Users/sasha/Desktop/rails_projects/blue_eyes/public/uploads/tmp/20120516-2228-19160-9893/idea.jpg>, :expects=>200, :idempotent=>true, :method=>"PUT"} 
    response => #<Excon::Response:0x007fd72a146820 @body="<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Error><Code>PermanentRedirect</Code><Message>The bucket you are attempting to access must be addressed using the specified endpoint. Please send all future requests to this endpoint.</Message><RequestId>F5F5AF888E837622</RequestId><Bucket>user.a.777</Bucket><HostId>IShK3GIthzCQysLOKXnR+ijJiHmMuUtXBOpFxQM4uCvJgkEHfmFn43LL4oWmpT82</HostId><Endpoint>s3.amazonaws.com</Endpoint></Error>", @headers={"x-amz-request-id"=>"F5F5AF888E837622", "x-amz-id-2"=>"IShK3GIthzCQysLOKXnR+ijJiHmMuUtXBOpFxQM4uCvJgkEHfmFn43LL4oWmpT82", "Content-Type"=>"application/xml", "Transfer-Encoding"=>"chunked", "Date"=>"Thu, 17 May 2012 05:29:00 GMT", "Connection"=>"close", "Server"=>"AmazonS3"}, @status=301>): 
    app/controllers/registrations_controller.rb:30:in `update' 

No sé lo que significa que incluso.

en mis inicializadores/carrierwave.rb tengo ..

CarrierWave.configure do |config| 
    config.fog_credentials = { 
    :provider    => 'AWS',  # required 
    :aws_access_key_id  => 'somekey',  # required 
    :aws_secret_access_key => 'secretkey',  # required 
    :region     => 'eu-west-1' # optional, defaults to 'us-east-1' 
    } 
    config.fog_directory = 'bucket.name'      # required 
    #config.fog_host  = 'https://s3.amazonaws.com'   # optional, defaults to nil 
    config.fog_public  = false         # optional, defaults to true 
    config.fog_attributes = {'Cache-Control'=>'max-age=315576000'} # optional, defaults to {} 
end 

y mi cargador de archivos tiene

#storage :s3 
    storage :fog 
    def store_dir 
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}" 
    end 

mi archivo joya tiene

gem 'carrierwave' 
gem 'thin' 
gem 'fog' 

cuando arranco mi servidor , en lugar de webrick, usa thin en desarrollo también.

son mis configuraciones incorrectas? ayuda sería muy apreciada! He estado muy atascado en este número de carrierwave/s3

Respuesta

17

Me encontré con esto el día de hoy y era un problema con la región. Solo sácalo y déjalo establecer por defecto.

CarrierWave.configure do |config| 
    config.fog_credentials = { 
    :provider    => 'AWS',  # required 
    :aws_access_key_id  => 'somekey',  # required 
    :aws_secret_access_key => 'secretkey'  # required 
    } 
    config.fog_directory = 'bucket.name'      # required 
    #config.fog_host  = 'https://s3.amazonaws.com'  # optional, defaults to nil 
    config.fog_public  = false        # optional, defaults to true 
    config.fog_attributes = {'Cache-Control'=>'max-age=315576000'} # optional, defaults to {} 
end 
+1

gracias! eso es lo que winded haciendo demasiado =) – Sasha

2

Para mí trabajado esta configuración

config.fog_directory = 'bucket_name'     
config.fog_host  = 'https://s3-eu-west-1.amazonaws.com/bucket_name'  
+0

gracias! totalmente trabajado. – svs

2

que tenía el mismo problema.

Seguir los 3 pasos siguientes funcionó para mí.

1.Change la región por defecto al crear un cubo

2.Edit mi archivo carrierwave.rb (como se muestra a continuación)

initializers/carrierwave.rb:

if Rails.env.production? 
    CarrierWave.configure do |config| 
    config.fog_credentials = { 
     :provider    => 'AWS', 
     :aws_access_key_id  => ENV['S3_ACCESS_KEY'], 
     :aws_secret_access_key => ENV['S3_SECRET_KEY'], 
     :region => ENV['S3_REGION'] 
    } 
    config.fog_directory  = ENV['S3_BUCKET'] 
    end 
end 

3.Configure heroku en la línea de comandos como en: heroku config:set S3_REGION='your region'

0

Al igual que @Jason Bynum dijo, no especifique la región y deje que sea la predeterminada.

Si todavía no, no se preocupe, En este momento, heroku dará toque a ti como your region specified is wrong and should be xxx

Y saben cómo llenar la región en este momento :)

Los siguientes trabajan para me:

CarrierWave.configure do |config| 
    config.fog_credentials = { 
     provider:    'AWS',      # required 
     aws_access_key_id:  ENV['S3_KEY'],      # required 
     aws_secret_access_key: ENV['S3_SECRET'],      # required 
     region:    'ap-southeast-1',     # optional, defaults to 'us-east-1' 

    } 
    config.fog_directory = 'your_bucket_name'       # required 
    config.fog_public  = false          # optional, defaults to true 
    config.fog_attributes = { 'Cache-Control' => "max-age=#{365.day.to_i}" } # optional, defaults to {} 
end 

Gemfile:

gem 'carrierwave', '0.10.0' 
gem 'fog', '1.36.0'