2011-07-05 18 views
24

Próbowałem nawiązać połączenie z kontem AWS s3 jak to w moim IRB konsoli -Problem w dostępie do wiadra z moim AWS S3 konto

AWS::S3::Base.establish_connection!(:access_key_id => 'my access key', :secret_access_key => 'my secret key', :server => "s3-ap-southeast-1.amazonaws.com") 

i to działa dobrze i poprosi to -

=> #<AWS::S3::Connection:0x8cd86d0 @options={:server=>"s3-ap-southeast-1.amazonaws.com", :port=>80, :access_key_id=>"my access key", :secret_access_key=>"my secret key"}, @access_key_id="my access key", @secret_access_key="my secret key", @http=#<Net::HTTP s3-ap-southeast-1.amazonaws.com:80 open=false>> 

mam wiadro, która opiera się na „Singapore Region” i dla tego serwera końcowego czyli jest: s3-ap-southeast-1.amazonaws.com Więc gdy próbuję uzyskać do niego dostęp za pomocą tego polecenia -

AWS::S3::Service.buckets 

to pobiera wszystkie wiadra na moim rachunku poprawnie -

=> [#<AWS::S3::Bucket:0x8d291fc @attributes={"name"=>"bucket1", "creation_date"=>2011-06-28 10:08:58 UTC}, @object_cache=[]>, 
#<AWS::S3::Bucket:0x8d291c0 @attributes={"name"=>"bucket2", "creation_date"=>2011-07-04 07:15:21 UTC}, @object_cache=[]>, 
#<AWS::S3::Bucket:0x8d29184 @attributes={"name"=>"bucket3", "creation_date"=>2011-07-04 07:39:21 UTC}, @object_cache=[]>] 

gdzie jako bucket1 należy do Regionu Singapurze i pozostałe 2 do Regionu USA. Tak więc, kiedy to zrobić -

AWS::S3::Bucket.find("bucket1") 

to pokazuje mi ten błąd:

AWS::S3::PermanentRedirect: The bucket you are attempting to access must be addressed using the specified endpoint. Please send all future requests to this endpoint. 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/error.rb:38:in `raise' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/base.rb:72:in `request' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/base.rb:88:in `get' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/bucket.rb:102:in `find' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/bucket.rb:145:in `objects' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/bucket.rb:313:in `reload!' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/bucket.rb:242:in `objects' 
    from /home/surya/.rvm/gems/ruby-1.9.2-p180/gems/aws-s3-0.6.2/lib/aws/s3/bucket.rb:253:in `each' 
    from (irb):5 
    from /home/surya/.rvm/rubies/ruby-1.9.2-p180/bin/irb:16:in `<main>' 

Nie rozumiem, dlaczego tak się dzieje przyczynę wczoraj samo działa dobrze. Jakieś pomysły?? Czy coś mi umyka??

+2

możliwość podłączania do niewłaściwej nazwy S3 DNS. Nie można uzyskać dostępu do zasobników z niewłaściwego regionu. –

+0

@spike Gronim Następnie jaki powinien być DNS do wykorzystania? – Surya

+1

bucket_name.s3.amazonaws.com –

Odpowiedz

37

Przed połączeniem, spróbuj użyć

AWS::S3::DEFAULT_HOST.replace "s3-ap-southeast-1.amazonaws.com" 

Inną rzeczą, jaką możesz zrobić (chociaż nie jest to dobre rozwiązanie) jest dostęp do wiadra z indeksu tablicy

AWS::S3::Bucket.list[0] 
+1

Spróbuj również użyć https://github.com/qoobaa/s3, znalazłem to łatwiejsze dla mnie. Porzuciłem klejnot AWS/s3 na razie. – hubbard

+0

OK !! Dzięki za informację :) – Surya

+2

Gdzie powinienem użyć tego kodu? – Abramodj

2

Tutaj Wpadłem też na ten problem. Odkąd mieszkam w Brazylii, próbowałem stworzyć wiadro sao paulo, po tym jak je usunąłem i użyłem amerykańskiego kubełka Standart, wszystko dobrze się układało.

+0

, która nie rozwiązuje problemu. Wyjaśniłeś tutaj, że program używa nas standardowego jako domyślnego segmentu. –

0

Region aws musi być ustawiony na us-standard, aby uzyskać dostęp do wiader S3.

W przypadku Linuksa z wiersza poleceń uruchom: export AWS_DEFAULT_REGION="us-standard".

7

Jeśli ktoś staje się problem, w którym staramy się robić różne regiony na różnych platformach, można skonfigurować Twój config tak:

AWS.config({ 
    :region => 'us-west-2', 
    :access_key_id => ENV["AWS_ACCESS_KEY_ID"], 
    :secret_access_key => ENV["AWS_SECRET_ACCESS_KEY"], 
    :s3 => { :region => 'us-east-1' } 
}) 
Powiązane problemy