Wtyczka Kong
Wtyczka Konga obsługuje cztery wymiary, kolejność wykonania jest od góry do dołu, i należy zauważyć, że jeśli ta sama wtyczka jest skonfigurowana w różnych wymiarach, zostanie wykonana tylko raz:
- Zastosuj API plus zestaw konsumencki;
- Stosowane do konsumentów;
- Zastosowano w API;
- Stosowane globalnie;
Poza tym nie wszystkie wtyczki wspierają definiowanie konsumentów
Dodaj kolejne API do testowania Dodaj nowy interfejs:
{ "created_at": 1515055457572, "strip_uri": prawda, "ID": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "nazwa": "spring-boot-consul-service2", "Metody": [ "WYJDŹ" ], "http_if_terminated": fałsz, "preserve_host": fałsz, "upstream_url": "http://spring-boot-consul-service2.service.dc1.consul:17004", "Uris": [ "/user" ], "upstream_send_timeout": 60000, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "powtórzenia": 5, "https_only": fałszywe
}
Dodaj Steam
{ "created_at": 1515055993113, "lista zamówień": [ 41, 28, 44, 14, 79, 38, 30, 69, 15, 88, 72, 53, 89, 47, 81, 43, 60, 91, 92, 100, 98, 55, 12, 40, 9, 31, 84, 24, 36, 39, 96, 74, 6, 8, 93, 99, 78, 34, 49, 37, 61, 76, 33, 35, 32, 77, 70, 26, 52, 87, 73, 23, 57, 25, 17, 90, 62, 82, 19, 75, 50, 4, 51, 42, 65, 66, 63, 3, 1, 68, 94, 67, 20, 80, 54, 7, 5, 16, 85, 13, 46, 10, 97, 22, 48, 11, 27, 86, 18, 59, 83, 21, 56, 95, 2, 64, 58, 71, 45, 29 ], "ID": "6B8bc38A-D449-47bf-8b8c-19B888E282D4", "imię": "spring-boot-consul-service2.service.dc1.consul", "Sloty": 100
}
Dodaj cele
Informacje o tagetach
{ "całość": 3, "dane": [ { "created_at": 1515056103599, "ID": "994e7886-3e48-45CB-80AD-3f7918ede007", "upstream_id": "6B8bc38a-d449-47bf-8b8c-19b888e282d4", "cel": "192.168.0.186:17004", "waga": 15 }, { "created_at": 1515056109570, "ID": "03B477EE-A69D-49EE-9892-276F451C373C", "upstream_id": "6B8bc38a-d449-47bf-8b8c-19b888e282d4", "cel": "192.168.0.185:17004", "waga": 15 }, { "created_at": 1515056112730, "ID": "8ace8d83-4504-4334-ad04-f0b536963df9", "upstream_id": "6B8bc38a-d449-47bf-8b8c-19b888e282d4", "cel": "192.168.0.184:17004", "waga": 15 } ]
}
Obecna lista API przedstawia się następująco:
{ "całość": 2, "dane": [ { "created_at": 1515055457572, "strip_uri": prawda, "ID": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "nazwa": "spring-boot-consul-service2", "Metody": [ "WYJDŹ" ], "http_if_terminated": fałsz, "https_only": fałsz, "upstream_url": "http://spring-boot-consul-service2.service.dc1.consul:17004", "Uris": [ "/user" ], "preserve_host": fałsz, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "upstream_send_timeout": 60000, "próby": 5 }, { "created_at": 1514995615974, "strip_uri": prawda, "ID": "B8431831-6a77-434e-ac4a-7e379550714f", "nazwa": "sprężynowy but-konsul-służba", "Metody": [ "WYJDŹ" ], "http_if_terminated": fałsz, "https_only": fałsz, "upstream_url": "http://spring-boot-consul-service.service.dc1.consul:17003", "Uris": [ "/service" ], "preserve_host": fałsz, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "upstream_send_timeout": 60000, "próby": 5 } ]
}
Interfejsy dostępu zwracają następujące dane:
{ "msg": "ok", "date": { "wynik": 42, "imię": "drzewo", "id": 1, "wiek": 12, "terazTime": 1515060166929, "info": "/checkUser, host:192.168.0.186, service_id:application-1700417004" }, "Kod": 200
} { "msg": "ok", "date": { "wynik": 505, "imię": "drzewo", "id": 1, "wiek": 12, "terazTime": 1515060402392, "info": "/checkUser, host:192.168.0.184, service_id:application-1700317003" }, "Kod": 200
} Dodaj wtyczkę Key-Auth
Otwórz wtyczkę key-auth
{ "created_at": 1515066239000, "config": { "key_in_body": fałsz, "run_on_preflight": prawda, "anonim": "", "hide_credentials": fałsz, "key_names": [ "Apikey" ] }, "ID": "78c519d3-11f7-4cdf-b038-9f17f1a83427", "włączony": prawda, "api_id": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "Name": "key-auth"
} Następnie wejdź do interfejsu z błędem takim jak ten:
Usuń wtyczkę key-auth
Sprawdź wtyczkę API binding
Dodaj wtyczkę ograniczającą szybkość
Wyniki
{ "created_at": 1515068825000, "config": { "minuta": 10, "polityka": "klaster", "redis_timeout": 2000, "hide_client_headers": fałsz, "drugi": 2, "limit_by": "konsument", "redis_port": 6379, "redis_database": 0, "fault_tolerant": prawda }, "ID": "482C627f-4041-4320-9b2f-0cc7722b92ea", "nazwa": "ograniczający prędkość", "api_id": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "włączony": prawdziwe
} Gdy interfejs dostępu przekroczy limit, otrzymane zostaną następujące zwroty:
Powrót
{ "message": "Przekroczenie limitu prędkości API"
} Jednak nadal występują pewne problemy, ponieważ format wiadomości jest stały, format wyjściowy nie jest zgodny z usługą backendową, a niestandardowe formaty wiadomości muszą być wspierane.
Kong modyfikuje wartość zwrotu wyjątku Na przykład format zunifikowanej wiadomości usługi wygląda następująco:
{ "kod": 200, "msg": "ok", "data": {xxx}
} Chcemy też, aby zwrot wyjątków z Kong pozostał w tym samym formacie jak powyżej. Następnie możemy bezpośrednio modyfikować kod źródłowy Konga, co jest w rzeczywistości bardzo proste.
Zacznij od pobrania kodu źródłowego
#下载kong插件源码
git clonegit@github.com:Kong/kong.git
Zlokalizuj kod wyjściowy do modyfikacji
Kod wyjściowy znajduje się w kong/kong/tools/responses.lua, otwórz go do edycji.
Zapisz, a potem skompiluj
[root@tree81 Kong]# Luarocks robią kong 0.11.2-0 jest obecnie zainstalowany w /usr/local (licencja: MIT) Start, spróbuj ponownie
Szybko odświeżaj adres kilka razy z rzędu:Logowanie do linku jest widoczne.Otrzymuj komunikat o błędzie:
{ "kod": 429, "msg": "Przekroczenie limitu prędkości API"
} Gotowe, idealny :) |