【问题标题】:Attach process/debug Azure Functions (IntelliJ + Java + Gradle) not hitting breakpoints附加进程/调试 Azure Functions (IntelliJ + Java + Gradle) 没有遇到断点
【发布时间】:2020-07-01 06:14:34
【问题描述】:

*注意:我在这篇文章的底部发布了我发送的示例 POSTMAN 请求

我有一个 Azure 函数应用程序,它是一个 Java 类中的 HTTP 触发器,它的终点是 /api/devices/{id},主机当然是 http://localhost:7071,id 是序列号,即长度为 10 的字母数字字符串

我跑去清理并在本地打包 azure 函数。:

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

然后,我尝试运行(根据这篇文章https://docs.microsoft.com/en-us/azure/azure-functions/functions-create-maven-intellij):

./gradlew azureFunctionsRun -DenableDebug

我还尝试在 Gradle GUI/插件中“右键单击”azureFunctionsRun 任务(IntelliJ 的最右侧工具栏,其中列出了其他 Gradle 任务,即构建)并点击“调试”但无论我尝试哪种调试方法,我的断点都不会被命中。

我正在使用 POSTMAN 访问端点,并且我知道我正在使用正确的标头等,因为我在 DEV 上尝试过这个并通过 POSTMAN 发送确切的请求并且它可以工作。我收到一个“500 内部服务器”请求,但它仍然跳转到 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 函数并在本地调试的正确方法是什么??我想在本地通过 POSTMAN 发送我的 HTTP 请求,并调试这个 Azure 函数!您可以看到,即使我收到 500 响应,log.info("Source IP of the client is {}") 正在使用主要逻辑在 try {} catch 块内被命中,因此应该命中断点!我在下面包含了您需要的所有信息,如果您需要 host.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] }

【问题讨论】:

    标签: azure debugging gradle intellij-idea azure-functions


    【解决方案1】:

    好的,我得到了这个工作,我要做的就是将它添加到我的 local.settings.json:

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

    然后我进入顶部工具栏上的 IntelliJ Run > Edit Configurations 然后我单击“+”号并添加了一个“Remote”,您可以将名称编辑为您单击的内容,但所有其他字段都应预先填写使用您在 local.settings.json 中列出的相同端口。

    然后,您可以像正常一样运行您的 azure 函数(如果您在 gradle 上运行 ./gradlew azureFunctionsRun,或者在 maven 上运行 mvn azure-functions:run,或者进入目标或构建文件夹并执行“func start”)

    然后单击 ctrl + alt + f5 并附加到正在运行的 Java 进程(它将在“Java”下。它不会在“只读”进程列表下)

    【讨论】:

    • 我按照您展示的流程进行操作,现在它在抱怨 - Unable to open debugger port (localhost:5005): java.net.ConnectException "Connection refused: connect"
    • @Musa 如果您将上面的代码行添加到您的 local.settings.json,并重新编译/打包,然后在 intelliJ 中创建远程调试器,使用默认设置(即模式 -> 附加到remote JVM, transport -> Socket, Host -> localhost, Port -> 5005, Cmmand line arguments for remote JVM -> -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 ),然后不应该给你关于“无法打开调试器端口”的消息...... local.settings.json中的代码行实际上打开了端口5005......你添加后重新编译了吗?即 mvn clean package 或 ./gradlew build ?
    • @Musa 上面回复^
    • 通过在 intellij 中添加远程调试器,我能够解决它。我不必修改本地设置文件,谢谢
    猜你喜欢
    • 1970-01-01
    • 2013-10-04
    • 2016-11-15
    • 2017-12-30
    • 2014-08-24
    • 1970-01-01
    • 1970-01-01
    • 2014-02-02
    • 2015-02-05
    相关资源
    最近更新 更多