Azure App Service Networking Updates

App Service 現在 基本 (Basic) SKU 即 支援 VNet Integration 和 Private Endpoints。

通過此更新,您可以使用低成本SKU,並實現以前只能通過的高 SKU 實現的相同安全級別。
請注意,如果要降級現有應用服務計劃並仍使用 VNet Integration,則需要使用較新的App Service 集群,以確保 App Service Plan 支援 基本 (Basic) SKU 的 VNet Integration。

有關更多詳細資訊,請參閱: https://docs.microsoft.com/azure/app-service/overview-vnet-integration#limitations。

瞭解 如何啟用虛擬網路集成:https://docs.microsoft.com/azure/app-service/configure-vnet-integration-enable。

瞭解如何使用 Azure Private Endpoints 連接到 Web Service: https://docs.microsoft.com/azure/private-link/tutorial-private-endpoint-webapp-portal。

HTH. 2022-6-30 by Jacky

Backup Azure Web App database size exceeds 4GB limit, you get an error

In my environment:

  1. My database size is 4.31 GB.

  2. Click “Backup” button in my Web App and it failed.
    Error message: Cannot backup database YourDatabaseName since it exceeds maximum allowable limit (4392.828125 MB > 4096 MB).

Solution:

Please check this blog that explain an additional steps you can take to setup a separate automated backup mechanism to your Azure SQL Databases https://techcommunity.microsoft.com/t5/azure-database-support-blog/how-to-automate-export-azure-sql-db-to-blob-storage-use/ba-p/368864that this blog cover the steps required to automate export Azure SQL Database to a .bacpac file and store it to Azure Storage account.

That doesn`t interfere or block the built-in automated backup feature in Azure SQL Database covered here for more details. Automatic, geo-redundant backups - Azure SQL Database & Azure SQL Managed Instance
https://docs.microsoft.com/en-us/azure/azure-sql/database/automated-backups-overview?tabs=single-database

HTH. 2021-11-2 By Jacky

Azure Announcements Newsletter October 29th 2021

AZURE ANNOUNCEMENTS NEWSLETTER October 22nd, 2021 – October 28th, 2021

Total Announcements: 12

• General Availability (7)
• Preview Features (2)
• Region Updates (3)

Announcements Details

Azure Service: Advisor

General Availability

Azure Advisor for Azure Data Explorer is now available, providing personalized recommendations to optimize your Azure Data Explorer clusters. By analyzing your configurations and usage telemetry, Azure Advisor offers personalized, actionable recommendations that can help you reduce costs and improve performance.
Announcement: General availability: Azure Advisor recommendations for Azure Data Explorer Clusters | Azure updates | Microsoft Azure
Documentation: Use Azure Advisor recommendations to optimize your Azure Data Explorer cluster | Microsoft Docs

Azure Service: DevOps

Preview Features

Announcing the public preview of Visual Studio Code for the Web, a new web-based code editor that runs entirely in your browser with no install. Everyone can use VS Code for the Web for free at https://vscode.dev to quickly open and browse source code on your local machine, or hosted on GitHub or Azure Repos, and make and commit lightweight changes. VS Code for the Web does not have access to compute resources, so you won't be able to build, run, or debug your application, nor you will be able to use the integrated terminal. VS Code for the Web can be "upgraded" to a GitHub Codespaces instance in those cases when you need to leverage a more complete VS Code experience, including the ability to build and debug your code, use all VS Code extensions, or access the integrated terminal. Additionally, you can start working on the Web and continue your work on a VS Code desktop app.
Announcement: https://azure.microsoft.com/en-us/updates/public-preview-visual-studio-code-for-the-web-2/
Documentation: https://code.visualstudio.com/blogs/2021/10/20/vscode-dev

Azure Service: Express Route

General Availability

IPv6 support for ExpressRoute Private Peering is now generally available with ExpressRoute circuits and Azure environments globally. IPv6 support will unlock hybrid connectivity for you as you look to expand into mobile and IoT markets with Azure, or to address IPv4 exhaustion in your on-premise networks. Here are the new capabilities available with this support: Establish BGP sessions between the customer and Microsoft edge over ExpressRoute using IPv4 subnets, IPv6 subnets, or both Connect to dual-stack deployments in all Azure regions using a new or existing ExpressRoute gateway
Announcement: General availability: ExpressRoute IPv6 Support for Private Peering | Azure updates | Microsoft Azure

Documentation:Azure ExpressRoute: Add IPv6 support using Azure PowerShell | Microsoft Docs

Azure Service: Key Vault

General Availability

A strong enterprise governance strategy is crucial for protecting applications and infrastructure in the cloud. It enables you to manage risk, compliance, continuity, and security. Organizations use Azure Key Vault to create and manage secrets, certificates, and cryptographic keys to safeguard azure applications and services. Today we are taking governance a step further. Azure Key Vault will not only serve as a safeguard for your secrets but will also empower security officers to enforce security standards at scale to allow you to federate Key Vaults with a set of built-in policy definitions. We are excited to share that integration of Azure Key Vault with Azure Policy has reached general availability and is now ready for production use. This capability is a step towards our commitment to simplifying secure secrets management in Azure, while also enhancing policy enforcements that you can define on Key Vault, keys, secrets and certificates.
Announcement: General availability: Azure governance policy for Azure Key Vault | Azure updates | Microsoft Azure
Documentation: Integrate Azure Key Vault with Azure Policy | Microsoft Docs

Azure Service: Monitor

Region Updates

Azure Log Analytics in West US 3, Korea South, and Canada East
Announcement: General availability: Azure Log Analytics in West US 3, Korea South, and Canada East | Azure updates | Microsoft Azure
Documentation: Azure Products by Region | Microsoft Azure
|
|

Region Updates

Azure Monitor Log Analytics and Application Insights support for Availability Zones is now generally available in West US 2
Announcement: Azure Monitor Log Analytics and Application Insights support for Availability Zones is now generally available in West US 2 | Azure updates | Microsoft Azure
Documentation: Azure services that support availability zones | Microsoft Docs

Azure Service: Policy

General Availability

A strong enterprise governance strategy is crucial for protecting applications and infrastructure in the cloud. It enables you to manage risk, compliance, continuity, and security. Organizations use Azure Key Vault to create and manage secrets, certificates, and cryptographic keys to safeguard azure applications and services. Today we are taking governance a step further. Azure Key Vault will not only serve as a safeguard for your secrets but will also empower security officers to enforce security standards at scale to allow you to federate Key Vaults with a set of built-in policy definitions. We are excited to share that integration of Azure Key Vault with Azure Policy has reached general availability and is now ready for production use. This capability is a step towards our commitment to simplifying secure secrets management in Azure, while also enhancing policy enforcements that you can define on Key Vault, keys, secrets and certificates.
Announcement: General availability: Azure governance policy for Azure Key Vault | Azure updates | Microsoft Azure
Documentation: Integrate Azure Key Vault with Azure Policy | Microsoft Docs

Azure Service: Sphere

General Availability

The Azure Sphere 21.10 feature release is now generally available and includes the following components: Updated Azure Sphere OS Updated Azure Sphere SDK for Windows and for Linux Updated Azure Sphere extensions for Visual Studio and for Visual Studio Code Updated samples and tutorials If your devices are connected to the internet, they will receive the updated OS from the cloud. You'll be prompted to install the updated SDK on next use, or you can install it now.
Announcement: General availability: Azure Sphere version 21.10 | Azure updates | Microsoft Azure
Documentation: Install the Azure Sphere SDK for Linux | Microsoft Docs

Azure Service: Spring Cloud

General Availability

As of October 20, the following functionality is now generally available in Azure Spring Cloud: Monitor application lifecycle events using Azure Activity log and Azure Service Health (GA). Azure Spring Cloud now provides built-in tools to monitor the status and health of your applications. Enable end-to-end SSL/TLS (GA). Earlier this year we provided support for end-to-end SSL/TLS to secure traffic from an ingress controller to applications via HTTPS. This feature is now generally available.
Announcement: General availability: Azure Spring Cloud application health monitoring and end-to-end TLS/SSL | Azure updates | Microsoft Azure
Documentation: General availability: Azure Spring Cloud application health monitoring and end-to-end TLS/SSL | Azure updates | Microsoft Azure

Preview Features

As of October 20, the following functionality is now available in public preview in Azure Spring Cloud: Access built-in Spring Cloud Config Server and Service Registry using Azure Active Directory (preview). With Azure Active Directory role-based access control (RBAC), you can access the endpoints of Spring Cloud Config Server and Service Registry managed by Azure Spring Cloud from your apps deployed outside of Azure Spring Cloud environments for dev/test or migration scenarios. Ingress logs and metrics (preview). Access and query Nginx logs in Azure Log Analytics and easily correlate them with your application logs for better troubleshooting. Monitor Nginx traffic via Ngnix metrics in Azure Monitor.
Announcement: Public preview: Azure Spring Cloud RBAC config server and registry access and Nginx logs and metrics | Azure updates | Microsoft Azure
Documentation: Public preview: Azure Spring Cloud RBAC config server and registry access and Nginx logs and metrics | Azure updates | Microsoft Azure

Azure Service: Storage

General Availability

We announced recently that you can retain your backups for a longer duration in a cost effective manner using Azure Backup's Vault-Archive tier for your Azure Virtual Machines and SQL Server in Azure Virtual Machines. We had introduced the use of this feature only via PowerShell. With this update, we have introduced support for using the Vault-Archive tier of Azure Storage via Azure Portal and Azure CLI. Also, the ability to move the backups of SAP HANA databases running in Virtual Machines from Vault-Standard tier (erstwhile known as "Vault" tier) to Vault-Archive tier, is now generally available. In the screenshot below, you can see an overview of the Azure Portal experience for moving all eligible recovery points to the vault archive tier for SQL Server and SAP HANA in Azure Virtual Machines.
Announcement: General availability: Azure Backup now supports Archive Tier through Azure Portal | Azure updates | Microsoft Azure
Documentation: Archive Tier support overview - Azure Backup | Microsoft Docs

Azure Service: Virtual Machines

Region Updates

Azure Red Hat OpenShift is now in preview for Azure Government customers (federal, state, local governments, and their partners). Azure Red Hat OpenShift provides highly available, fully managed OpenShift clusters on demand, monitored and operated jointly by Microsoft and Red Hat. Kubernetes is at the core of Red Hat OpenShift. OpenShift brings added-value features to complement Kubernetes, making it a turnkey container platform as a service (PaaS) with a significantly improved developer and operator experience.
Announcement: Azure Red Hat OpenShift now available in public preview in Azure Government | Azure updates | Microsoft Azure
Documentation: Azure Red Hat OpenShift now in preview in Azure Government - Azure Government (microsoft.com)

HTH. 2021-11-1 by Jacky

Update CDN Endpoint originHostHeader

1
2
3
4
5
6
7
8
9
10
11
12
13
$azContext = Get-AzContext
$azProfile = [Microsoft.Azure.Commands.Common.Authentication.Abstractions.AzureRmProfileProvider]::Instance.Profile
$profileClient = New-Object -TypeName Microsoft.Azure.Commands.ResourceManager.Common.RMProfileClient -ArgumentList ($azProfile)
$token = $profileClient.AcquireAccessToken($azContext.Subscription.TenantId)
$authHeader = @{
'Content-Type'='application/json'
'Authorization'='Bearer ' + $token.AccessToken
}

$body=ConvertTo-Json -Depth 2 @{"properties"=@{originHostHeader= $null}}
$restUri = 'https://management.azure.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Cdn/profiles/{profileName}/endpoints/{endpointName}?api-version=2020-04-15'

$response = Invoke-RestMethod -Uri $restUri -Method PATCH -Headers $authHeader -Body $body -ContentType 'application/json'

Reference: https://docs.microsoft.com/en-us/rest/api/cdn/cdn/endpoints/update

HTH. 2021-6-8 By Jacky Chiou

How to collect performance counters of your Cloud Services

A performance counter can be added to your cloud service for either Azure Diagnostics or Application Insights.
For more information: https://docs.microsoft.com/en-us/azure/cloud-services/diagnostics-performance-counters

My steps of Azure Diagnostics:

  1. Open your Cloud Service project in Visual Studio. Go to WebRole’s Properties.

  2. In Properties page -> Click “Configure -> Go to “Performance Counters” Tab -> Add performance counters. For example: \LogicalDisk(C:)% Free Space and \LogicalDisk(C:)\Free Megabytes

  3. Configure a storage account for the Diagnostics results:

  4. Publish the Cloud Service Project into your Cloud Service.

  5. Get the performance counters data from Storage Account Table:

HTH. 2021-3-24 By Jacky

Unable to use dates as a partitionkey using cosmos db binding

Issue:
Unable to use dates as a partitionkey using cosmos db binding in Function App.

Error message

1
2021-02-25T10:06:43.246 [Error] Executed 'Functions.DateAsPartitionKey' (Failed, Id=4b6caaf1-70b3-43f6-ad3b-6135690aaff8, Duration=989ms)Message: {"Errors":["PartitionKey extracted from document doesn't match the one specified in the header"]}ActivityId: 93031b95-f2b7-4671-be9b-d2b15bdbe699, Request URI: /apps/4ade04dd-f1a9-46ca-8ce8-d1d500ff6422/services/14f4e25c-4cdb-4c48-9698-7c2bd157131c/partitions/89f15a69-3e0b-4eac-88ed-4ec954b9d385/replicas/132587031061806885p/, RequestStats:RequestStartTime: 2021-02-25T10:06:42.9959386Z, RequestEndTime: 2021-02-25T10:06:42.9959386Z, Number of regions attempted:1ResponseTime: 2021-02-25T10:06:42.9959386Z, StoreResult: StorePhysicalAddress: rntbd://cdb-ms-prod-westeurope1-fd59.documents.azure.com:14396/apps/4ade04dd-f1a9-46ca-8ce8-d1d500ff6422/services/14f4e25c-4cdb-4c48-9698-7c2bd157131c/partitions/89f15a69-3e0b-4eac-88ed-4ec954b9d385/replicas/132587031061806885p/, LSN: 10, GlobalCommittedLsn: 10, PartitionKeyRangeId: 0, IsValid: True, StatusCode: 400, SubStatusCode: 1001, RequestCharge: 1.24, ItemLSN: -1, SessionToken: -1#10, UsingLocalLSN: False, TransportException: null, ResourceType: Document, OperationType: Upsert, SDK: Microsoft.Azure.Documents.Common/2.11.0, Windows/10.0.14393 documentdb-netcore-sdk/2.9.2

Sample Project:
index.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
module.exports = async function (context, req) {
context.log('JavaScript HTTP trigger function processed a request.');

const dobDate = new Date(2012, 2, 2);
const dateItem = {
datepartition: dobDate
};
context.bindings.dataOut = JSON.stringify(dateItem);

context.res = {
// status: 200, /* Defaults to 200 */
body: dateItem
};
}

function.json

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
{
"bindings": [
{
"authLevel": "anonymous",
"type": "httpTrigger",
"direction": "in",
"name": "req",
"methods": [
"get"
]
},
{
"name": "dataOut",
"type": "cosmosDB",
"direction": "out",
"databaseName": "staging",
"collectionName": "datecheck",
"createIfNotExists":"true",
"partitionKey": "datepartition",
"connectionStringSetting": "COSMOSDB_CONNSTRING"
},
{
"type": "http",
"direction": "out",
"name": "res"
}
]
}

Possible solution:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
const CosmosClient = require("@azure/cosmos").CosmosClient;
const client = new CosmosClient({ endpoint:"YourCosmosDBEndpoint", key: "YourKey" });
const container = client.database("staging").container("datecheck");

module.exports = async function (context, req) {
context.log('JavaScript HTTP trigger function processed a request.');

const dobDate = new Date(2012, 2, 2);
const dateItem = {
datepartition: dobDate
};

await container.items.create(dateItem);

context.res = {
// status: 200, /* Defaults to 200 */
body: dateItem
};
}

HTH. 2021-3-4 By Jacky

How to get a list of all the Programmatic Deployments

Issue:
How to get a list of all the Programmatic Deployments (Microsoft.MarketplaceOrdering/Agreements) from all the subscriptions in Tenant?

Currently not all resources types are available to be queried in Azure Resource Graph. Missing resource types require additional development work to enable in Azure Resource Graph.

Possible Solution:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
Connect-AzAccount
Write-Host "Starting..."

$subscriptions = Get-AzSubscription
Write-Host $subscriptions.count

$report = @()
foreach ($sub in $subscriptions)
{
Write-Host $sub.Id
$uri = "https://management.azure.com/subscriptions/" + $sub.Id + "/providers/Microsoft.MarketplaceOrdering/agreements?api-version=2015-06-01"
Write-Host $uri

$Params = @{
"URI" = $uri
"Method" = 'GET'
"Headers" = @{
"Content-Type" = 'application/json'
"Accept" = 'application/json'
"Authorization" = 'Bearer yourBearerToken'
}
}

$res = Invoke-RestMethod @Params

If($res.value -ne ""){
foreach($agreement in $res.value){
$row =New-Object -TypeName PSObject -Property @{
SubscriptionName = $sub.Name
Publisher = $agreement.properties.publisher
Offer = $agreement.properties.offer
Sku = $agreement.name
State = $agreement.properties.state
}
$report += $row
}
}
}
$report | Export-Csv -Path c:\\tests\offers.csv -NoTypeInformation

Where to get the ApiKey:
1. Go to https://docs.microsoft.com/en-us/rest/api/marketplaceordering/marketplaceagreements/list
2. Click “Try it”
3. Copy the Api Key from “Request Preview”

HTH. 2021-3-2 By Jacky

HTTP/2 request with client certificate sample code

My sample code:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net.Http;
using System.Security.Cryptography.X509Certificates;
using System.Text;
using System.Threading.Tasks;

namespace TestHTTP2
{
class Program
{
static async Task Main(string[] args)
{
X509Certificate2 clientCert = GetClientCertificate();
Http2CustomHandler requestHandler = new Http2CustomHandler();
requestHandler.ClientCertificates.Add(clientCert);

using (var httpClient = new HttpClient(requestHandler))
{
//client.BaseAddress = new Uri(https://www.bing.com/);

HttpResponseMessage response = await httpClient.GetAsync(@https://jackyclientcer21.azurewebsites.net/);

if (response.IsSuccessStatusCode)
{
Console.WriteLine("HTTP2 is success!!");
}
else
{
Console.WriteLine(response.StatusCode);
Console.WriteLine(response.Content);
}
}
Console.ReadLine();
}

private static X509Certificate2 GetClientCertificate()
{
X509Store userCaStore = new X509Store(StoreName.My, StoreLocation.CurrentUser);
try
{
//X509Store store = new X509Store(StoreName.My, StoreLocation.CurrentUser);

userCaStore.Open(OpenFlags.ReadOnly);
X509Certificate2 clientCertificate = null;
foreach (X509Certificate2 certificate in userCaStore.Certificates)
{
if (certificate != null)
{
Console.WriteLine(certificate.Subject);
Console.WriteLine(certificate.Thumbprint);
clientCertificate = certificate;
break;
}
}

return clientCertificate;
}
catch
{
throw;
}
finally
{
userCaStore.Close();
}
}
}

public class Http2CustomHandler : WinHttpHandler
{
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, System.Threading.CancellationToken cancellationToken)
{
request.Version = new Version("2.0");
return base.SendAsync(request, cancellationToken);
}
}
}

HTH. 2021-2-9 by Jacky

HttpRequestMessage.CreateResponse causes stackoverflow when serializing JObject in Functions v3 runtime

This sample code was running for a long time in Function runtime v2, after platform upgrade to v3 started having stackoverflow crash in CreateResponse method:

1
2
3
4
5
6
7
8
9
10
11
[FunctionName("Function1")]
public static async Task<HttpResponseMessage> Run(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequestMessage req,
ILogger log)
{
var jsonString = @"{""Status"":""Success"",""Message"":""Function successfully executed""}";
var t = JObject.Parse(jsonString);
return req.CreateResponse(HttpStatusCode.OK, t);

}

Functions runtime v3 update is causing some infinite recursion when serializing JObject, top of the stack when overflow happens:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
InlinedCallFrame
System.ModuleHandle.ResolveTypeHandleInternal(System.Reflection.RuntimeModule, Int32, System.RuntimeTypeHandle[], System.RuntimeTypeHandle[])
System.Reflection.RuntimeModule.ResolveType(Int32, System.Type[], System.Type[])
System.Reflection.CustomAttribute.FilterCustomAttributeRecord(System.Reflection.MetadataToken, System.Reflection.MetadataImport ByRef, System.Reflection.RuntimeModule, System.Reflection.MetadataToken, System.RuntimeType, Boolean, ListBuilder`1<System.Object> ByRef, System.RuntimeType ByRef, System.IRuntimeMethodInfo ByRef, Boolean ByRef, Boolean ByRef)
System.Reflection.CustomAttribute.IsCustomAttributeDefined(System.Reflection.RuntimeModule, Int32, System.RuntimeType, Int32, Boolean)
System.Reflection.CustomAttribute.IsDefined(System.RuntimeType, System.RuntimeType, Boolean)
System.RuntimeType.IsDefined(System.Type, Boolean)
System.Runtime.Serialization.CollectionDataContract.IsCollectionOrTryCreate(System.Type, Boolean, System.Runtime.Serialization.DataContract ByRef, System.Type ByRef, Boolean)
System.Runtime.Serialization.CollectionDataContract.IsCollectionHelper(System.Type, System.Type ByRef, Boolean)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type, System.Runtime.Serialization.CollectionDataContractAttribute ByRef)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type, System.Runtime.Serialization.CollectionDataContractAttribute ByRef)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type, System.Runtime.Serialization.CollectionDataContractAttribute ByRef)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type, System.Runtime.Serialization.CollectionDataContractAttribute ByRef)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type, System.Runtime.Serialization.CollectionDataContractAttribute ByRef)
System.Runtime.Serialization.DataContract.GetNonDCTypeStableName(System.Type)
System.Runtime.Serialization.DataContract.GetStableName(System.Type, Boolean ByRef)
System.Runtime.Serialization.DataContract.GetCollectionStableName(System.Type, System.Type,

Workaround 1:

Changed last line to return directly the json string instead of JObject, that mitigated the problem:

1
2
3
return req.CreateResponse(HttpStatusCode.OK, 
@"{""Status"":""Success"",""Message"":""Function successfully executed""}");

Workaround 2:

set “FUNCTIONS_V2_COMPATIBILITY_MODE” to “true”

HTH. By Jacky 2021-1-29