PlanetScale atteint la limite avec un pilote sans serveur

PlanetScale a publié une nouvelle fonctionnalité qui rend sa base de données plus facilement accessible à partir de déploiements de périphérie sans serveur.

Un paradigme de déploiement émergent pour les applications consiste à utiliser des services de périphérie sans serveur, tels que Cloudflare Workers, Vercel Edge Functions et Netlify Edge Functions. Ces services sont largement basés sur JavaScript et permettent aux organisations d’exécuter des applications à la périphérie d’un réseau.

Un défi à ce jour avec les services de périphérie a été la couche de base de données, où se trouve le pilote sans serveur PlanetScale, publié le 1er août. 18 ans, s’intègre. Le pilote crée une nouvelle couche dans la base de données PlanetScale qui permet des requêtes via JavaScript dans une approche qui peut s’intégrer aux plates-formes de déploiement en périphérie.

PlanetScale cible le déploiement de bases de données pilotées par les développeurs, un domaine dans lequel il est en concurrence avec le fournisseur de bases de données sans serveur FaunaDB, qui est également accessible via JavaScript.

Parmi les utilisateurs de la base de données PlanetScale qui cherchent à utiliser le pilote sans serveur PlanetScale se trouve le service d’actualités sportives et de culture populaire en ligne Barstool Sports.

La société fonctionnait sur Amazon Aurora pour ses charges de travail de base de données MySQL et a rencontré des problèmes de mise à l’échelle et de performances, a déclaré Andrew Barba, responsable de l’ingénierie chez Barstool Sports.

Amazon Aurora, comme PlanetScale, est destiné à être compatible avec MySQL. En 2021, Barstool est passé à PlanetScale après que le fournisseur de bases de données a lancé son offre de base de données en tant que service entièrement gérée.

Le nouveau pilote sans serveur PlanetScale est un développement particulièrement notable pour Barstool. Ces dernières années, il y a eu une tendance croissante des organisations à déplacer le calcul aussi près que possible des utilisateurs – la périphérie. Barstool attend avec impatience le pilote sans serveur PlanetScale pour JavaScript, alors que Barstool continue de développer et d’optimiser ses opérations, a déclaré Barba.

Semblable à la façon dont le calcul déplace la périphérie, il est temps que les bases de données se déplacent également vers la périphérie.

André BarbaResponsable de l’ingénierie, Barstool Sports

“De la même manière que le calcul déplace la périphérie, il est temps que les bases de données se déplacent également vers la périphérie”, a déclaré Barba.

Le pilote sans serveur PlanetScale active l’API JavaScript

Avec une pile d’applications traditionnelle qui s’exécute sur un serveur, un développeur aurait accès à un ensemble complet d’API permettant des connexions à n’importe quelle base de données.

Les services périphériques sans serveur utilisent des runtimes JavaScript et WebAssembly qui n’ont pas le même accès que les piles d’applications traditionnelles. Les environnements de périphérie sans serveur ont troqué l’accès complet à l’API pour la vitesse et la sécurité, a déclaré Nick Van Wiggeren, vice-président de l’ingénierie chez PlanetScale.

Les services Edge, y compris Cloudflare Workers, ont fourni aux utilisateurs des solutions de contournement quelque peu compliquées pour se connecter à différents types de bases de données, a noté Van Wiggeren. PlanetScale souhaitait fournir un mécanisme pour les services de périphérie qui fonctionnerait avec n’importe quel service de périphérie et serait facile à configurer.

Pour PlanetScale, la partie la plus difficile de la création du pilote sans serveur consistait à trouver comment exposer toutes les fonctionnalités de la base de données avec une API qui se connecte via HTTP. C’est un processus qui a pris environ six mois à PlanetScale pour développer les capacités de la base de données et de son infrastructure de plate-forme.

“Nous avons commencé et réalisé que nous avions réellement besoin d’un nouvel équilibreur de charge, une nouvelle porte d’entrée dans la base de données qui peut répondre aux requêtes via HTTP”, a déclaré Van Wiggeren. “Nous n’étions pas disposés à faire des compromis sur la sécurité ou les fonctionnalités, nous avons donc construit et architecturé à partir de zéro, notre propre équilibreur de charge HTTP pour les bases de données MySQL.”

Fonctionnement du pilote sans serveur PlanetScale avec JavaScript

Le nouvel équilibreur de charge pour le traitement des demandes de base de données HTTP n’est qu’une partie de l’activation des capacités de périphérie sans serveur ; l’autre élément clé est JavaScript.

Le pilote actuel du nouveau service PlanetScale utilise la norme Fetch API en JavaScript pour activer les connexions HTTP. La nature multiplateforme de Fetch est la raison pour laquelle PlanetScale l’utilise, a déclaré Van Wiggeren, ajoutant que le pilote sans serveur PlanetScale est essentiellement un wrapper autour de l’API Fetch qui gère tous les composants de requête de base de données, en utilisant Fetch pour se connecter à la base de données via HTTP.

“La raison pour laquelle nous sommes si spécifiques à propos de Fetch est que c’est ce qui est multiplateforme – que vous utilisiez JavaScript dans le navigateur, que vous utilisiez JavaScript sur Cloudflare Worker ou une fonction Vercel Edge, Fetch est la norme pour comment vous faites cette demande », a-t-il dit.

À l’avenir, il y a encore des domaines que PlanetScale pourrait chercher à aborder en termes de connectivité API. Un de ces domaines pourrait être GraphQL, une autre approche API pour connecter et interroger des données.

“C’est un domaine qui nous intéresse vraiment”, a déclaré Van Wiggeren à propos de GraphQL. “C’est définitivement une façon attrayante et, je pense, très intéressante pour les gens d’exploiter leurs bases de données.”

Leave a Comment