5671,5672 - Pentesting AMQP
Reading time: 4 minutes
tip
Ucz się i ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się i ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Wsparcie HackTricks
- Sprawdź plany subskrypcyjne!
- Dołącz do 💬 grupy Discord lub grupy telegram lub śledź nas na Twitterze 🐦 @hacktricks_live.
- Dziel się trikami hackingowymi, przesyłając PR-y do HackTricks i HackTricks Cloud repozytoriów github.
Podstawowe informacje
Z cloudamqp:
RabbitMQ to oprogramowanie do kolejkowania wiadomości, znane również jako broker wiadomości lub menedżer kolejek. Mówiąc prosto; jest to oprogramowanie, w którym definiowane są kolejki, do których aplikacje łączą się w celu przesyłania wiadomości.
Wiadomość może zawierać wszelkiego rodzaju informacje. Może na przykład zawierać informacje o procesie lub zadaniu, które powinno rozpocząć się w innej aplikacji (która może być nawet na innym serwerze), lub może to być po prostu zwykła wiadomość tekstowa. Oprogramowanie menedżera kolejek przechowuje wiadomości, aż aplikacja odbierająca połączy się i pobierze wiadomość z kolejki. Aplikacja odbierająca następnie przetwarza wiadomość.
Definicja z .
Domyślny port: 5672,5671
PORT STATE SERVICE VERSION
5672/tcp open amqp RabbitMQ 3.1.5 (0-9)
Enumeracja
Ręczna
import amqp
#By default it uses default credentials "guest":"guest"
conn = amqp.connection.Connection(host="<IP>", port=5672, virtual_host="/")
conn.connect()
for k, v in conn.server_properties.items():
print(k, v)
Automatyczny
nmap -sV -Pn -n -T4 -p 5672 --script amqp-info <IP>
PORT STATE SERVICE VERSION
5672/tcp open amqp RabbitMQ 3.1.5 (0-9)
| amqp-info:
| capabilities:
| publisher_confirms: YES
| exchange_exchange_bindings: YES
| basic.nack: YES
| consumer_cancel_notify: YES
| copyright: Copyright (C) 2007-2013 GoPivotal, Inc.
| information: Licensed under the MPL. See http://www.rabbitmq.com/
| platform: Erlang/OTP
| product: RabbitMQ
| version: 3.1.5
| mechanisms: PLAIN AMQPLAIN
|_ locales: en_US
Brute Force
Inne porty RabbitMQ
W https://www.rabbitmq.com/networking.html można znaleźć, że rabbitmq używa kilku portów:
- 1883, 8883: (klienci MQTT bez i z TLS, jeśli włączony jest plugin MQTT. Dowiedz się więcej o tym, jak przeprowadzić pentesting MQTT tutaj.
- 4369: epmd, usługa odkrywania peerów używana przez węzły RabbitMQ i narzędzia CLI. Dowiedz się więcej o tym, jak przeprowadzić pentesting tej usługi tutaj.
- 5672, 5671: używane przez klientów AMQP 0-9-1 i 1.0 bez i z TLS
- 15672: HTTP API klienci, interfejs zarządzania i rabbitmqadmin (tylko jeśli włączony jest plugin zarządzania). Dowiedz się więcej o tym, jak przeprowadzić pentesting tej usługi tutaj.
- 15674: klienci STOMP-over-WebSockets (tylko jeśli włączony jest plugin Web STOMP)
- 15675: klienci MQTT-over-WebSockets (tylko jeśli włączony jest plugin Web MQTT)
- 15692: metryki Prometheus (tylko jeśli włączony jest plugin Prometheus)
- 25672: używany do komunikacji między węzłami i narzędziami CLI (port serwera dystrybucji Erlang) i jest przydzielany z dynamicznego zakresu (ograniczonego do jednego portu domyślnie, obliczonego jako port AMQP + 20000). O ile zewnętrzne połączenia na tych portach nie są naprawdę konieczne (np. klaster używa federacji lub narzędzia CLI są używane na maszynach poza podsiecią), te porty nie powinny być publicznie eksponowane. Zobacz przewodnik po sieciach po szczegóły. Tylko 9 z tych portów otwartych w internecie.
- 35672-35682: używane przez narzędzia CLI (porty klientów dystrybucji Erlang) do komunikacji z węzłami i przydzielane z dynamicznego zakresu (obliczone jako port dystrybucji serwera + 10000 przez port dystrybucji serwera + 10010). Zobacz przewodnik po sieciach po szczegóły.
- 61613, 61614: klienci STOMP bez i z TLS (tylko jeśli włączony jest plugin STOMP). Mniej niż 10 urządzeń z tym portem otwartym, głównie UDP dla węzłów DHT.
Shodan
AMQP
tip
Ucz się i ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się i ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Wsparcie HackTricks
- Sprawdź plany subskrypcyjne!
- Dołącz do 💬 grupy Discord lub grupy telegram lub śledź nas na Twitterze 🐦 @hacktricks_live.
- Dziel się trikami hackingowymi, przesyłając PR-y do HackTricks i HackTricks Cloud repozytoriów github.