设备数据通过Azure Functions 推送到 Power BI 数据大屏进行展示(2.Azure Functions实战) - 图1

    本案例适用于开发者入门理解Azure Functions/ IoT Hub / Service Bus / Power BI等几款产品。

    主要实战的内容为:

    1. 将设备遥测数据上传到物联网中心,
    2. 将遥测数据路由到消息中间件的Topic中,
    3. 使用Azure Function解析消息中间件Topic中的消息并推送到大屏 。

    设备数据通过Azure Functions 推送到 Power BI 数据大屏进行展示(2.Azure Functions实战) - 图2

    先了解下Azure Functions的基本概念:

    azure functions 基本概念.mp4 (29.48MB) 在Azure Portal 创建Functions 并体验:

    创建function并trigger sb topic.mp4 (13.99MB) IoT Hub 和Service Bus的准备工作,请参考:
    设备数据通过Azure Functions 推送到 Power BI 数据大屏进行展示(1.准备工作)

    使用Visual studio 2019 创建并发布Functions: vs创建function pushdata to pbi.mp4 (43.21MB)

    本示例中的示例代码:

    1. using System;
    2. using System.IO;
    3. using System.Net;
    4. using System.Text;
    5. using Microsoft.Azure.WebJobs;
    6. using Microsoft.Azure.WebJobs.Host;
    7. using Microsoft.Extensions.Logging;
    8. using Newtonsoft.Json;
    9. namespace FunctionApp2
    10. {
    11. public static class Function1
    12. {
    13. [FunctionName("Function1")]
    14. public static void Run([ServiceBusTrigger("fromiothubtopic", "sub", Connection = "sbconn")]string mySbMsg, ILogger log)
    15. {
    16. log.LogInformation($"C# ServiceBus topic trigger function processed message: {mySbMsg}");
    17. string url = "https://api.powerbi.cn/beta/请替换成您自己的URL";
    18. IoTDeviceMsg msg = JsonConvert.DeserializeObject<IoTDeviceMsg>(mySbMsg);
    19. // Create JSON message
    20. var telemetryDataPoint = new
    21. {
    22. temperature = msg.temperature,
    23. humidity = msg.humidity,
    24. time = DateTime.Now
    25. };
    26. var messageString = JsonConvert.SerializeObject(telemetryDataPoint);
    27. HttpWebRequest req = (HttpWebRequest)WebRequest.Create(url);
    28. req.Method = "POST";
    29. req.Timeout = 8000;//设置请求超时时间,单位为毫秒
    30. req.ContentType = "application/json";
    31. byte[] data = Encoding.UTF8.GetBytes("[" + messageString + "]");
    32. req.ContentLength = data.Length;
    33. using (Stream reqStream = req.GetRequestStream())
    34. {
    35. reqStream.Write(data, 0, data.Length);
    36. reqStream.Close();
    37. }
    38. HttpWebResponse resp = (HttpWebResponse)req.GetResponse();
    39. Stream stream = resp.GetResponseStream();
    40. //获取响应内容
    41. if (resp.StatusCode == HttpStatusCode.OK)
    42. {
    43. log.LogInformation($"OK: {messageString}");
    44. }
    45. }
    46. }
    47. public class IoTDeviceMsg
    48. {
    49. public decimal temperature { get; set; }
    50. public decimal humidity { get; set; }
    51. }
    52. }

    针对开发人员入门,需关注如下基本概念:

    1.Azure Functions Trigger

    AzureFunctions 提供了几种模板,模板支持如下的触发:
    HTTPTrigger - 使用 HTTP 请求触发执行代码。
    TimerTrigger - 按预定义的计划执行清除或其他批处理任务。
    CosmosDBTrigger - 在 NoSQL 数据库中以集合形式添加或更新Azure CosmosDB 文档时,对这些文档进行处理。
    QueueTrigger - 当消息到达 Azure 存储队列时,响应这些消息。
    BlobTrigger - Azure 存储 blob 添加到容器时,处理这些 blob。 可以使用此函数调整图像大小。
    EventHubTrigger - 响应传送到 Azure 事件中心的事件。
    ServiceBusQueueTrigger - 通过侦听消息队列将代码连接到其他Azure 服务或本地服务。
    ServiceBusTopicTrigger - 通过订阅主题将代码连接到其他Azure 服务或本地服务。
    2. Azure Functions 集成
    AzureFunctions 可与各种 Azure 和第三方服务集成。 这些服务可以触发函数开始执行,或者可用作代码的输入和输出。 AzureFunctions 支持以下服务集成:
    Azure CosmosDB
    Azure 事件中心
    Azure 通知中心
    Azure 服务总线(队列和主题)
    Azure 存储(blob、队列和表)
    本地(使用服务总线)
    两种计费方式:
    使用计划(Consumptionplan):只为代码运行时间付费
    应用服务计划(App Serviceplan):将函数像 Web 应用一样运行。 如果已对其他应用程序使用应用服务,可以按相同的计划运行自己的函数,而不用另外付费。
    具体的计费请参考:
    https://www.azure.cn/zh-cn/pricing/details/azure-functions/

    image.png