diff --git a/sdk/eventhub/event-processor-host/README.md b/sdk/eventhub/event-processor-host/README.md index 6b8f07382024..099deb832e9c 100644 --- a/sdk/eventhub/event-processor-host/README.md +++ b/sdk/eventhub/event-processor-host/README.md @@ -1,5 +1,7 @@ -@azure/event-processor-host -================ +# @azure/event-processor-host + +> NOTE: This package is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob. +> Please see the [migration guide](https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-hubs/migrationguide.md) to move your application that uses this package Azure Event Processor Host helps you efficiently receive events from an EventHub. It will create EventHub Receivers across all the partitions in the provided consumer group of an EventHub and provide you messages received across @@ -7,50 +9,65 @@ all the partitions. It will checkpoint metadata about the received messages at r Azure Storage Blob. This makes it easy to continue receiving messages from where you left at a later time. #### Conceptual Overview + ![overview](https://raw.githubusercontent.com/Azure/azure-sdk-for-js/master/sdk/eventhub/event-processor-host/eph.png) - More information about Azure Event Processor Host can be found over [here](https://docs.microsoft.com/azure/event-hubs/event-hubs-event-processor-host). - General overview of how the Event Processor Host SDK works internally can be found over [here](https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-processor-host/overview.md). -## Pre-requisite ## -- **Node.js version: 6.x or higher.** +## Pre-requisite + +- **Node.js version: 6.x or higher.** - We would **still encourage you** to install the latest available LTS version at any given time from https://nodejs.org. **It is a good practice to always install the latest available LTS version of node.js.** - Installing node.js on **Windows or macOS** is very simple with available installers on the [node.js website](https://nodejs.org). If you are using a **linux based OS**, then you can find easy to follow, one step installation instructions over [here](https://nodejs.org/en/download/package-manager/). -## Installation ## +## Installation + ```bash npm install @azure/event-processor-host ``` -## IDE ## -This sdk has been developed in [TypeScript](https://typescriptlang.org) and has good source code documentation. It is highly recommended to use [vscode](https://code.visualstudio.com) + +## IDE + +This sdk has been developed in [TypeScript](https://typescriptlang.org) and has good source code documentation. It is highly recommended to use [vscode](https://code.visualstudio.com) or any other IDE that provides better intellisense and exposes the full power of source code documentation. -## Debug logs ## +## Debug logs You can set the following environment variable to get the debug logs. - Getting debug logs **only** from the Event Processor Host SDK + ```bash export DEBUG=azure:eph* ``` + - Getting debug logs from the Event Processor Host SDK **and** the protocol level library. + ```bash export DEBUG=azure:eph*,rhea* ``` + - Getting debug logs from the **Event Processor Host SDK, the Event Hub SDK and the protocol level library.** + ```bash export DEBUG=azure*,rhea* ``` + - If you are **not interested in viewing the message transformation** (which consumes lot of console/disk space) then you can set the `DEBUG` environment variable as follows: + ```bash export DEBUG=azure*,rhea*,-rhea:raw,-rhea:message,-azure:amqp-common:datatransformer ``` + - If you are interested only in **errors**, then you can set the `DEBUG` environment variable as follows: + ```bash export DEBUG=azure:eph:error,azure:event-hubs:error,azure-amqp-common:error,rhea-promise:error,rhea:events,rhea:frames,rhea:io,rhea:flow ``` #### Logging to a file + - Set the `DEBUG` environment variable as shown above and then run your test script as follows: - Logging statements from your test script go to `out.log` and logging statements from the sdk go to `debug.log`. ```bash @@ -64,19 +81,23 @@ export DEBUG=azure:eph:error,azure:event-hubs:error,azure-amqp-common:error,rhea ```bash node your-test-script.js &> out.log ``` + ## Recommendation -- You will find the sample provided below demonstrates a multi eph instance in the same process. Since node.js is single threaded, it has to load balance between managing(renew, steal, acquire, update) leases and receive messages across all the partitions. It is better to -create each instance in a separate process or a separate machine. This should provide better results. + +- You will find the sample provided below demonstrates a multi eph instance in the same process. Since node.js is single threaded, it has to load balance between managing(renew, steal, acquire, update) leases and receive messages across all the partitions. It is better to + create each instance in a separate process or a separate machine. This should provide better results. ## Examples + - Examples can be found over -[here](https://github.com/Azure/azure-sdk-for-js/tree/master/sdk/eventhub/event-processor-host/samples). + [here](https://github.com/Azure/azure-sdk-for-js/tree/master/sdk/eventhub/event-processor-host/samples). ## Usage ### NOTE + The following samples focus on EPH (Event Processor Host) which is responsible for receiving messages. -For sending messages to the EventHub, please use the `azure-event-hubs` package from npm. More +For sending messages to the EventHub, please use the `@azure/event-hubs` package from npm. More information about the event hub client can be found over [here](https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-hubs). You can also use [this example](https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-processor-host/samples/typescript/src/sendBatch.ts) that sends multiple messages batched together. You should be able to run the `send` example from one terminal window and see those messages @@ -135,6 +156,7 @@ main().catch((err) => { ``` ### Multiple EPH instances in the same process. + This example creates 2 instances of EPH in the same process. It is also perfectly fine to create multiple EPH instances in different processes on the same or different machine. @@ -206,20 +228,35 @@ async function startEph(ephName /**string**/) { ); // Message handler let count = 0; - const onMessage /**OnReceivedMessage**/ = async (context /**PartitionContext**/, data /**EventData**/) => { + const onMessage /**OnReceivedMessage**/ = async ( + context /**PartitionContext**/, + data /**EventData**/ + ) => { count++; - console.log("##### [%s] %d - Rx message from '%s': '%s'", ephName, count, context.partitionId, - data.body); + console.log( + "##### [%s] %d - Rx message from '%s': '%s'", + ephName, + count, + context.partitionId, + data.body + ); // Checkpointing every 200th event that is received acrosss all the partitions. if (count % 200 === 0) { try { - console.log("***** [%s] EPH is currently receiving messages from partitions: %O", ephName, - eph.receivingFromPartitions); + console.log( + "***** [%s] EPH is currently receiving messages from partitions: %O", + ephName, + eph.receivingFromPartitions + ); await context.checkpoint(); console.log("$$$$ [%s] Successfully checkpointed message number %d", ephName, count); } catch (err) { - console.log(">>>>>>> [%s] An error occurred while checkpointing msg number %d: %O", - ephName, count, err); + console.log( + ">>>>>>> [%s] An error occurred while checkpointing msg number %d: %O", + ephName, + count, + err + ); } } }; @@ -267,7 +304,7 @@ async function main() { ); let count = 0; // Message event handler - const onMessage = async (context/*PartitionContext*/, data /*EventData*/) => { + const onMessage = async (context /*PartitionContext*/, data /*EventData*/) => { console.log(">>>>> Rx message from '%s': '%s'", context.partitionId, data.body); count++; // let us checkpoint every 100th message that is received across all the partitions. @@ -292,8 +329,8 @@ main().catch((err) => { }); ``` -## AMQP Dependencies ## -It depends on [rhea](https://github.com/amqp/rhea) library for managing connections, sending and receiving events over the [AMQP](https://docs.oasis-open.org/amqp/core/v1.0/os/amqp-core-complete-v1.0-os.pdf) protocol. +## AMQP Dependencies +It depends on [rhea](https://github.com/amqp/rhea) library for managing connections, sending and receiving events over the [AMQP](https://docs.oasis-open.org/amqp/core/v1.0/os/amqp-core-complete-v1.0-os.pdf) protocol. ![Impressions](https://azure-sdk-impressions.azurewebsites.net/api/impressions/azure-sdk-for-js%2Fsdk%2Feventhub%2Fevent-processor-host%2FREADME.png) diff --git a/sdk/eventhub/event-processor-host/samples/javascript/iothubEph.js b/sdk/eventhub/event-processor-host/samples/javascript/iothubEph.js index df9d9dc236ca..ecd6694983c2 100644 --- a/sdk/eventhub/event-processor-host/samples/javascript/iothubEph.js +++ b/sdk/eventhub/event-processor-host/samples/javascript/iothubEph.js @@ -7,6 +7,10 @@ intervals in an Azure Storage Blob. */ +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + const { EventProcessorHost, delay } = require("@azure/event-processor-host"); // Define IoT Hub and storage connection strings here diff --git a/sdk/eventhub/event-processor-host/samples/javascript/multiEph.js b/sdk/eventhub/event-processor-host/samples/javascript/multiEph.js index db8e290b3384..75d98a7e0b35 100644 --- a/sdk/eventhub/event-processor-host/samples/javascript/multiEph.js +++ b/sdk/eventhub/event-processor-host/samples/javascript/multiEph.js @@ -13,6 +13,10 @@ to learn about Event Processor Host. */ +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + const { EventProcessorHost, delay } = require("@azure/event-processor-host"); // Define Storage and Event Hubs connection strings and related Event Hubs entity name here diff --git a/sdk/eventhub/event-processor-host/samples/javascript/sendBatch.js b/sdk/eventhub/event-processor-host/samples/javascript/sendBatch.js index 38decaa6641c..090b1c755c58 100644 --- a/sdk/eventhub/event-processor-host/samples/javascript/sendBatch.js +++ b/sdk/eventhub/event-processor-host/samples/javascript/sendBatch.js @@ -2,41 +2,7 @@ Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT Licence. - This sample is to populate your Event Hubs instance (in case it is empty) with events before you try - any of the other samples that show how to receive the events from Even + The sample to populate your Event Hubs instance with events before you try + any of the other samples that show how to receive the events from Event Hubs is moved to + https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-hubs/samples/javascript/sendEvents.js */ - -const { EventHubClient } = require("@azure/event-hubs"); - -// Define connection string and related Event Hub entity name here -const connectionString = ""; -const eventHubName = ""; - -async function main() { - const client = EventHubClient.createFromConnectionString(connectionString, eventHubName); - const partitionIds = await client.getPartitionIds(); - const messageCount = 300; - - const events = []; - // NOTE: For receiving events from Azure Stream Analytics, please send Events to an EventHub - // where the body is a JSON object/array. - // const events = [ - // { body: { "message": "Hello World 1" }, applicationProperties: { id: "Some id" }, partitionKey: "pk786" }, - // { body: { "message": "Hello World 2" } }, - // { body: { "message": "Hello World 3" } } - // ]; - for (let i = 0; i < messageCount; i++) { - events.push({ body: `Hello foo ${i}` }); - } - console.log("Sending batch events..."); - - // Will concurrently send batched events to all the partitions. - const sendPromises = partitionIds.map((id) => client.sendBatch(events, id)); - - await Promise.all(sendPromises); - await client.close(); -} - -main().catch((err) => { - console.log("Error occurred: ", err); -}); diff --git a/sdk/eventhub/event-processor-host/samples/javascript/singleEph.js b/sdk/eventhub/event-processor-host/samples/javascript/singleEph.js index 5812419d4148..87f51a2b883a 100644 --- a/sdk/eventhub/event-processor-host/samples/javascript/singleEph.js +++ b/sdk/eventhub/event-processor-host/samples/javascript/singleEph.js @@ -13,6 +13,10 @@ to learn about Event Processor Host. */ +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + const { EventProcessorHost, delay } = require("@azure/event-processor-host"); // Define storage connection string and Event Hubs connection string and related entity name here diff --git a/sdk/eventhub/event-processor-host/samples/javascript/websockets.js b/sdk/eventhub/event-processor-host/samples/javascript/websockets.js index 16727d602597..0259b97b716f 100644 --- a/sdk/eventhub/event-processor-host/samples/javascript/websockets.js +++ b/sdk/eventhub/event-processor-host/samples/javascript/websockets.js @@ -10,6 +10,10 @@ - The `https-proxy-agent` to enable the `ws` library to work with a proxy server. */ +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + const { EventProcessorHost } = require("@azure/event-processor-host"); const WebSocket = require("ws"); const url = require("url"); diff --git a/sdk/eventhub/event-processor-host/samples/typescript/src/iothubEph.ts b/sdk/eventhub/event-processor-host/samples/typescript/src/iothubEph.ts index 4d7b310d4bf8..26848125e1c9 100644 --- a/sdk/eventhub/event-processor-host/samples/typescript/src/iothubEph.ts +++ b/sdk/eventhub/event-processor-host/samples/typescript/src/iothubEph.ts @@ -16,6 +16,10 @@ import { delay } from "@azure/event-processor-host"; +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + // Define IoT Hub and storage connection strings here const iotConnectionString = ""; const storageConnectionString = ""; diff --git a/sdk/eventhub/event-processor-host/samples/typescript/src/multiEph.ts b/sdk/eventhub/event-processor-host/samples/typescript/src/multiEph.ts index 6dc803fd0fba..59679d54389b 100644 --- a/sdk/eventhub/event-processor-host/samples/typescript/src/multiEph.ts +++ b/sdk/eventhub/event-processor-host/samples/typescript/src/multiEph.ts @@ -22,6 +22,10 @@ import { delay } from "@azure/event-processor-host"; +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + // Define Storage and Event Hubs connection strings and related Event Hubs entity name here const ehConnectionString = ""; const eventHubsName = ""; diff --git a/sdk/eventhub/event-processor-host/samples/typescript/src/sendBatch.ts b/sdk/eventhub/event-processor-host/samples/typescript/src/sendBatch.ts index 19a99ff37319..8c6c93b665eb 100644 --- a/sdk/eventhub/event-processor-host/samples/typescript/src/sendBatch.ts +++ b/sdk/eventhub/event-processor-host/samples/typescript/src/sendBatch.ts @@ -2,41 +2,7 @@ Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT Licence. - This sample is to populate your Event Hubs instance (in case it is empty) with events before you try - any of the other samples that show how to receive the events from Even + The sample to populate your Event Hubs instance with events before you try + any of the other samples that show how to receive the events from Event Hubs is moved to + https://github.com/Azure/azure-sdk-for-js/blob/master/sdk/eventhub/event-hubs/samples/typescript/src/sendEvents.ts */ - -import { EventHubClient, EventData } from "@azure/event-hubs"; - -// Define connection string and related Event Hub entity name here -const connectionString = ""; -const eventHubName = ""; - -export async function main(): Promise { - const client = EventHubClient.createFromConnectionString(connectionString, eventHubName); - const partitionIds = await client.getPartitionIds(); - const messageCount = 300; - - const events: EventData[] = []; - // NOTE: For receiving events from Azure Stream Analytics, please send Events to an EventHub - // where the body is a JSON object/array. - // const events = [ - // { body: { "message": "Hello World 1" }, applicationProperties: { id: "Some id" }, partitionKey: "pk786" }, - // { body: { "message": "Hello World 2" } }, - // { body: { "message": "Hello World 3" } } - // ]; - for (let i = 0; i < messageCount; i++) { - events.push({ body: `Hello foo ${i}` }); - } - console.log("Sending batch events..."); - - // Will concurrently send batched events to all the partitions. - const sendPromises = partitionIds.map((id) => client.sendBatch(events, id)); - - await Promise.all(sendPromises); - await client.close(); -} - -main().catch((err) => { - console.log("Error occurred: ", err); -}); diff --git a/sdk/eventhub/event-processor-host/samples/typescript/src/singleEph.ts b/sdk/eventhub/event-processor-host/samples/typescript/src/singleEph.ts index a25ea446f0c5..203b4b9521da 100644 --- a/sdk/eventhub/event-processor-host/samples/typescript/src/singleEph.ts +++ b/sdk/eventhub/event-processor-host/samples/typescript/src/singleEph.ts @@ -22,6 +22,10 @@ import { delay } from "@azure/event-processor-host"; +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + // Define storage connection string and Event Hubs connection string and related entity name here const ehConnectionString = ""; const eventHubsName = ""; diff --git a/sdk/eventhub/event-processor-host/samples/typescript/src/websockets.ts b/sdk/eventhub/event-processor-host/samples/typescript/src/websockets.ts index ac3c0f78ae76..cfc48f694913 100644 --- a/sdk/eventhub/event-processor-host/samples/typescript/src/websockets.ts +++ b/sdk/eventhub/event-processor-host/samples/typescript/src/websockets.ts @@ -12,6 +12,11 @@ import { EventProcessorHost } from "@azure/event-processor-host"; import WebSocket from "ws"; + +console.warn( + "The package @azure/event-processor-host is deprecated in favor of @azure/event-hubs and @azure/eventhubs-checkpointstore-blob" +); + const url = require("url"); const httpsProxyAgent = require("https-proxy-agent");