Ich arbeite an einem persönlichen Projekt, das Benutzern dabei helfen soll, Musikkonzerte in Chicago zu finden. Ein bemerkenswerter Aspekt dieses Projekts aus architektonischer Sicht ist, dass die gesamte Webanwendung völlig kostenlos gehostet wird.
Das Bild unten zeigt die Architekturkomponenten:
Haftungsausschluss: Ich werde von keinem der hier erwähnten Dienste gesponsert; Ich hebe sie einfach deshalb hervor, weil ich sie nützlich fand.
GitHub ist die beliebteste Plattform zum kostenlosen Hosten Ihrer Codebasis. Ich habe auch Alternativen wie Bitbucket und GitLab ausprobiert und sie funktionieren genauso gut. Ehrlich gesagt reicht jede dieser Optionen aus – wählen Sie einfach eine aus und machen Sie weiter, ohne darüber nachzudenken.
In einem professionellen Umfeld arbeiten Sie normalerweise direkt mit AWS oder einem anderen Cloud-Service-Anbieter zusammen und haben so die volle Kontrolle über Bereitstellungen, Benachrichtigungen und Überwachung. Dieser Ansatz erfordert jedoch mehr Zeit und Aufwand. Glücklicherweise vereinfachen Dienste wie Netlify und Vercel diesen Prozess, indem sie einen Großteil der Reibung beseitigen. Sie ermöglichen eine schnelle Bereitstellung, sind jedoch von ihrem Ökosystem abhängig. Sobald Ihre Website erheblichen Traffic verzeichnet (Tausende Besuche), empfiehlt es sich, die Limits für die kostenlose Stufe zu überprüfen, um unerwartete Kosten zu vermeiden. Für persönliche Projekte habe ich diese Dienste bisher mehrmals ohne Probleme genutzt.
Dennoch bietet Netlify mehrere sofort einsatzbereite Funktionen. Im Architekturbild werden drei der Komponenten automatisch von Netlify bereitgestellt:
Mit der GUI von Netlify können Sie Ihr Codebasis-Repository integrieren – in meinem Fall GitHub. Netlify versteht die Standardeinstellungen für eine Next.js-Anwendung und verwendet sie, um den Code nahtlos bereitzustellen.
chicagomusiccompass.com ist eine statische Webanwendung, das heißt, es ist kein Server beteiligt. Wenn eine Bereitstellung ausgelöst wird, generiert die App statische Assets (HTML, JS und CSS), die in einem S3-Bucket gespeichert werden. Netlify übernimmt dann die Konfiguration mit CloudFront und stellt Ihnen eine gebrauchsfertige URL zur Verfügung.
Statische Websites müssen häufig Daten von anderen Domänen abrufen. Dies erfordert in der Regel einen Proxy, ein sogenanntes „Back End for Front End“ (BFF). Clientanwendungen haben standardmäßig keinen Zugriff auf andere Domänen, es sei denn, der Server erlaubt dies ausdrücklich über CORS, was nicht immer üblich ist. Für dieses Projekt verwende ich einen Proxy, um eine JSON-Datei aus einer anderen Domäne abzurufen.
Netlify verwaltet die gesamte Bereitstellungsorchestrierung und stellt eine URL (Subdomain) bereit, die Sie für eine benutzerfreundliche URL mit Ihrer Domain verknüpfen können.
Zum Beispiel ist dies die Netlify-URL für mein Projekt:
https://clinquant-chebakia-f64a5b.netlify.app/
Ich habe dann meine Domain mit einem CNAME-Eintrag konfiguriert, um www auf die Netlify-URL zu verweisen:
Wenn ein Benutzer https://www.chicagomusiccompass.com/ besucht, löst DNS die Domain in ihr endgültiges Ziel auf – die Netlify-URL ?.
Während hier viel passiert, wird das meiste davon über Dashboards (GUI) konfiguriert. Der Schlüssel liegt darin, zu verstehen, wie alles zusammenhängt. Der Rest ist nur das Navigieren in der Benutzeroberfläche.
cron-job.org ist ein Dienst, der es Ihnen ermöglicht, Cron-Jobs kostenlos auszuführen. So funktioniert es in diesem Setup:
a) Netlify Deploy Hook:
Netlify bietet einen konfigurierbaren Webhook (einen URL-Endpunkt), der bei Auslösung die Site erneut bereitstellt. Dadurch wird sichergestellt, dass chicagomusiccompass.com bei Bedarf automatisch aktualisiert werden kann.
b) cron-job.org-Integration:
Mit cron-job.org können Sie einen Cron-Job planen – in diesem Fall so einstellen, dass er täglich ausgeführt wird. Der Job löst einfach den Netlify-Bereitstellungs-Hook aus und veranlasst Netlify, die Site jeden Tag neu bereitzustellen (zu aktualisieren).
Hinweis: Während chicagomusiccompass.com auch Back-End-Komponenten hat, konzentriert sich dieser Beitrag ausschließlich auf die Front-End-Architektur.
chicagomusiccompass.com ist eine Next.js-Anwendung, die beim Erstellen eine statische Site (kein Server) zusammen mit einigen Lambda-Funktionen generiert. Das GitHub-Repository ist in Netlify integriert, sodass jeder Push an das Repository eine neue Bereitstellung auslöst. Dieser Prozess generiert eine neue Version der statischen Site und aktualisiert die Lambda-Funktionen. Netlify übernimmt die Bereitstellung dieser Dateien und stellt automatisch die erforderliche Netzwerkinfrastruktur bereit, um den Zugriff auf die Webanwendung über eine Subdomain zu ermöglichen. Darüber hinaus habe ich die benutzerdefinierte Domäne chicagomusiccompass.com so konfiguriert, dass sie auf Netlify verweist. Die Site wird durch einen täglichen Cron-Job auf dem neuesten Stand gehalten, der einen Netlify-Bereitstellungs-Hook auslöst.
Die Seite ist seit ein paar Monaten in Betrieb und erhält derzeit nicht viel Verkehr, aber in Bezug auf die Infrastrukturkosten zahle ich keinen Cent.
Im professionellen Umfeld wähle ich je nach Projektanforderungen möglicherweise eine ähnliche Lösung, insbesondere in der Anfangsphase. Später könnte ich bestimmte Komponenten migrieren, wenn das Unternehmen wächst und sich die Anforderungen ändern.
Front-End-Architektur ist heutzutage ziemlich spannend geworden, insbesondere wenn Sie kostenlose Dienste nutzen können. Denken Sie jedoch daran, dass wenn ein Service kostenlos ist, Sie möglicherweise das Produkt sind.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3