Viime vuosina verkkotallennuksista on tullut valtavirtaa, ja ne tarjoavat erittäin skaalautuvia arkkitehtuureja, parannettua turvallisuutta ja laajan tiedonsaannin. Yksi suosituimmista tallennuspalveluista on Amazonin Simple Storage Service, joka tunnetaan yleisesti nimellä S3.
Amazon S3 on erittäin tehokas palvelu, joka on Amazon Web Servicesin ydin. Tuotantoympäristön ulkopuolella S3:n kanssa voi kuitenkin olla haastavaa työskennellä. Siihen liittyy pääsyavainten kiertelyä, käyttäjätilien käyttöönottoa ja luotettavan verkkoyhteyden ylläpitoa - puhumattakaan siitä, että se maksaa rahaa.Onneksi on olemassa työkalu, joka auttaa ratkaisemaan tämän ongelman. FakeS3 on kevyt palvelin, joka simuloi oikean S3:n käyttäytymistä. Se vastaa samoihin kutsuihin, joihin Amazon S3 vastaa, ja tallentaa ladatut tiedostot paikalliseen tiedostojärjestelmääsi - Amazonin palveluun ei tehdä pyyntöjä. Vaikka gem ei tue kaikkia S3:n komentoja, toteutettu API riittää useimpien sovellusten käyttötapauksiin.
Tässä artikkelissa esittelen lähestymistavan AWS:n ja FakeS3:n integrointiin Paperclipin kanssa - suosittu tiedostojen liitekirjasto Active Recordille. Paperclip ja S3 yhdessä yhdistettynä tarjoavat tehokkaan tiedostojen tallennusjärjestelmän, jossa yhdistyvät Paperclipin hyödylliset perusominaisuudet (kuten validointien hallinta ja kuvamuunnokset) ja verkkotallennuksen edut. Vaikka näiden työkalujen konfigurointi ei ole itsestään selvää ja vaatii yksityiskohtaisen dokumentaation tutkimista sekä monien helmikohtaisten ongelmien ratkaisemista, kannattaa käyttää hieman aikaa kehityksen nopeuttamiseen ja tehostamiseen.
Mikä on tavoitteemme?
Kuvattujen työkalujen integrointi edellyttää kolmea vaihetta:
Käynnistetään taustalla FakeS3-jalokiven tarjoama S3-fakepalvelin.
AWS S3 -asiakkaan määrittäminen delegoimaan kaikki pyynnöt käynnistetylle väärennetylle palvelimelle.
Paperclipin määrittäminen käyttämään väärennettyä S3-päätepistettä rakennettujen resurssien URL-osoitteissa.
Varmista, että asennat aws-sdk:n version 1.6. Paperclip, joka käyttää SKD:tä Amazonin palvelun tallennustilan hallintaan, ei toimi hyvin tämän helmen korkeampien versioiden kanssa. Tämä johtuu SDK:n API:n merkittävistä muutoksista, jotka versio 2.0 toi mukanaan.
Muista myös, että FakeS3:n päätavoitteena on minimoida ajoaikariippuvuudet. Se on enemmänkin kehitystyökalu, jolla voit testata S3-kutsuja omassa koodi eikä tuotantopalvelimelle, joka haluaa kopioida S3:n toimintoja. Sen vuoksi sinun tulisi sisällyttää gem vain kehitys- ja testiryhmään.
AWS-konfiguraatio
AWS SDK tarjoaa erityisen apumenetelmän, joka vastaa konfiguraation lataamisesta. Se lataa oletusarvoisesti konfiguraation osoitteesta config/aws.yml, poimii sen parametrit nykyistä ympäristöä varten ja välittää ne AWS-asiakkaalle. Kutsu ensin seuraavaa metodia alustajassa:
access_key_id, secret_access_key, salainen_avain - AWS-asiakkaan tunnistetiedot, joita tarvitaan Amazon-tilisi käyttämiseen. Niitä ei huomioida väärennetyllä S3-palvelimella, joten mukautetut arvot hiekkalaatikkoympäristöissä.
s3_endpoint, s3_portti- S3-päätepisteen määrittely. Käytämme näitä parametreja korvataksemme todellisen S3-päätepisteen FakeS3-helmen käynnistämällä väärennetyllä päätepisteellä - kaikki Amazonin palveluun kohdistuvat pyynnöt siirretään nyt paikalliselle väärennöspalvelimelle.
s3_force_path_style - S3 hyväksyy kaksi tapaa sisällyttää kauhan nimi URL-osoitteeseen. Voit valita, haluatko ämpäriin nimen domain-tyylisesti (bucket.s3.amazonaws.com) vai polkutyylisesti (s3.amazonaws.com/bucket). Jotta asiat pysyisivät yksinkertaisina ja jotta vältyttäisiin ylimääräisiltä asetuksilta, jotka liittyvät ämpärin aliverkkotunnuksen yhdistämiseen silmukan takaisinkytkentäosoitteeseen, suosin kehitysympäristössä polkutyyliä domain-tyylin sijaan.
use_ssl - pakottaa AWS SDK:n käyttämään HTTPS:ää vanilla-HTTP:n sijaan. Meidän on poistettava tämä vaihtoehto käytöstä, koska FakeS3 gem ei tue HTTPS-pyyntöjä, jotka AWS-asiakas tekee oletusarvoisesti.
Tuotantoympäristön konfigurointi on melko suoraviivaista:
Tällä kertaa kyse on kuitenkin aidosta S3-palvelusta, joten sinun on annettava aidot AWS-tunnukset.
Mahdollisten tietoturvariskien vuoksi on hyvä käytäntö pitää salaiset arvot, kuten käyttöoikeudet, poissa versionhallintajärjestelmästä esimerkiksi käyttämällä ympäristömuuttujia. Käytämme ERB:tä sen arvojen syöttämiseen konfiguraatiotiedostoon.
Paperiliittimen kokoonpano
Nyt on aika kohdata Paperclip ja pakottaa se toimimaan hienosti jo määritetyn S3-asiakkaan kanssa. Paperclipin konfiguroinnin päätavoite on saada tallennuspolku, joka paikantaa fakeserverin isännöimät resurssit:
varastointi - määrittää tallennusvälineen (oletuksena paikallinen tiedostojärjestelmä). Koska käytämme AWS S3:a, meidän on muutettava se muotoon :s3.
ämpäri - sen S3-säiliön nimi, johon tiedostot tallennetaan. Jos ämpäriä ei ole olemassa, Paperclip yrittää luoda sen.
url - asetettu :s3_alias_url aiheuttaa sen, että Paperclip alias S3-säiliön isäntänimen arvolla, joka on määritetty arvolla :s3_host_alias parametri.
s3_host_alias - alias oletusarvoisen S3-säiliön isännälle. Huomaa, että hostin, portin ja kauhan nimen sijoitus vastaa AWS-asiakkaan asetuksia.
polku - malli avaimille, joiden alle tiedostot tallennetaan ämpäriin. Avainten pitäisi olla yksilöllisiä ämpäriin, kuten tiedostonimien. Koska S3 ei tue hakemistoja, voit käyttää hakemistoa / symboli hakemistorakenteiden simuloimiseksi.
AWS-tunnusten tapaan myös kauhan nimeä pidetään salaisena arvona, joka tulisi säilyttää koodipohjan ulkopuolella. Suosittelen sen nimen tallentamista ympäristömuuttujaan.
Yhdistä lopuksi konfiguraatio Paperclipin oletusasetuksiin alustuksessa:
Sekä AWS- että Paperclip-konfiguraatiot sisältävät viittauksen paikalliseen S3-fakeserveriin, jonka odotetaan toimivan osoitteessa localhost:10001. Ennen kehitystyöskentelyä sinun tulee käynnistää palvelin seuraavalla komennolla (FakeS3 gemin tarjoama):
fakes3 -r public/system -p 10001
Välitettävät parametrit ovat:
root -r - juurihakemisto, johon ladatut tiedostot tallennetaan. Harkitse sen jättämistä pois VCS:stä, jos et halua, että ladatut tiedostot tallennetaan arkistoosi.
port -p - sen portin numero, jossa paikallista palvelinta käytetään.
Jos käytät Foremania prosessien hallintaan sovelluksessasi, voi olla kätevää lisätä Procfileen seuraava merkintä: