Plugin Kong
O plugin do Kong suporta quatro dimensões, a ordem de execução é de cima para baixo, e vale notar que, se o mesmo plugin estiver configurado em dimensões diferentes, ele só será executado uma vez:
- Aplique a API mais a combinação de consumidores;
- Aplicado ao consumidor;
- Aplicado na API;
- Aplicado globalmente;
Além disso, nem todos os plugins suportam definir consumidores
Adicionar outra API para testes Adicione uma nova interface:
{ "created_at": 1515055457572, "strip_uri": verdade, "id": "a99919d1-0770-40a1-81a9-e3c31FD9d282", "nome": "cônsul-cônsul-de mola 2", "métodos": [ "SAI" ], "http_if_terminated": falso, "preserve_host": falso, "upstream_url": "http://spring-boot-consul-service2.service.dc1.consul:17004", "uris": [ "/usuário" ], "upstream_send_timeout": 60000, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "retentações": 5, "https_only": falso
}
Adicionar vapores
{ "created_at": 1515055993113, "Ordem de Lista": [ 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", "nome": "spring-boot-consul-service2.service.dc1.consul", "Slots": 100
}
Adicionar alvos
Informações sobre Tagets
{ "total": 3, "dados": [ { "created_at": 1515056103599, "id": "994e7886-3e48-45cb-80AD-3F7918ede007", "upstream_id": "6b8bc38a-d449-47bf-8b8c-19b888e282d4", "alvo": "192.168.0.186:17004", "peso": 15 }, { "created_at": 1515056109570, "id": "03b477ee-a69d-49ee-9892-276f451c373c", "upstream_id": "6b8bc38a-d449-47bf-8b8c-19b888e282d4", "alvo": "192.168.0.185:17004", "peso": 15 }, { "created_at": 1515056112730, "id": "8ace8d83-4504-4334-ad04-f0b536963df9", "upstream_id": "6b8bc38a-d449-47bf-8b8c-19b888e282d4", "alvo": "192.168.0.184:17004", "peso": 15 } ]
}
A lista atual de APIs é a seguinte:
{ "total": 2, "dados": [ { "created_at": 1515055457572, "strip_uri": verdade, "id": "a99919d1-0770-40a1-81a9-e3c31FD9d282", "nome": "cônsul-cônsul-de mola 2", "métodos": [ "SAI" ], "http_if_terminated": falso, "https_only": falso, "upstream_url": "http://spring-boot-consul-service2.service.dc1.consul:17004", "uris": [ "/usuário" ], "preserve_host": falso, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "upstream_send_timeout": 60000, "retentações": 5 }, { "created_at": 1514995615974, "strip_uri": verdade, "id": "b8431831-6a77-434e-ac4a-7e379550714f", "nome": "cônsul-bota-mola-serviço", "métodos": [ "SAI" ], "http_if_terminated": falso, "https_only": falso, "upstream_url": "http://spring-boot-consul-service.service.dc1.consul:17003", "uris": [ "/service" ], "preserve_host": falso, "upstream_connect_timeout": 60000, "upstream_read_timeout": 60000, "upstream_send_timeout": 60000, "retentações": 5 } ]
}
As interfaces de acesso retornam o seguinte:
{ "MSG": "OK", "data": { "pontuação": 42, "nome": "árvore", "id": 1, "Idade": 12, "nowTime": 1515060166929, "info": "/checkUser, host:192.168.0.186, service_id:application-1700417004" }, "código": 200
} { "MSG": "OK", "data": { "Pontuação": 505, "nome": "árvore", "id": 1, "Idade": 12, "nowTime": 1515060402392, "info": "/checkUser, host:192.168.0.184, service_id:application-1700317003" }, "código": 200
} Adicione o plugin Key-Auth
Abra o plugin de autenticação de tecla
{ "created_at": 1515066239000, "config": { "key_in_body": falso, "run_on_preflight": verdade, "anônimo": "", "hide_credentials": falso, "key_names": [ "apikey" ] }, "id": "78c519d3-11f7-4cdf-b038-9f17f1a83427", "habilitado": verdade, "api_id": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "nome": "key-auth"
} Depois, acesse a interface com um erro como este:
Remova o plugin de autenticação de teclas
Confira o plugin de vinculação de API
Adicionar o limite de taxa do plugin limitador de taxa
Saída
{ "created_at": 1515068825000, "config": { "minuto": 10, "política": "cluster", "redis_timeout": 2000, "hide_client_headers": falso, "segundo": 2, "limit_by": "consumidor", "redis_port": 6379, "redis_database": 0, "fault_tolerant": verdade }, "ID": "482C627F-4041-4320-9B2F-0cc7722B92EA", "nome": "limitador de taxa", "api_id": "a99919d1-0770-40a1-81a9-e3c31fd9d282", "habilitado": verdadeiro
} Quando a interface de acesso ultrapassar o limite, serão recebidos os seguintes retornos:
Retorno
{ "message": "Limite de taxa da API ultrapassado"
} No entanto, ainda existem alguns problemas, pois o formato da mensagem é fixo, o formato de saída não é consistente com o serviço backend e formatos de mensagem personalizados precisam ser suportados.
Kong modifica o valor de retorno de exceção Por exemplo, o formato unificado de mensagem do serviço é o seguinte:
{ "código": 200, "MSG": "OK", "data": {xxx}
} Também queremos que o retorno de exceção do Kong permaneça no mesmo formato acima. Então podemos modificar diretamente o código-fonte do Kong, que na verdade é muito simples.
Comece baixando o código-fonte
#下载kong插件源码
clone gitgit@github.com:Kong/kong.git
Localize o código de saída para modificar
O código de saída está localizado em kong/kong/tools/responses.lua, abra para edição.
Salve e depois compile
[root@tree81 Kong]# Fazem Luarocks O kong 0.11.2-0 agora está instalado em /usr/local (licença: MIT) Lançar, tente novamente
Atualize rapidamente o endereço várias vezes seguidas:O login do hiperlink está visível.Recebo uma mensagem de erro:
{ "código": 429, "msg": "Limite de taxa de API ultrapassado"
} Pronto, perfeito :) |