gpt4 book ai didi

azure - 附加进程/调试 Azure Functions (IntelliJ + Java + Gradle) 未命中断点

转载 作者:行者123 更新时间:2023-12-03 04:55:31 28 4
gpt4 key购买 nike

*注意:我在本文底部发布了我要发送的示例 POSTMAN 请求

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

我运行 clean & 在本地打包 azure 函数。:

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

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

./gradlew azureFunctionsRun -DenableDebug

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

我正在使用 POSTMAN 访问端点,并且我知道我正在使用正确的 header 等,因为我在 DEV 上尝试了此操作并通过 POSTMAN 发送了确切的请求并且它有效。我收到“500内部服务器”请求,但它仍然跳转到java代码中的一些代码逻辑(在Azure Function App内部)(有一些方法被命中,因为我的代码中有日志):

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 Function 并在本地进行调试的正确方法是什么?我想在本地通过POSTMAN发送我的HTTP请求,并调试这个Azure功能!你可以看到,即使我得到了 500 响应,log.info("Source IP of the client is {}") 也在 try {} catch block 内与主逻辑一起被命中,所以断点应该被命中!我在下面提供了您需要的所有信息,如果您想要 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 并通过 postman 发送我的 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

最佳答案

好的,我让它工作了,我要做的就是将其添加到我的 local.settings.json 中:

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

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

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

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

关于azure - 附加进程/调试 Azure Functions (IntelliJ + Java + Gradle) 未命中断点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60768562/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com