2012-05-17 12 views
7

Starałem się, aby firma carrierwave współpracowała z Amazonem s3. zamiastcarrierwave, Excon :: Błędy :: MovedNerwalnie w RegistrationsController # błąd aktualizacji

storage :s3 

mam

storage :fog 

zmieniając go do przechowywania: s3 daje natychmiastowy błąd

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

więc zmieniłem go do przechowywania: mgła jak poniżej rdoc mówi .

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

jednak gdy próbuję przesłać obraz, ja dostać ten szalony błąd. użyję również gem devise.

mój pełny ślad stosu jest

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' 

nie wiem, co to jeszcze znaczy.

w moich inicjalizatorów/carrierwave.rb mam ..

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 

i mój plik uploader ma

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

mój plik gem ma

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

kiedy uruchomić mój serwer , zamiast webrick, używa również cienkiego programowania.

Czy moje konfiguracje są nieprawidłowe? pomoc byłaby bardzo ceniona! Byłem super utknął na ten problem carrierwave/s3

Odpowiedz

17

Wpadłem na to wcześniej, a to był problem z regionem. Po prostu go wyjmij i pozwól, aby był ustawiony domyślnie.

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

dziękuję! to jest to, co zrobiłem zbyt =) – Sasha

2

Dla mnie pracował tę konfigurację

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

dzięki! całkowicie pracował. – svs

2

miałem ten sam problem.

Wykonaj 3 kroki opisane poniżej.

1.ZMIEŃ domyślny obszar przy tworzeniu wiadrze

2.Edit mój plik carrierwave.rb (jak pokazano poniżej)

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 w wierszu poleceń jak w: heroku config:set S3_REGION='your region'

0

Tak jak powiedział @Jason Bynum, nie określaj regionu i pozwól mu być domyślnym.

Jeśli jeszcze nie, nie martw się, w tej chwili, będzie Heroku dać wskazówkę lubisz your region specified is wrong and should be xxx

I wiesz, jak wypełnić ten region teraz :)

Poniższe pracy dla mi:

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'