logo
  • Proces
  • Case studies
  • Blog
  • O nas
Napisz do nas
  1. Strona główna

  2. /

    Blog

  3. /

    Co to jest CQRS?

Co to jest CQRS?

Back-end

8 minut czytania

Tomasz Kozon

30 lis 2023

nodejs

net

docker

kubernetes

CQRS, zsynchronizowany skrót od Command Query Responsibility Segregation to zaawansowane podejście architektoniczne, które dekomponuje czytanie i zapis danych na oddzielne modele. Ten artykuł zgłębi tajniki CQRS, pokazując jak prawidłowo zrozumieć i efektywnie zastosować ten wzorzec w różnych typach aplikacji.

Spis treści

Historia i ewolucja CQRS

Komenda i zapytanie: Dwa filary CQRS

Zrozumienie Command and Query Responsibility Segregation: Przykłady

Kiedy warto zastosować CQRS? Scenariusze użycia

Zalety i ograniczenia implementacji CQRS

CQRS w kontekście mikrousług

CQRS a inne wzorce projektowe: Porównanie i kontrasty

Najczęstsze błędy i wyzwania przy wdrażaniu CQRS

Narzędzia i technologie wspierające implementację CQRS

FAQ – najczęstsze pytania dotyczące CQRS

CQRS, Command Query Responsibility Segregation,

Powiązane oferty pracy

Full-Stack JS Developer (Node + React)

B2B:

8000 - 13000 PLN netto +VAT

Pokaż wszystkie oferty

Powiązane case studies

SAO Life - aplikacja lojalnościowa dla klientów marki premium

Mobile development, Web development

Automatyzacja procesu wynajmu kontenerów i self-storage dla Balticon S.A.

Web development, UX/UI, E-commerce, SEO

Pokaż wszystkie case study

CQRS, czyli Command Query Responsibility Segregation, to wzorzec projektowy w architekturze oprogramowania zakładający rozdzielenie funkcji odczytu (Query) od zapisu (Command) w systemie informatycznym. Głównym celem jego implementacji jest poprawa wydajności poprzez dedykowane, niezależne obsługiwanie zapytań i operacji, co pozwala na optymalizację każdej z tych części systemu w sposób niezależny. Dodatkowo, wzorzec CQRS sprzyja rozdzieleniu odpowiedzialności oraz tworzeniu modularnych, łatwiejszych do utrzymania i testowania aplikacji. Jego zrozumienie i prawidłowe zastosowanie może być kluczowe dla skuteczności i efektywności rozwiązania informatycznego.

 

Historia i ewolucja CQRS

Command Query Responsibility Segregation, to wzorzec architektoniczny, który zyskał popularność w ciągu ostatnich dwóch dekad, ale jego korzenie sięgają jeszcze dalej. Wprowadzenie CQRS do głównego nurtu architektury oprogramowania można przypisać kilku kluczowym postaciom i wydarzeniom.

Początki i kontekst:

W latach 90-tych i na początku 2000-tych, rozwój oprogramowania zaczął coraz bardziej koncentrować się na skalowalności, wydajności i złożoności systemów. Systemy oparte na klasycznym podejściu, które traktowały operacje zapisu i odczytu w sposób jednorodny, zaczęły napotykać ograniczenia w kontekście rosnącej liczby użytkowników i wymagań biznesowych. To wyzwanie zainspirowało rozwój różnych wzorców architektonicznych, w tym CQRS.

Formalizacja CQRS:

Chociaż elementy CQRS były obecne w różnych formach już wcześniej, formalne wprowadzenie wzorca do szerszej dyskusji miało miejsce około 2009 roku. Wtedy to Greg Young, jeden z pionierów CQRS, zaczął popularyzować ten wzorzec, szczególnie poprzez swoje wystąpienia i artykuły. Greg Young zidentyfikował, że rozdzielenie odpowiedzialności za operacje zapisu i odczytu może znacznie poprawić wydajność i skalowalność systemów.

Rozwój i adaptacja:

Z czasem CQRS stał się coraz bardziej powszechny w środowisku deweloperskim. Jego zastosowanie zostało wspierane przez rozwój innych wzorców i technologii, takich jak Event Sourcing, który naturalnie łączy się z CQRS i pozwala na jeszcze bardziej zaawansowane zarządzanie stanem i historią zmian w systemach. Event Sourcing, który przechowuje każde zdarzenie zmieniające stan systemu, idealnie uzupełnia koncepcję CQRS, umożliwiając bardziej elastyczne i skalowalne podejście do zarządzania danymi.

Przykłady zastosowań:

W miarę jak wzorzec CQRS zyskiwał na popularności, wiele organizacji zaczęło wdrażać go w swoich projektach, zwłaszcza w przypadkach, gdzie wymagana była wysoka skalowalność i złożoność systemu. Firmy takie jak Microsoft, Amazon czy Netflix zaczęły dokumentować swoje doświadczenia z CQRS, co przyczyniło się do dalszej popularyzacji i zrozumienia tego wzorca w środowisku profesjonalnym.

Ewolucja i współczesne trendy:

Dziś CQRS jest szeroko uznawany za jedno z kluczowych podejść w architekturze oprogramowania, zwłaszcza w kontekście systemów rozproszonych i mikroserwisów. Współczesne implementacje CQRS często łączą go z nowoczesnymi technologiami chmurowymi i platformami do zarządzania danymi, co pozwala na efektywne zarządzanie złożonością i wydajnością. Wzorzec ten ewoluuje dalej, adaptując się do zmieniających się potrzeb i technologii, takich jak Kubernetes czy różne bazy danych NoSQL.

 

Czy szukasz wykonawcy projektów IT ?
logo
Sprawdź case studies

Komenda i zapytanie: Dwa filary CQRS

Komenda i zapytanie, dwie fundamentalne koncepcje wyłaniające się ze struktury CQRS, dzielą aplikację na dwie niezależne części: jedną do zapisu danych (Command) oraz drugą do odczytu (Query). Komenda jest odpowiedzialna za wszystkie operacje modyfikujące stan aplikacji, czyli wszelkie akcje zapisu - dodawanie, usuwanie czy edycja danych. Z kolei zapytanie to obszar zadedykowany do odczytu danych. Taka segregacja pozwala na optymalizację każdej z części pod kątem jej specyficznych wymagań. Pomaga to zwiększyć wydajność oraz skalowalność aplikacji, pozwalając na skoncentrowanie się na poszczególnych aspektach bez ingerencji w całość systemu.

 

Zrozumienie Command and Query Responsibility Segregation: Przykłady

Zrozumienie Command and Query Responsibility Segregation staje się niezwykle proste, gdy zastosujemy do tego kilka praktycznych przykładów. Przyjmijmy, że mamy sklep internetowy. Komendy w tym kontekście to czynności takie jak dodanie produktu do koszyka czy złożenie zamówienia. Zapytania natomiast to akcje typu sprawdzenie stanu magazynowego danego produktu, wyświetlenie historii zamówień użytkownika. Każda z tych czynności to albo komenda, albo zapytanie - istota CQRS. Systemy oparte na tej koncepcji są łatwiejsze w utrzymaniu i rozbudowie, ponieważ oddzielają one obsługę operacji modyfikujących stan systemu (komendy) od operacji odczytujących informacje (zapytania).

 

Kiedy warto zastosować CQRS? Scenariusze użycia

CQRS znajduje zastosowanie w systemach, które mają specyficzne wymagania dotyczące odczytu i zapisu danych. Jeśli operacje zapisu są rzadkie, ale wymagają dużej złożoności biznesowej, a jednocześnie odczyty muszą być szybkie i wydajne, CQRS może znacząco poprawić wydajność systemu. Jest to szczególnie przydatne w aplikacjach e-commerce, gdzie liczba zapytań o dostępność produktów jest wielokrotnie większa niż liczba zmian w stanie magazynu. Podobnie, w systemach bankowych czy giełdowych, gdzie przetwarzanie transakcji musi być dokładne, a jednocześnie raportowanie wymaga agregacji dużych ilości danych, rozdzielenie odpowiedzialności na modele odczytu i zapisu może poprawić stabilność systemu. CQRS świetnie sprawdza się także w architekturze mikrousług, pozwalając na lepszą skalowalność poszczególnych komponentów. Warto jednak pamiętać, że w prostych aplikacjach jego wdrożenie może być niepotrzebnie skomplikowane i prowadzić do zwiększonego kosztu utrzymania. Przed jego implementacją należy dokładnie przeanalizować wymagania biznesowe i techniczne systemu, aby uniknąć niepotrzebnej komplikacji architektury.

CQRS, Command Query Responsibility Segregation,

Zalety i ograniczenia implementacji CQRS

CQRS, posiada szereg zalet, które przyciągają twórców systemów o złożonej strukturze. Pozwala między innymi na niezależną skalowalność komend i zapytań, co jest szczególnie pomocne w systemach, gdzie obciążenie jest nierówno rozłożone. Polaryzacja tej odpowiedzialności zapewnia także wyższą elastyczność podczas projektowania systemu i łatwiejszą implementację nowych funkcji. Ograniczenia CQRS wynikają przede wszystkim z jej złożoności. Jego implementacja jest znacznie bardziej skomplikowana od tradycyjnych podejść i wymaga doświadczonego zespołu programistów. Ponadto, zastosowanie CQRS może prowadzić do zwiększonych kosztów utrzymania i trudności z synchronizacją stanów między modelami zapytań i komend.

 

CQRS w kontekście mikrousług

Zastosowanie wzorca CQRS w architekturze mikrousług otwiera nowe możliwości dla efektywnego zarządzania złożonymi systemami. W środowisku mikrousług, gdzie każda usługa jest odpowiedzialna za określoną funkcjonalność lub zestaw danych, CQRS naturalnie komponuje się z tą modularnością, pozwalając na oddzielenie operacji zapisu (poleceń) od operacji odczytu (zapytań). Ta separacja nie tylko przyczynia się do zwiększenia wydajności i skalowalności poprzez optymalizację baz danych i zasobów dla różnych rodzajów operacji, ale także ułatwia zarządzanie spójnością danych w rozproszonych systemach. Ponadto, wykorzystanie CQRS w mikrousługach pozwala na bardziej elastyczne podejście do zarządzania transakcjami i zwiększa odporność systemu na błędy, co jest kluczowe w rozległych, rozproszonych środowiskach. Poprzez stosowanie CQRS, zespoły deweloperskie mogą lepiej zarządzać złożonością systemów mikrousługowych, co przekłada się na wyższą jakość usług i lepszą wydajność całej architektury.

 

CQRS a inne wzorce projektowe: Porównanie i kontrasty

Command Query Responsibility Segregation wyróżnia się na tle innych wzorców projektowych unikalnym podejściem do segregacji operacji odczytu i zapisu danych. W przeciwieństwie do tradycyjnych wzorców, takich jak MVC (Model-View-Controller) czy CRUD (Create, Read, Update, Delete), które nie rozróżniają między operacjami odczytu i zapisu na poziomie architektonicznym, CQRS wprowadza wyraźny podział, przypisując osobne modele do każdego z tych typów operacji. Dzięki temu, systemy oparte na CQRS mogą być bardziej skalowalne i łatwiejsze w utrzymaniu, zwłaszcza w złożonych środowiskach, gdzie operacje odczytu znacznie przewyższają operacje zapisu. Ten podział umożliwia również optymalizację wydajności poprzez niezależne skalowanie warstw odczytu i zapisu. Z kolei w przypadku wzorców jak Event Sourcing, który często współpracuje z CQRS, nacisk kładziony jest na rejestrowanie zmian w stanie aplikacji jako sekwencji zdarzeń, co stanowi inny mechanizm zarządzania stanem niż tradycyjne aktualizacje bazy danych. Choć CQRS oferuje znaczące korzyści w odpowiednich kontekstach, jego implementacja może być bardziej złożona i wymagać głębszego zrozumienia dominującej logiki biznesowej, co stanowi kontrast do bardziej bezpośrednich podejść, jakie oferują inne wzorce projektowe.

CQRS

Najczęstsze błędy i wyzwania przy wdrażaniu CQRS

Choć CQRS jest potężnym wzorcem architektonicznym, jego wdrożenie niesie ze sobą wyzwania i ryzyko popełnienia błędów. Jednym z najczęstszych problemów jest nadmierna komplikacja systemu – CQRS nie jest rozwiązaniem uniwersalnym i jego użycie w prostych aplikacjach może prowadzić do niepotrzebnego narzutu technicznego oraz utrudnić rozwój. Innym wyzwaniem jest zapewnienie spójności danych między modelem zapisu a modelem odczytu. W systemach opartych na Event Sourcing może to prowadzić do problemów z propagacją zdarzeń i koniecznością zarządzania ich wersjonowaniem.

Dodatkowo, synchronizacja modeli może generować opóźnienia, co wymaga implementacji strategii obsługi danych w stanie eventual consistency (spójności ostatecznej). Źle zaprojektowana architektura może także prowadzić do zbyt dużego rozdrobnienia kodu, co utrudnia jego utrzymanie. Błędem jest również brak odpowiednich mechanizmów obsługi błędów i monitorowania zdarzeń, co może powodować trudności w diagnozowaniu problemów w działającym systemie. Aby uniknąć tych pułapek, wdrażanie CQRS powinno być poprzedzone dokładną analizą wymagań oraz testami koncepcyjnymi, które pozwolą ocenić, czy rzeczywiście przyniesie korzyści w danym przypadku.

 

Narzędzia i technologie wspierające implementację CQRS

Implementacja wzorca Command Query Responsibility Segregation jest wspierana przez szereg narzędzi i technologii, które ułatwiają zarządzanie oddzielnymi ścieżkami dla operacji zapisu (komend) i odczytu (zapytań). Frameworki takie jak Axon i MediatR w środowisku .NET, czy CQRS Kit i Node-CQRS w Node.js, oferują gotowe mechanizmy do definiowania i obsługi komend oraz zapytań, wraz z potrzebnym wsparciem dla event sourcing. Dla systemów opartych na mikrousługach, narzędzia takie jak Kafka mogą być wykorzystane do efektywnego zarządzania komunikacją i przepływem zdarzeń między różnymi częściami systemu. Bazy danych, które naturalnie wspierają modelowanie oparte na zdarzeniach lub są zoptymalizowane pod kątem szybkich odczytów, takie jak Event Store czy Apache Cassandra, również są kluczowe dla efektywnej implementacji CQRS. Dodatkowo, konteneryzacja i orkiestracja za pomocą narzędzi takich jak Docker i Kubernetes mogą pomóc w skalowaniu i zarządzaniu złożonymi środowiskami, które wykorzystują CQRS.

 

FAQ – najczęstsze pytania dotyczące CQRS

1. Co oznacza skrót CQRS?

CQRS to skrót od Command Query Responsibility Segregation, czyli Rozdzielenie odpowiedzialności za polecenia i zapytania.

2. Czym różni się CQRS od tradycyjnego podejścia CRUD?

W tradycyjnym podejściu (CRUD), ta sama warstwa obsługuje zarówno odczyty, jak i zapisy. W CQRS rozdziela się te dwie odpowiedzialności, co umożliwia niezależną optymalizację każdej z nich.

3. Kiedy warto używać CQRS?

CQRS sprawdza się w złożonych systemach, gdzie logika biznesowa dla zapisu i odczytu znacząco się różni, lub gdy wymagane są wysokie osiągi i skalowalność.

4. Czy CQRS zawsze idzie w parze z Event Sourcingiem?

Nie. CQRS i Event Sourcing mogą być stosowane razem, ale nie muszą. Można zaimplementować CQRS bez Event Sourcingu.

5. Jakie są zalety stosowania CQRS?

  • Lepsza separacja odpowiedzialności
  • Możliwość niezależnej skalowalności odczytu i zapisu
  • Większa elastyczność w projektowaniu modeli danych

6. Czy CQRS jest odpowiedni dla każdego projektu?

Nie. W prostych aplikacjach może wprowadzać niepotrzebną złożoność. CQRS ma sens głównie tam, gdzie złożoność systemu to uzasadnia.

7. Jak wygląda implementacja CQRS w praktyce?

W praktyce używa się oddzielnych modeli i warstw dla zapytań (Query) i poleceń (Command), często też różnych baz danych lub schematów danych.

8. Jakie technologie wspierają CQRS?

CQRS można wdrożyć w wielu językach i frameworkach – np. .NET, Java, Node.js. Pomocne są też biblioteki typu MediatR, Axon Framework czy MassTransit.

Nasza oferta

Web development

Dowiedz się więcej

Mobile development

Dowiedz się więcej

E-commerce

Dowiedz się więcej

Projektowanie UX/UI

Dowiedz się więcej

Outsourcing

Dowiedz się więcej

SEO

Dowiedz się więcej

Powiązane artykuły

Commerce as a Service: Przyszłość e-commerce w modelu chmurowym

2 paź 2025

E-commerce przechodzi obecnie jedną z największych transformacji od czasu swojego powstania. Tradycyjne, monolityczne platformy sprzedażowe ustępują miejsca rozwiązaniom chmurowym, które oferują elastyczność i szybkość działania. Commerce as a Service (CaaS) to nowy model, który pozwala firmom budować własny ekosystem sprzedaży w oparciu o modułowe usługi dostępne przez API.

Tomasz Kozon

#back-end

related-article-image-Commerce as a Service

Architektura MACH – co to jest i jak działa?

27 wrz 2025

Transformacja cyfrowa sprawia, że tradycyjne, monolityczne systemy informatyczne coraz częściej okazują się niewystarczające. Firmy potrzebują elastycznych i skalowalnych rozwiązań, które pozwolą im szybciej reagować na zmieniające się oczekiwania klientów. Odpowiedzią na te wyzwania jest architektura MACH – nowoczesne podejście do projektowania aplikacji i platform cyfrowych.

Tomasz Kozon

#fullstack

Hono - lekki framework webowy

23 wrz 2025

W świecie web developmentu coraz większą popularność zyskują rozwiązania lekkie, szybkie i proste w implementacji. Jednym z nich jest Hono - nowoczesny framework webowy, który łączy minimalizm z imponującą wydajnością. Dzięki wsparciu dla środowisk serverless i edge computing pozwala tworzyć aplikacje działające błyskawicznie, nawet przy dużym obciążeniu. To narzędzie, które idealnie wpisuje się w potrzeby współczesnych deweloperów poszukujących efektywnych i elastycznych rozwiązań backendowych.

Tomasz Kozon

#fullstack

Zero Trust Architecture: Rozwiązanie na ograniczenia tradycyjnych systemów zabezpieczeń

17 wrz 2025

Architektura Zero Trust to nowoczesne podejście do bezpieczeństwa sieciowego, które obiecuje przełamać bariery tradycyjnych systemów zabezpieczeń. 'Nie ufaj nikomu' - to dewiza, prezentując alternatywę dla rozwiązań opartych na starym modelu 'ufaj, ale weryfikuj'. Czy to jest odpowiedź na narastające ograniczenia starych systemów? Rozważmy to szczegółowo.

Tomasz Kozon

#security

Convex – rewolucja w tworzeniu aplikacji w czasie rzeczywistym

10 wrz 2025

W świecie, w którym użytkownicy oczekują natychmiastowych reakcji i płynnej interakcji, tworzenie aplikacji w czasie rzeczywistym staje się nie tylko wyzwaniem, ale i koniecznością. Convex to nowoczesna platforma backendowa, która upraszcza ten proces, łącząc synchronizację danych, logikę biznesową i skalowalność w jednym ekosystemie. Dzięki niej deweloperzy mogą budować interaktywne aplikacje bez konieczności konfigurowania skomplikowanej infrastruktury czy zarządzania WebSocketami.

Tomasz Kozon

#back-end

Multi-CDN: Jak zwiększyć wydajność i niezawodność Twojej strony

6 wrz 2025

Innowacyjne rozwiązania dla usprawnienia pracy stron internetowych nieustannie zyskują na popularności. Takim jest Multi-CDN - technologia, która może znacząco poprawić wydajność i niezawodność Twojego serwisu. Przełomowy, lecz jeszcze nie w pełni rozpoznany, ten system możemy wykorzystać do osiągnięcia znacznie lepszych wyników. Zatem, jak działają Multi-CDN? Jakie korzyści przynosi ich stosowanie?

Tomasz Kozon

#devops

Security as Code: fundamenty bezpiecznego DevOps

4 wrz 2025

W świecie IT bezpieczeństwo jest kluczowym aspektem każdego procesu deweloperskiego. W dobie przyspieszającej cyfryzacji, zapewnienie bezpieczeństwa należy do kluczowych obowiązków każdego dewelopera. Bezpieczeństwo, jak każda inna funkcjonalność, również może być kodowane. Poruszając temat 'Bezpieczeństwa jako Kod: Podstawy Bezpiecznego DevOps' wnioskujemy, że istotne jest łączenie praktyk DevOps z najlepszymi praktykami z zakresu bezpieczeństwa.

Tomasz Kozon

#devops

Zobacz wszystkie artykuły powiązane z #Back-end

Napisz do nas

Zadzwoń

Znajdź nas

Newsletter
social iconsocial iconsocial iconsocial iconsocial icon
logo

Oferta

  • Web Development

  • Mobile Development

  • UI/UX Design

  • E-commerce

  • Outsourcing

  • SEO

Menu

  • O nas

  • Case studies

  • FAQ

  • Blog

  • Kariera

  • Kontakt

© 2025 - Boring Owl - Software House Warszawa

adobexd logo

adobexd

algolia logo

algolia

amazon-s3 logo

amazon-s3

android logo

android

angular logo

angular

api logo

api

apscheduler logo

apscheduler

argocd logo

argocd

astro logo

astro

aws-amplify logo

aws-amplify

aws-cloudfront logo

aws-cloudfront

aws-lambda logo

aws-lambda

axios logo

axios

azure logo

azure

bash logo

bash

bootstrap logo

bootstrap

bulma logo

bulma

cakephp logo

cakephp

celery logo

celery

chartjs logo

chartjs

clojure logo

clojure

cloudflare logo

cloudflare

cloudinary logo

cloudinary

cms logo

cms

cobol logo

cobol

contentful logo

contentful

coolify logo

coolify

cpython logo

cpython

css3 logo

css3

django logo

django

django-rest logo

django-rest

docker logo

docker

drupal logo

drupal

dynamodb logo

dynamodb

elasticsearch logo

elasticsearch

electron logo

electron

expo-io logo

expo-io

express-js logo

express-js

fakerjs logo

fakerjs

fastapi logo

fastapi

fastify logo

fastify

figma logo

figma

firebase logo

firebase

flask logo

flask

flutter logo

flutter

gatsbyjs logo

gatsbyjs

ghost-cms logo

ghost-cms

google-cloud logo

google-cloud

graphcms logo

graphcms

graphql logo

graphql

groovy logo

groovy

gtm logo

gtm

gulpjs logo

gulpjs

hasura logo

hasura

headless-cms logo

headless-cms

heroku logo

heroku

html5 logo

html5

httpie logo

httpie

i18next logo

i18next

immutablejs logo

immutablejs

imoje logo

imoje

ios logo

ios

java logo

java

javascript logo

javascript

jekyll logo

jekyll

jekyll-admin logo

jekyll-admin

jenkins logo

jenkins

jquery logo

jquery

json logo

json

keras logo

keras

keystone5 logo

keystone5

kotlin logo

kotlin

kubernetes logo

kubernetes

laravel logo

laravel

lodash logo

lodash

magento logo

magento

mailchimp logo

mailchimp

material-ui logo

material-ui

matlab logo

matlab

maven logo

maven

miro logo

miro

mockup logo

mockup

momentjs logo

momentjs

mongodb logo

mongodb

mysql logo

mysql

nestjs logo

nestjs

net logo

net

netlify logo

netlify

next-js logo

next-js

nodejs logo

nodejs

npm logo

npm

nuxtjs logo

nuxtjs

oracle logo

oracle

pandas logo

pandas

php logo

php

postgresql logo

postgresql

postman logo

postman

prestashop logo

prestashop

prettier logo

prettier

prisma logo

prisma

prismic logo

prismic

prose logo

prose

pwa logo

pwa

python logo

python

python-scheduler logo

python-scheduler

rabbitmq logo

rabbitmq

react-flow logo

react-flow

react-hook-form logo

react-hook-form

react-js logo

react-js

react-native logo

react-native

react-query logo

react-query

react-static logo

react-static

redis logo

redis

redux logo

redux

redux-persist logo

redux-persist

redux-saga logo

redux-saga

redux-thunk logo

redux-thunk

relume logo

relume

restful logo

restful

ruby-on-rails logo

ruby-on-rails

rust logo

rust

rxjs logo

rxjs

saleor logo

saleor

sanity logo

sanity

scala logo

scala

scikit-learn logo

scikit-learn

scrapy logo

scrapy

scrum logo

scrum

selenium logo

selenium

sentry logo

sentry

shodan logo

shodan

shopify logo

shopify

slack logo

slack

sms-api logo

sms-api

socket-io logo

socket-io

solidity logo

solidity

spring logo

spring

sql logo

sql

sql-alchemy logo

sql-alchemy

storyblok logo

storyblok

storybook logo

storybook

strapi logo

strapi

stripe logo

stripe

structured-data logo

structured-data

struts logo

struts

styled-components logo

styled-components

supabase logo

supabase

svelte logo

svelte

swagger logo

swagger

swift logo

swift

symfony logo

symfony

tailwind-css logo

tailwind-css

tensorflow logo

tensorflow

terraform logo

terraform

threejs logo

threejs

twig logo

twig

typescript logo

typescript

vercel logo

vercel

vue-js logo

vue-js

webflow logo

webflow

webpack logo

webpack

websocket logo

websocket

woocommerce logo

woocommerce

wordpress logo

wordpress

yarn logo

yarn

yii logo

yii

zend logo

zend

zeplin logo

zeplin

zustand logo

zustand

Zobacz więcej