- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个简单的 Azure V1 函数,可用作 CosmosDB 触发器,每次插入文档时,触发器都会工作并完成,Azure 控制台中函数应用程序本身的 App Insights 和监视器日志显示它触发了 1时间,代码的结果显示它触发了 1 次,但流控制台显示重复的输出,这是设计使然还是我做错了什么?
这就是函数
using System.Collections.Generic;
using Microsoft.Azure.Documents;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Host;
using Newtonsoft.Json.Linq;
using System.Net.Http;
using System.Net.Http.Formatting;
using System.Net.Http.Headers;
using System;
using System.Threading.Tasks;
namespace NWCloudTransactionEventHandler
{
public static class Function1
{
[FunctionName("Function1")]
public static async Task RunAsync([CosmosDBTrigger(
databaseName: "xxx",
collectionName: "xxx",
ConnectionStringSetting = "xxx",
LeaseCollectionName = "leases", LeaseCollectionPrefix = "cloud")]IReadOnlyList<Document> documents, TraceWriter log)
{
if (documents != null && documents.Count > 0)
{
log.Info("Start change feed processing");
log.Info("Documents modified " + documents.Count);
foreach(var document in documents)
{
dynamic jsonDoc = document;
string destinationSystem = jsonDoc.OriginalTransaction["destinationSystem"];
log.Info("destination system = " + destinationSystem);
if(destinationSystem == "xx.com")
{
log.Info("Start processing destinaton = xx.com");
string destinationSystemCountry = jsonDoc.OriginalTransaction["destinationSystemCountry"];
log.Info("destination country = " + destinationSystemCountry);
if (destinationSystemCountry == "xx")
{
log.Info("Start processing xx.com destination Country = xx");
JObject transaction = jsonDoc.OriginalTransaction["transactionDetails"];
log.Info("transactionDetail = " + transaction);
log.Info("Starting httpRequest");
HttpClient httpClient = new HttpClient();
httpClient.DefaultRequestHeaders.Add("Authorization", "xxxx");
HttpResponseMessage response = await httpClient.PostAsync("https://xxx/checkout", new StringContent(transaction.ToString(), System.Text.Encoding.UTF8, "application/json"));
log.Info("response is " + response);
}
else
{
log.Info("Destinationcountry is unsupported at this time");
return;
}
}
else
{
log.Info("Destinationsystem is unsupported at this time");
return;
}
}
log.Info("Change feed processing finished");
}
}
}
}
下面您可以看到重复的输出
2018-09-29T03:35:03 Welcome, you are now connected to log-streaming service.
2018-09-29T03:35:02.639 [Info] Executing HTTP request: {
"requestId": "1ebc2482-cb42-4b78-aa8f-c74e8d47a0e5",
"method": "GET",
"uri": "/admin/host/status"
}
2018-09-29T03:35:02.654 [Info] Host Status: {
"id": "nwcloudtransactioneventhandler-t",
"state": "Running",
"version": "1.0.11959.0"
}
2018-09-29T03:35:02.654 [Info] Executed HTTP request: {
"requestId": "1ebc2482-cb42-4b78-aa8f-c74e8d47a0e5",
"method": "GET",
"uri": "/admin/host/status",
"authorizationLevel": "Admin",
"status": "OK"
}
2018-09-29T03:35:20.638 [Info] Function started (Id=820dff13-dfb3-4641-84d9-123c85aa9ac2)
2018-09-29T03:35:20.638 [Info] Start change feed processing
2018-09-29T03:35:20.638 [Info] Documents modified 1
2018-09-29T03:35:20.638 [Info] destination system = xx.com
2018-09-29T03:35:20.638 [Info] Start processing destinaton = xx.com
2018-09-29T03:35:20.638 [Info] destination country = xx2018-09-29T03:35:20.638 [Info] Start processing hm.com destination Country = xx2018-09-29T03:35:20.638 [Info] transactionDetail = {
"callback": {
"refund": "https://x",
"success": "https://x"
},
"items": [
{
"attributes": {
"color": "Orange/Guld",
"size": "NOSIZE"
},
"price": "xx",
"quantity": "1",
"shipping": "0.0",
"title": "Bordslampa-Orange/Guld-NOSIZE",
"url": "xx"
}
],
"paymentMethod": {
"code": "XYZ",
"phone": "x",
"type": "x"
},
"reference": "x",
"test": "true"
}
2018-09-29T03:35:20.638 [Info] Starting httpRequest
2018-09-29T03:35:20.684 [Info] response is StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: System.Net.Http.StreamContent, Headers:
{
Vary: Origin
X-Content-Type-Options: nosniff
X-Frame-Options: ALLOWALL
X-Request-Id: c44a4e1a-55f0-4c0b-8183-3433530b7920
X-Runtime: 0.010130
X-Xss-Protection: 1; mode=block
Connection: keep-alive
Cache-Control: must-revalidate, max-age=0, private
Date: Sat, 29 Sep 2018 03:35:20 GMT
ETag: "52a9130e2fdb487944cfa9498bc071d0"
Content-Length: 1031
Content-Type: application/json; charset=utf-8
}
2018-09-29T03:35:20.684 [Info] Change feed processing finished
2018-09-29T03:35:20.684 [Info] Function completed (Success, Id=820dff13-dfb3-4641-84d9-123c85aa9ac2, Duration=46ms)
2018-09-29T03:35:20.638 [Info,Function1] Function started (Id=820dff13-dfb3-4641-84d9-123c85aa9ac2)
2018-09-29T03:35:20.638 [Info,Function1] Executing 'Function1' (Reason='New changes on collection transactions at 2018-09-29T03:35:20.6380214Z', Id=820dff13-dfb3-4641-84d9-123c85aa9ac2)
2018-09-29T03:35:20.638 [Info,Function1] Start change feed processing
2018-09-29T03:35:20.638 [Info,Function1] Documents modified 1
2018-09-29T03:35:20.638 [Info,Function1] destination system = xx.com
2018-09-29T03:35:20.638 [Info,Function1] Start processing destinaton = xx.com
2018-09-29T03:35:20.638 [Info,Function1] destination country = xx2018-09-29T03:35:20.638 [Info,Function1] Start processing xx.com destination Country = xx2018-09-29T03:35:20.638 [Info,Function1] transactionDetail = {
"callback": {
"refund": "https://x",
"success": "https://nxs"
},
"items": [
{
"attributes": {
"color": "Orange/Guld",
"size": "NOSIZE"
},
"price": "x",
"quantity": "1",
"shipping": "0.0",
"title": "Bordslampa-Orange/Guld-NOSIZE",
"url": "x"
}
],
"paymentMethod": {
"code": "XYZ",
"phone": "x",
"type": "x"
},
"reference": "x",
"test": "true"
}
2018-09-29T03:35:20.638 [Info,Function1] Starting httpRequest
2018-09-29T03:35:20.684 [Info,Function1] response is StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: System.Net.Http.StreamContent, Headers:
{
Vary: Origin
X-Content-Type-Options: nosniff
X-Frame-Options: ALLOWALL
X-Request-Id: c44a4e1a-55f0-4c0b-8183-3433530b7920
X-Runtime: 0.010130
X-Xss-Protection: 1; mode=block
Connection: keep-alive
Cache-Control: must-revalidate, max-age=0, private
Date: Sat, 29 Sep 2018 03:35:20 GMT
ETag: "52a9130e2fdb487944cfa9498bc071d0"
Content-Length: 1031
Content-Type: application/json; charset=utf-8
}
2018-09-29T03:35:20.684 [Info,Function1] Change feed processing finished
2018-09-29T03:35:20.684 [Info,Function1] Function completed (Success, Id=820dff13-dfb3-4641-84d9-123c85aa9ac2, Duration=46ms)
2018-09-29T03:35:20.684 [Info,Function1] Executed 'Function1' (Succeeded, Id=820dff13-dfb3-4641-84d9-123c85aa9ac2)
最佳答案
这是一个 bug已跟踪但尚未修复。
当功能代码面板打开时,文件日志(即诊断日志中的应用程序日志)被启用。与函数相关的条目会写入主机日志和函数日志,即写入 (kudu https://funcappname.scm.azurewebsites.net/DebugConsole
) 中的文件:
日志流控制台会打印主机日志和功能日志,因此与功能相关的条目会出现两次。例如,带有 [Info,Function1]
前缀的日志是主机日志中与函数相关的条目,这对我们来说是重复的。
关于c# - 为什么 azure Function App 流式日志查看器会重复日志输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52565026/
似乎有很多方法可以在 Azure 中自动使用 PowerShell。由于 ARM 模板是最新的,Azure 中的其他 PowerShell 选项是否已过时?这些工具/脚本之间有什么区别: Azure
我正在开发一个将托管在 Azure 中的 Web API。我想使用 Azure 诊断将错误记录到 Azure 表存储中。在经典门户中,我可以将日志配置为转到 Azure 表存储。 Classic Po
Azure 文件存储事件可以触发 Azure WebJob 或 Azure Function 吗? 例如,在文件夹“/todo/”中创建文件时。 最佳答案 我们目前没有任何 Azure 文件绑定(bi
我需要创建一个逻辑应用程序,我的要求是,我需要从 azure data Lake Gen2 文件夹迁移 json 文件,并根据某些值需要将该 json 转换为 xml,然后将其发送到 SQL。 因此,
我使用 VS Code 创建了 1 个 node.js 和 1 个 java Azure Function 当我使用 VS Code 将这两个函数部署到 Azure 时,我最终获得了这么多 Azure
收集 Azure 诊断数据时,暂存槽是否也会将诊断数据发送到 WadPerformanceCounters 表? 如果是这样,我该如何关闭它?或者在阅读诊断信息时如何区分暂存/生产。 我不想显示有关我
您好,我是 Azure 的新手。我有 VS 2012 和 Azure SDK 2.1,当我使用模拟器运行我的 Web 应用程序时一切正常。但是当我在 azure 上部署时出现错误消息: Could n
我很难区分 Azure 订阅和 Azure 租户有何不同?我尝试使用示例来弄清楚,但每次我得出的结论是它们在某种程度上是相同的?如果租户是组织在注册 Microsoft 云服务时接收并拥有的 Azur
如果我想在 Azure Insights 中设置自定义指标集合,并以(近)实时的方式可视化其中一些指标,并查看聚合的历史数据,我应该使用 Azure Metrics Explorer 还是 Azure
我想了解具有以下配置的 Azure 数据工厂 (ADF) 的现实示例/用例: Azure 集成运行时 (AIR) 默认值 自托管集成运行时(SHIR) 其他问题: 这两种配置(AIR 和 SHIR)是
请参阅下面来自 Azure 服务总线的指标。想要识别请求数量中的背景噪音|流量较低时的响应。假设振荡请求| session 中 amqp 握手的响应是潜在的。只是不明白这是什么类型的握手?从总线接收的
此问题与 Azure 事件中心和 Azure 服务总线之间的区别无关。 问题如下: 如果您将Azure Events Hub添加到您的应用程序中,那么您会注意到它依赖于Azure Service Bu
这两个事情是完全不同的,还是它们能完成的事情大致相同/相似? 最佳答案 Azure 辅助角色是“应用程序场”中您自己的一组虚拟机。您可以以分布式方式在它们上运行任何代码。通常,您编写业务代码以在这些服
我目前正在使用 Windows Azure 虚拟机来运行 RStudio, 我的虚拟机是 Windows Server R2 2012,它是 Azure 上的一项附加服务。 我还有一个 Azure 存
我们正在寻找托管一个网站(一些 css、js、一个 html 文件,但不是 aspx、一个通用处理程序)。 我们部署为: 1) Azure 网站 2) Azure 云服务 两种解决方案都有效。但有一个
我想从 Azure 表创建 blob。 AzCopy 支持此功能,但我找不到任何说明数据移动 API 也支持它的文档。此选项可用吗? https://azure.microsoft.com/en-us
This article表示 Azure 订阅所有者有权访问订阅中的所有资源。但是,要访问 Azure 数据库,必须是数据库中的用户,或者是 Azure Admin AD 组的成员。 无论 SQL 安
我尝试使用以下代码将 XML 文件上传到 Azure FTP 服务器: https://www.c-sharpcorner.com/article/upload-and-download-files-
除了 Azure 服务总线使用主题而 Azure 事件中心基于事件 - Azure 事件中心和 Azure 服务总线之间是否有任何根本区别? 对我来说,事件和消息之间没有真正的区别,因为两者只是不同类
我有一个通过虚拟网络网关连接到 Azure 虚拟网络的 Windows VPN 客户端。目标#1 是使用其内部 IP 地址连接到我的虚拟机。这有效。 第二个目标是使用其内部计算机名称进行连接(因为 I
我是一名优秀的程序员,十分优秀!