window.pipedriveLeadboosterConfig = { bas: 'leadbooster-chat.pipedrive.com', företagId: 11580370, playbookUuid: '22236db1-6d50-40c4-b48f-8b11262155be', version: 2, } ;(funktion () { var w = fönster if (w.LeadBooster) { console.warn('LeadBooster finns redan') } annars { w.LeadBooster = { q: [], on: funktion (n, h) { this.q.push({ t: "o", n: n, h: h }) }, trigger: funktion (n) { this.q.push({ t: 't', n: n }) }, } } })() thecodest, Author at The Codest - Page 18 of 18

Amazon S3 är en extremt kraftfull tjänst som utgör kärnan i Amazon Web Services. Utanför produktionsmiljön kan S3 dock vara utmanande att arbeta med. Det handlar om att skicka runt åtkomstnycklar, tillhandahålla användarkonton och upprätthålla en tillförlitlig nätverksanslutning - för att inte tala om att det kostar pengar.Lyckligtvis finns det ett verktyg som hjälper till att lösa detta problem. FakeS3 är en lättviktig server som simulerar beteendet hos den riktiga S3. Den svarar på samma anrop som Amazon S3 svarar på och lagrar uppladdade filer i ditt lokala filsystem - inga förfrågningar görs till Amazons tjänst. Även om gem inte stöder hela uppsättningen S3-kommandon är det implementerade API:et tillräckligt för de flesta applikationsanvändningsfall.

I den här artikeln kommer jag att presentera metoden för att integrera AWS och FakeS3 med Paperclip - populärt filbilagebibliotek för Active Record. Paperclip och S3 blandat tillsammans ger ett effektivt fillagringssystem som kombinerar användbara Paperclips kärnfunktioner (som valideringshantering och bildtransformationer) med fördelarna med online-lagring. Även om konfigurationen av dessa verktyg inte är självklar och kräver att man gräver i detaljerad dokumentation samt löser många gem-specifika problem, är det värt att spendera lite tid på att göra utvecklingen snabbare och effektivare.

Vad är vårt mål?

Integrationen av de beskrivna verktygen kräver tre steg:

  1. Startar S3-fakeserver som tillhandahålls av FakeS3 gem i bakgrunden.
  2. Konfigurera AWS S3-klient för att delegera alla förfrågningar till lanserad fakeserver.
  3. Konfigurera Paperclip för att använda falsk S3-slutpunkt i URL:er för inbyggda resurser.

Installation

Låt oss börja med att installera nödvändiga gems:

# Gemfile

gem "paperclip"
gem "aws-sdk", "~> 1.6"

gem "fakes3", grupp: [:utveckling, :test]

Se till att installera version 1.6 av aws-sdk. Paperclip som använder SKD för att hantera lagring i Amazons tjänst fungerar inte bra med högre versioner av denna pärla. Detta beror på betydande förändringar i SDK: s API som infördes med version 2.0.

Kom också ihåg att huvudsyftet med FakeS3 är att minimera runtime-beroenden. Det är mer av ett utvecklingsverktyg för att testa S3-anrop i din kod snarare än en produktionsserver som vill duplicera S3-funktionalitet. Därför bör du endast inkludera gem i utvecklings- och testgrupper.

AWS-konfiguration

AWS SDK tillhandahåller en dedikerad hjälpmetod som ansvarar för att ladda konfigurationen. Den kommer som standard att ladda konfigurationen från konfiguration/aws.yml, extrahera dess parametrar för den aktuella miljön och skicka dem till AWS-klienten. Först anropar du följande metod i en initialiserare:

# config/initializers/aws.rb

AWS::Rails.load_yaml_config

Nu när konfigurationsfilen har laddats på rätt sätt kan vi fortsätta med att specificera innehållet i den:

# config/aws.yml

utveckling: &utveckling
    access_key_id: "abc"
    hemlig_access_key: "abc"
    s3_endpoint: "localhost"
    s3_port: 10001
    s3_force_path_style: true
    use_ssl: false

test: *utveckling

Låt oss diskutera alla parametrar en efter en:

Konfigurationen för produktionsmiljön är ganska okomplicerad:

# config/aws.yml

produktion: &produktion
    access_key_id:     
    hemlig_access_nyckel: 

staging: *produktion

Den här gången handlar det dock om en riktig S3-tjänst, och därför måste du ange autentiska AWS-legitimationsuppgifter.

På grund av potentiella säkerhetsrisker är det en god praxis att hålla hemliga värden som åtkomstnycklar utanför ditt versionskontrollsystem, t.ex. genom att använda miljövariabler. Vi kommer att använda ERB för att injicera dess värden i konfigurationsfilen.

Paperclip-konfiguration

Nu är det dags att möta Paperclip och tvinga den att fungera snyggt med den redan konfigurerade S3-klienten. Huvudmålet med Paperclips konfiguration är att få lagringsvägen som kommer att lokalisera resurser som är värd för fakeserver:

localhost:10001/:bucket_name/:path

Återigen, låt oss börja med utvecklingsmiljön:

# config/paperclip.yml

utveckling: &utveckling
    lagring: :s3
    hink: "utveckling"
    s3_host_name: "localhost"
    url: ":s3_alias_url"
    sökväg: ":class/:attachment/:id_partition/:style/:filename.:extension"
    s3_host_alias: "localhost:10001/development"

test: *utveckling
# config/paperclip.yml

produktion: &produktion
    lagring: :s3
    hink:  
    url:     ":s3_domän_url"
    sökväg:    ":class/:attachment/:id_partition/:style/:filename.:extension"

staging: *produktion

På samma sätt som AWS-legitimationsuppgifter anses bucket-namnet också vara ett hemligt värde som bör lagras utanför din kodbas. Jag rekommenderar att du lagrar dess namn i miljövariabeln.

Slutligen sammanfogar du konfigurationen till Paperclips standardalternativ i en initialiserare:

# config/initializers/paperclip.rb

paperclip_defaults = Rails.application.config_for :paperclip
paperclip_defaults.symbolize_keys!

Paperclip::Attachment.default_options.merge! paperclip_defaults

Löpning fakes3

Både AWS- och Paperclip-konfigurationerna innehåller en referens till den lokala S3-fakeservern som förväntas köras under lokalhost:10001. Innan du arbetar med utveckling bör du starta servern med följande kommando (tillhandahålls av FakeS3 gem):

fakes3 -r public/system -p 10001

Godkända parametrar är:

Om du använder Foreman för processhantering i ditt program kan det vara lämpligt att lägga till följande post i Procfile:

# Procfile

fakes3: fakes3 -r ${FAKES3_STORAGE_PATH:-public/system} -p ${FAKES3_PORT:-10001}

Detta kommer att spara tid som går förlorad på att starta fakeserver varje gång du behöver utveckla några S3-relaterade funktioner.

Slutsats

Vi har konfigurerat AWS-klienten för att delegera alla förfrågningar till lokal fakeserver, ställa in Paperclip för att använda falsk S3-slutpunkt i byggda resursers webbadresser och lanserat fakeserver som tillhandahålls av Fake S3 gem som lagrar alla filer i lokalt filsystem.

Resultatet blev att vi blev oberoende av internetanslutning och sparade pengar genom att göra vår utveckling snabbare och mer tillförlitlig.

sv_SESwedish