Присоединить процесс / отладка Azure Функции (IntelliJ + Java + Gradle), не достигая точек останова - PullRequest
0 голосов
/ 20 марта 2020

* Примечание. Я разместил образец запроса POSTMAN, который я отправляю внизу этого сообщения.

У меня есть приложение Azure функций, которое является триггером HTTP в одном классе java, и оно конечная точка - / api / devices / {id}, с узлом конечно http://localhost: 7071 , а id - серийный номер, т.е. длина 10 alphanumeri c строка

I запустить, чтобы очистить и упаковать azure функции локально.:

./gradlew clean
./gradlew build
./gradlew azureFunctionsPackage 

Затем я попытался запустить (согласно этой статье https://docs.microsoft.com/en-us/azure/azure-functions/functions-create-maven-intellij):

./gradlew azureFunctionsRun -DenableDebug

Я также пытался «щелкнуть правой кнопкой мыши» задачу azureFunctionsRun в графическом интерфейсе / плагине Gradle (крайняя правая панель инструментов IntelliJ, где перечислены другие задачи Gradle, т.е. сборка) и нажал «Отладка», но какой бы метод отладки я ни пытался, ни одна из моих точек останова не будет достигнута.

Я поражаю конечные точки с помощью POSTMAN и знаю, что использую правильные заголовки и тому подобное, потому что я пробовал это на DEV и отправьте точные запросы через POSTMAN, и это работает. Я получаю запрос «500 внутренних серверов», но он все еще прыгает в часть кода logi c в коде java (внутри приложения-функции Azure) (есть методы, вызываемые из-за того, что у меня есть журналы в моем код):

11:19:23 PM: Executing task 'azureFunctionsRun'...

Starting Gradle Daemon...
Connected to the target VM, address: '127.0.0.1:58691', transport: 'socket'
Gradle Daemon started in 2 s 517 ms

Как правильно присоединить процесс к функции Azure и выполнить локальную отладку? Я хочу отправить свой HTTP-запрос через POSTMAN локально и отладить эту Azure функцию! Вы можете видеть, что хотя я получаю ответ 500, log.info («Исходный IP-адрес клиента {}») попадает в блок try {} catch с основными логами c, поэтому точки останова должны быть пораженным! Я включил всю необходимую информацию ниже, если вам нужен хост. json или local.settings. json, пожалуйста, дайте мне знать. Я пытался отладить сейчас через intelliJ в течение нескольких недель, и я действительно раздражаюсь, я не могу заставить это работать.

Вот код функции azure ниже:

@FunctionName("edgegw_bootstrap_handler")
    public HttpResponseMessage httpFunctionHandler(
            @HttpTrigger(name = "req",
                    methods = {HttpMethod.GET},
                    authLevel = AuthorizationLevel.ANONYMOUS,
                    route = "devices/{id}")
                    HttpRequestMessage<Optional<String>> request,
            @BindingName("id") final String deviceId,
            final ExecutionContext context) {

        //TODO refactor: move the business logic to a separate class
        log.info("Processing a request for device id {}", deviceId);
        final String registrationKey = keyProvider.get(EDGE_REGISTRATION_KEY);

        try {
            String clientIp = request.getHeaders().get(HEADER_XFORWARDED_KEY).split("\\s*,\\s*")[0];
            log.info("Source IP of the client is {}", clientIp);

            // we don't want to validate client IP in DEV
            if (LoadLine.thisLoadLine() != LoadLine.Dev) {
                log.info("Validating client IP");
                Optional<EdgegwConfig> edgeGw = dataGateway.getEdgeGwConfigCrud().get(deviceId);
                String oamIp = edgeGw.get().getServerConfig().getEpsIpData().getEpsOam().getIp();

                if (!isIpValid(clientIp, oamIp)) {
                    log.warn(WARN("Received request with invalid source IP {}"), clientIp);
                    return request.createResponseBuilder(HttpStatus.BAD_REQUEST).build();
                }
                log.info("Received client IP is valid");
            }

            if (!request.getHeaders().getOrDefault(HEADER_AUTHORIZATION_KEY, UNAUTHORIZED).equals(HEADER_AUTHORIZATION_PREFIX + registrationKey)) {
                log.warn(WARN("Received unauthorized request from {}"), clientIp);
                return request.createResponseBuilder(HttpStatus.BAD_REQUEST).build();
            }

            String result = getSecrets(deviceId);
            return request.createResponseBuilder((result != null) ? HttpStatus.OK : HttpStatus.BAD_REQUEST).
                    header("Content-Type", "application/json; charset=UTF-8").
                    body(result).build();

        } catch (Exception e) {
            log.error(ERROR("Server exception occurred: {}"), e.getMessage());
            return request.createResponseBuilder(HttpStatus.INTERNAL_SERVER_ERROR).build();
        }

    } 

Я знаю, что некоторые из моих точек останова должны попасть, потому что я получаю этот ответ в терминале, после запуска azureFunctionsRun и отправки моего HTTP-запроса через почтальона:

[3/20/2020 4:19:42 AM] Executing HTTP request: {
[3/20/2020 4:19:42 AM]   "requestId": "94c12814-c7f7-4c1d-9680-0a9cbc2597ac",
[3/20/2020 4:19:42 AM]   "method": "GET",
[3/20/2020 4:19:42 AM]   "uri": "/api/devices/2M290702XY"
[3/20/2020 4:19:42 AM] }
[3/20/2020 4:19:42 AM] Executing 'Functions.edgegw_bootstrap_handler' (Reason='This function was programmatically called via the host APIs.', Id=7dbf720b-4c57-4448-8474-872cc1e77e5a)
[3/20/2020 4:19:43 AM] 2020-03-19 23:19:43 [pool-2-thread-1] INFO ::  Processing a request for device id 2M290702XY
[3/20/2020 4:19:43 AM] 2020-03-19 23:19:43 [pool-2-thread-1] INFO ::  Source IP of the client is 10.0.0.61
[3/20/2020 4:19:45 AM] 2020-03-19 23:19:45 [pool-2-thread-1] INFO ::  
[3/20/2020 4:19:45 AM]                                       
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@  @@        @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@        @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@  @@  @@    @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@  @@@@  @@  @@    @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@        @@        @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@        @@        @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@    @@  @@  @@@@  @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@    @@  @@  @@@@  @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@        @@  @  @  @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@        @@        @@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@  @@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
[3/20/2020 4:19:45 AM] @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@  Thank you for using jOOQ 3.11.11
[3/20/2020 4:19:45 AM]                                       
[3/20/2020 4:19:45 AM] 2020-03-19 23:19:45 [pool-2-thread-1] INFO ::  Found document with id 2M290702XY
[3/20/2020 4:19:45 AM] 2020-03-19 23:19:45 [pool-2-thread-1] ERROR::  |EDGE_GW_ERROR| Server exception occurred: The String is not a valid Base64-encoded string.
[3/20/2020 4:19:45 AM] Function "edgegw_bootstrap_handler" (Id: 7dbf720b-4c57-4448-8474-872cc1e77e5a) invoked by Java Worker
[3/20/2020 4:19:45 AM] Executed 'Functions.edgegw_bootstrap_handler' (Succeeded, Id=7dbf720b-4c57-4448-8474-872cc1e77e5a)
[3/20/2020 4:19:45 AM] Executed HTTP request: {
[3/20/2020 4:19:45 AM]   "requestId": "94c12814-c7f7-4c1d-9680-0a9cbc2597ac",
[3/20/2020 4:19:45 AM]   "method": "GET",
[3/20/2020 4:19:45 AM]   "uri": "/api/devices/2M290702XY",
[3/20/2020 4:19:45 AM]   "identities": [
[3/20/2020 4:19:45 AM]     {
[3/20/2020 4:19:45 AM]       "type": "WebJobsAuthLevel",
[3/20/2020 4:19:45 AM]       "level": "Admin"
[3/20/2020 4:19:45 AM]     }
[3/20/2020 4:19:45 AM]   ],
[3/20/2020 4:19:45 AM]   "status": 500,
[3/20/2020 4:19:45 AM]   "duration": 2653
[3/20/2020 4:19:45 AM] }

enter image description here

1 Ответ

0 голосов
/ 27 марта 2020

Хорошо, я получил это на работу, что мне нужно было сделать, это добавить это в мои local.settings. json:

"languageWorkers:java:arguments": "-Djava.net.preferIPv4Stack=true -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005"

Затем я вошел в IntelliJ на верхней панели инструментов. Выполнить> Изменить Затем я нажал на знак «+» и добавил «Удаленный», вы можете отредактировать имя для того, на что вы щелкнете, но все остальные поля должны быть предварительно заполнены тем же портом, который вы указали в local.settings. json.

Затем вы можете запускать ваши azure функции как обычно (./gradlew azureFunctionsRun, если вы на gradle, или mvn azure -функции: запускать на maven или заходить в папку назначения или сборки и выполняя "fun c start")

, затем вы нажимаете Ctrl + Alt + F5 и присоединяетесь к запущенному процессу Java (он будет находиться под "Java". Он Win ' t находиться в списке процессов «Только чтение»)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...