Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mchmarny/dapr-pipeline
Example of Twitter event processing pipeline using dapr framewrk
https://github.com/mchmarny/dapr-pipeline
dapr eventing framework pipeline processing serverless twitter
Last synced: 3 months ago
JSON representation
Example of Twitter event processing pipeline using dapr framewrk
- Host: GitHub
- URL: https://github.com/mchmarny/dapr-pipeline
- Owner: mchmarny
- License: apache-2.0
- Created: 2020-04-10T20:44:51.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-05T02:25:31.000Z (over 1 year ago)
- Last Synced: 2024-06-22T15:49:41.508Z (7 months ago)
- Topics: dapr, eventing, framework, pipeline, processing, serverless, twitter
- Language: Go
- Homepage:
- Size: 48.2 MB
- Stars: 20
- Watchers: 4
- Forks: 7
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# dapr-pipeline
Example of Twitter event processing pipeline using dapr framework.
![alt text](resource/image/overview-local.png "Local Pipeline Overview")
> This readme covers local deployment. For Kubernetes deployment instructions [see here](./deployment/)
> To keep it DRY, this demo uses [godapr](https://github.com/mchmarny/godapr) HTTP client
## Prerequisites
### Dapr
To run this demo locally, you will have to install [Dapr](https://github.com/dapr/docs/blob/master/getting-started/environment-setup.md).
To use the Dapr twitter binding you will also need Twitter API consumer keys and secrets. You can get these by registering your Twitter application [here](https://developer.twitter.com/en/apps/create).
### Cognitive Services
To analyze sentiment of each text, you will also need an API token for the Azure [Cognitive Services](https://azure.microsoft.com/en-us/services/cognitive-services/). You can learn more about the API and how to configure it [here](https://docs.microsoft.com/en-us/azure/cognitive-services/text-analytics/how-tos/text-analytics-how-to-sentiment-analysis?tabs=version-2#sentiment-analysis-versions-and-features).
## Setup
Assuming you have all the prerequisites mentioned above you can demo this dapr pipeline in following steps. First, start by cloning this repo:
```shell
git clone https://github.com/mchmarny/dapr-pipeline.git
```and then navigate into the `dapr-pipeline` directory:
```shell
cd dapr-pipeline
```and build the executables for your OS
```shell
bin/build
```> Note, if you don't have `go` you can download the pre-built executables for Mac, Windows or Linux from the [latest release](https://github.com/mchmarny/dapr-pipeline/releases/latest).
## Run
This pipeline consists of three microservices: Processor, Sentimenter, and Viewer. Still inside of the the `dapr-pipeline` you cloned above, follow these instructions to launching each one of these services:
### Sentimenter
To starting `sentimenter`, first export your Azure Cognitive Services API key (see the [Prerequisites](#prerequisites) section for details).
```shell
export CS_TOKEN=""
```And then launch it using Dapr:
```shell
dapr run dist/sentimenter --app-id sentimenter --app-port 8082 --protocol http
```If everything goes well when launch these services using Dapr you will see following message:
```shell
ℹ️ Updating metadata for app command: bin/sentimenter
✅ You're up and running! Both Dapr and your app logs will appear here.
```### Viewer
Next, start `viewer`. In yet another terminal window navigate to the `dapr-pipeline` directory and run:
```shell
dapr run dist/viewer --app-id viewer --app-port 8083 --protocol http
```While there still won't be any data, at this point you should be able to navigate to the viewer UI
http://localhost:8083/
### Processor
Finally, to start the `processor`, first edit the Dapr [Twitter input binding component](components/twitter.yaml) using the Twitter API secrets your created in [Prerequisites](#prerequisites)):
```yaml
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: tweets
spec:
type: bindings.twitter
metadata:
- name: consumerKey
value: ""
- name: consumerSecret
value: ""
- name: accessToken
value: ""
- name: accessSecret
value: ""
- name: query
value: "serverless"
```> For demo purposes use a search term that appears often on Twitter (e.g. serverless)
Once the Twitter API secrets are set, you are ready to run the `processor`:
```shell
dapr run dist/processor --app-id processor --app-port 8081 --protocol http --port 3500
```### Dashboard
Once all three microservices are running, you can go back to the `viewer` (http://localhost:8083/). After a few moments you should see something like this:
![](resource/image/ui.png)
The icon left of the tweet author's username indicates the sentiment (positive , negative , or neutral ). The Twitter logo right of the username is also linked to the original tweet on https://twitter.com.
> YOu can find how-to on deployment this demo on Kubernetes [here](./deployment/)
## Disclaimer
This is my personal project and it does not represent my employer. I take no responsibility for issues caused by this code. I do my best to ensure that everything works, but if something goes wrong, my apologies is all you will get.
## License
This software is released under the [Apache v2 License](./LICENSE)