- 注:我在此帖子的底部发布了我发送的样本 Postman 请求
我有一个Azure Functions应用程序,它是一个Java类中的HTTP触发器,它的终点是/api/Devices/{id},主机当然是http://localhost:7071,id是一个序列号,即长度为10的字母数字字符串
我跑去清理和打包本地的Azure函数。
./gradlew clean
./gradlew build
./gradlew azureFunctionsPackage
然后,我尝试运行(根据本文https://learn.microsoft.com/en-us/azure/azure-functions/functions-create-maven-intellij):
./gradlew azureFunctionsRun -DenableDebug
我还尝试了在Gradle图形用户界面/插件(IntelliJ最右侧的工具栏,其中列出了其他Gradle任务,即Build)中“右键单击”azureFunctionsRun任务,并点击‘Debug’,但无论我尝试哪种调试方法,都不会命中我的断点。
我正在用 Postman 处理端点,我知道我使用的是正确的报头之类的,因为我在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函数并在本地调试的正确方式是什么?我想在本地通过 Postman 发送我的HTTP请求,并调试此Azure函数!您可以看到,尽管我收到了500响应,但在try{}Catch块中使用主逻辑命中了log.info(“客户端的源IP是{}”),所以应该命中了断点!我在下面包含了您需要的所有信息,如果您想要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] }
2条答案
按热度按时间ruyhziif1#
好的,我让它起作用了,我要做的是将它添加到我的local.settings.json:
然后,我进入顶部工具栏Run>Edit Configurations上的IntelliJ,然后点击“+”符号并添加“Remote”,您可以编辑名称为您所点击的内容,但所有其他字段应预先填写您在本地.settings.json中列出的相同端口。
然后,你可以运行你的azure函数,如Normal(./gradlew azureFunctions,Run if Your Gradle),或者MVN azure-Functions:在maven上运行,或者进入目标或构建文件夹并执行“Func Start”)
然后单击ctrl+alt+f5并附加到正在运行的Java进程(它将位于“Java”下)。它不会在“只读”进程列表下)
wfveoks02#
无论该进程如何运行,您都需要添加以下行:
"languageWorkers:java:arguments": "-Djava.net.preferIPv4Stack=true -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8001"
添加到您正在使用的设置文件,在我的例子中,它是local.settings.json。只需在“Values”对象中添加该属性即可。
然后,在IntelliJ中,在运行/调试配置中使用远程JVM调试,并在那里添加正确的端口号。对于我上面的示例配置,它将是8001,但它可以是任何其他未使用的端口。
启动该进程(我从
mvn clean package azure-functions:run
的终端用maven启动它。然后在IntelliJ中运行远程调试。