1973
Posts
1225
Kudos Received
124
Solutions
My Accepted Solutions
| Title | Views | Posted |
|---|---|---|
| 2557 | 04-03-2024 06:39 AM | |
| 3921 | 01-12-2024 08:19 AM | |
| 2122 | 12-07-2023 01:49 PM | |
| 3173 | 08-02-2023 07:30 AM | |
| 4306 | 03-29-2023 01:22 PM |
05-15-2020
07:15 PM
hello! If I insert a string containing 'or "or, PutSQL to Phoenix will be return the grammatical errors, this should be how to solve?
... View more
05-12-2020
11:47 AM
You should not use Flume. Flume and it's connectors are deprecated. This and any flow can easily move to NiFi. https://dev.to/tspannhw/migrating-apache-flume-flows-to-apache-nifi-jms-to-x-and-x-to-jms-1g02
... View more
05-08-2020
12:03 PM
Awesome. Good luck with NiFi.
... View more
04-27-2020
05:22 PM
1 Kudo
In the use case solved for this webinar, I am a Streaming Engineer at an airline, CloudAir. I need to find, filter and clean Twitter streams then perform sentiment analysis.
Score Models in the Stream to Act
As the Streaming Engineer at CloudAIR I am responsible for ingesting data from thousands of sources, operationalizing machine learning models as part of our streams, running real-time ELT/ETL processes and building event processing systems running from devices, servers and edge nodes. For today’s use case, one of our Machine Learning engineers had given me a model that was deployed into one of our production Cloudera Machine Learning (CML) environments. I logged into Cloudera, found the model, tested it, and then extracted the information I need to add this model to our streaming ingest flow for the social media team.
I have been given permissions to access the airline-sentiment workshop in CDP Public Cloud.
I can see all the models deployed in the project I have access to. I see that predict-sentiment is the one I am to use. It is deployed and has 8GB of RAM and 2 vCPU.
I can see that it has been running successfully for a while and I can test it right from the project.
You can see the URL after the POST and the accessKey is in JSON.
Ingesting & Pre-processing Data from Twitter
Using Cloudera Flow Management (CFM) I am ingesting real-time Twitter streams which I filter for only airline specific data. I then clean and transform these records in a few simple steps. The next pieces I will need are those two critical values from CML: the Access Key and URL for the model. I will add them to an instance of an ExecuteClouderaML processor.
I am also sending the raw tweet (large JSON files) to a Kafka topic for further processing by other teams.
I also need to store this data to tables for ad-hoc queries. So I quickly spin up a virtual warehouse with Impala for reporting uses. I will put my data into S3 buckets as Parquet files, with an external Impala table on top, for these reports.
Defining the Impala Table for Supporting Queries
Once my environment is ready, which will only take a few minutes, I will launch Hue to create a table.
From the virtual warehouse I can grab the JDBC URL that I will need to add to my Impala Connection pool in CFM for connecting to the warehouse. I will also need the JDBC driver.
From CFM I add a JDBC Controller and copy in the URL, the Impala driver name and a link to that JDBC jar. I will also set my user and password, or Kerberos credentials, to connect.
Using the Scores
After having called CML from CFM, I can see the scoring results and now use them to augment my twitter data. The data is added to the attributes for each event and does not affect the current flowfile data.
Now that data is streaming into Impala I can run ad-hoc queries and build charts on my sentiment-enriched, cleaned-up twitter data.
For those of you that love the command line, we can grab a link to the Impala command line tool for the virtual warehouse as well, and query from there. Good for quick checks.
Storing the Twitter Data in a Kudu Table
In another section of our flow we are also storing our enriched tweets in a CDP Data Center (CDP-DC) Kudu table for additional analytics that we are running in Hue and in a Jupyter notebook
that we spin up with our CDP-DC CML.
Jupyter notebooks spun up from Cloudera Machine Learning let me explore my data and do some charting, graphs and SQL work in Python3.
Assuring Data Governance and Lineage
One of the amazing features that comes in handy when you have a complex flow that spans a hybrid environment is to have data management and governance abilities. We can do that with Apache Atlas.
We can navigate and search through Atlas to see how data travels through Apache NiFi, Apache Kafka, tables and Cloudera Machine Learning model activities like deployment.
Final DataFlow For Scoring
We have a Query Record processor in CFM that analyzes the streaming events and looks for Negative sentiment by influencers, we then push those events to a Slack channel for our social media team to handle.
As we have seen, we are sending several different streams of data to Kafka topics for further processing with Spark Streaming, Flink, NiFi, Java and Kafka Streams applications. Using Cloudera Streams Messaging Manager we can see all the components of our Kafka cluster and where our events are as they travel through topics in various brokers. You can see messages in all of the partitions, you can also build up alerts for any part of your Kafka system. An important piece is you can trace messages from all of the consumers to all of the producers and see any lag or latency that occurs in clients.
We can also push to our Operational Database (HBase) and easily scan through the rapidly inserted rows.
This demo was presented in the webinar, Harnessing the Data Lifecycle for Customer Experience Optimization.
Source Code Resources
Queries, Python, Models, Notebooks
Example Cloudera Machine Learning Connector
SQL
... View more
04-03-2020
03:08 PM
Thanks for this writeup. I was having a heck of a time authenticating, was expecting the authentication keys to be separate fields in the processor configuration. I didn't realize you could add all that right in the connection string, although it leaves your passwords in plain text. Seems like an opportunity for improvement.
... View more
03-30-2020
11:45 AM
Can I use pyhive to connect to Hive using Hive JDBC string instead of a single hostname? The following doesn't work for me. from pyhive import hive hive_conn = hive.Connection(host=<JDBC STRING>, configuration {'serviceDiscoveryMode':'zooKeeper','zooKeeperNamespace':'hiveserver2'})
... View more
03-13-2020
12:14 AM
Can you please help me with this: Once I successfully upload the template and when using it, I got the following error: Error org.apache.nifi.processors.kite.InferAvroSchema is not known to this NiFi instance. My version: 1.11.3 02/21/2020 21:06:05 EST Tagged nifi-1.11.3-RC1
... View more
03-03-2020
09:19 AM
https://community.cloudera.com/t5/Community-Articles/ETL-With-Lookups-with-Apache-HBase-and-Apache-NiFi/ta-p/248243 That is an HBase example, just use a different one. We also teach how to do the lookup / update record processors in our CDF Workshop roadshow
... View more
01-30-2020
02:54 PM
Thanks you. This Worked!
... View more