AWS - MSK Enum
Amazon MSK
Amazon Managed Streaming for Apache Kafka (Amazon MSK) is 'n diens wat ten volle bestuur word en die ontwikkeling en uitvoering van toepassings wat stroomdata verwerk deur Apache Kafka fasiliteer. Amazon MSK bied beheervlak-operasies aan, insluitend die skep, opdateer en verwyder van klusters. Die diens maak die gebruik van Apache Kafka data-vlak-operasies moontlik, wat data-produksie en -verbruik insluit. Dit werk met open-source weergawes van Apache Kafka, wat verseker dat dit versoenbaar is met bestaande toepassings, gereedskap en invoegtoepassings van beide vennote en die Apache Kafka-gemeenskap, sonder die nodigheid van veranderinge in die toepassingskode.
Wat betroubaarheid betref, is Amazon MSK ontwerp om outomaties algemene klusterfoute te detecteer en te herstel, om te verseker dat produsent- en verbruikertoepassings voortgaan met hul data-skryf- en leesaktiwiteite met minimale onderbreking. Verder streef dit daarna om data-replikasieprosesse te optimaliseer deur te probeer om die stoorplek van vervangen makelaars te hergebruik, wat die hoeveelheid data wat deur Apache Kafka gerepliseer moet word, verminder.
Tipes
Daar is 2 tipes Kafka-klusters wat AWS toelaat om te skep: Provisioned en Serverless.
Vanuit die oogpunt van 'n aanvaller moet jy weet dat:
Serverless kan nie direk openbaar wees (dit kan slegs in 'n VPN loop sonder enige openbaar blootgestelde IP). Tog kan Provisioned gekonfigureer word om 'n openbare IP te kry (standaard nie) en die sekuriteitsgroep te konfigureer om die relevante poorte bloot te stel.
Serverless ondersteun slegs IAM as verifikasiemetode. Provisioned ondersteun SASL/SCRAM (wagwoord) verifikasie, IAM verifikasie, AWS Certificate Manager (ACM) verifikasie en Ongeverifieerde toegang.
Let daarop dat dit nie moontlik is om 'n Provisioned Kafka openbaar bloot te stel as ongeverifieerde toegang geaktiveer is nie.
Enumerasie
Kafka IAM Toegang (in serverless)
Beschrijving
Kafka IAM-toegang (Identity and Access Management) is een methode om toegangscontrole in te stellen voor Kafka-clusters in een serverloze omgeving. Met IAM kunnen beheerders de rechten en machtigingen van gebruikers beheren om toegang te krijgen tot Kafka-topics en -bronnen.
Mogelijke aanvallen
Onjuiste IAM-rollen: Als er onjuiste IAM-rollen zijn geconfigureerd, kan een aanvaller mogelijk toegang krijgen tot Kafka-topics en -bronnen die ze normaal gesproken niet zouden moeten hebben.
Onjuiste machtigingen: Als een gebruiker onjuiste machtigingen heeft toegewezen gekregen, kan deze mogelijk gevoelige gegevens lezen, schrijven of verwijderen van Kafka-topics.
Aanbevolen beveiligingsmaatregelen
Minimale rechten: Wijs gebruikers alleen de minimale rechten toe die ze nodig hebben om hun taken uit te voeren. Beperk de toegang tot Kafka-topics en -bronnen tot wat strikt noodzakelijk is.
Regelmatige controle: Controleer regelmatig de IAM-rollen en machtigingen om ervoor te zorgen dat ze correct zijn geconfigureerd en dat er geen onjuiste toegang is verleend.
Sterke authenticatie: Implementeer sterke authenticatiemethoden, zoals het gebruik van multi-factor authenticatie (MFA), om ongeautoriseerde toegang tot IAM-accounts te voorkomen.
Logging en monitoring: Implementeer uitgebreide logging en monitoring om verdachte activiteiten te detecteren en te reageren op mogelijke inbreuken.
Voorbeeld
Hier is een voorbeeld van een IAM-beleid voor Kafka-toegang:
In dit voorbeeld heeft de gebruiker toestemming om Kafka-clusters te beschrijven, lijsten op te halen en gegevens op te halen. Ze hebben ook toestemming om specifieke acties uit te voeren op een specifiek Kafka-cluster met de opgegeven ARN (Amazon Resource Name).
Referenties
Privesc
AWS - MSK PrivescOngeverifieerde Toegang
AWS - MSK Unauthenticated EnumVolharding
As jy toegang het tot die VPC waar 'n Provisioned Kafka is, kan jy ongeverifieerde toegang aktiveer, as SASL/SCRAM-verifikasie gebruik word, die wagwoord uit die geheim lees, 'n ander beheerde gebruiker IAM-permissies gee (as IAM of serverless gebruik word) of volhard met sertifikate.
Verwysings
Last updated