Create Table Hive for Twitter Feeds
Introduction
Social Media Analytics is one of the major uses of Big Data. This article shows how to use a Hive in Azure HDInsight to analyze Twitter feeds.
In this article, feeds about "Mauritius" shall be extracted and analyzed using Azure HDInsight.
Prerequisites
- Introduction to Big Data Analytics Using Microsoft Azure
- Big Data Analytics Using Hive on Microsoft Azure
Create a Twitter Application
For creating an application on Twitter, use the Twitter APIs, read data from Twitter and also post tweets if required.
To create your first Twitter Application:
- Go to https://dev.twitter.com/apps.
- Click on Create New App.
- Fill in the required details and create the app.
Once the app is created, navigate to the Keys and Access tokens in your application, this is where the keys to read data from Twitter can be obtained.
Extract the Tweets
The tweets shall be extracted using a PowerShell script, uploaded to Azure Storage before being processed by Azure HDInsight.
The following is the procedure to extract the tweets and save them to an Azure BLOB storage.
Define the variables
In this step, all the variables used in the PowerShell Script is defined.
- # Enter the HDInsight cluster name
- $clusterName ="chervinehadoop"
- # Enter the OAuth information for your Twitter application. These information in obtained in part 1
- $oauth_consumer_key ="" ;
- $oauth_consumer_secret ="" ;
- $oauth_token ="" ;
- $oauth_token_secret ="" ;
- # Path to save the Tweets on the Azure Blob Storage
- $destBlobName ="Tweets/MRUTweets.txt"
- # This script gets the tweets containing these keywords.
- $trackString ="Mauritius"
- $track = [System.Uri]::EscapeDataString($trackString);
- $lineMax = 24
Connect to an Azure Account
This will open an interface to capture your login credentials.
Add-AzureAccount.
If the authentication is successful, your ID and subscriptions should be displayed in PowerShell.
Create BLOB Storage
Create a BLOB Storage where the tweets shall be saved as in the following:
- $myCluster = Get-AzureHDInsightCluster -Name $clusterName
- $storageAccountName =$myCluster.DefaultStorageAccount.StorageAccountName.Replace(".blob.core.windows.net" , "" )
- $containerName = $myCluster.DefaultStorageAccount.StorageContainerName
- $storageAccountKey =get -azurestoragekey $storageAccountName | %{$_.Primary}
- $storageConnectionString ="DefaultEndpointsProtocol=https;AccountName=$storageAccountName;AccountKey=$storageAccountKey"
- $storageAccount =[Microsoft.WindowsAzure.Storage.CloudStorageAccount]::Parse($storageConnectionString)
- $storageClient = $storageAccount.CreateCloudBlobClient();
- $storageContainer = $storageClient.GetContainerReference($containerName)
- $destBlob = $storageContainer.GetBlockBlobReference($destBlobName)
OAuth Connection String
Build the OAuth Connection String to connect to Twitter as in the following:
- $oauth_nonce =[System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes([System.DateTime]::Now.Ticks.ToString()));
- $ts = [System.DateTime]::UtcNow - [System.DateTime]::ParseExact("01/01/1970" , "dd/MM/yyyy" , $ null )
- $oauth_timestamp = [System.Convert]::ToInt64($ts.TotalSeconds).ToString();
- $signature ="POST&" ;
- $signature +=[System.Uri]::EscapeDataString("https://stream.twitter.com/1.1/statuses/filter.json " )+ "&" ;
- $signature += [System.Uri]::EscapeDataString("oauth_consumer_key=" + $oauth_consumer_key + "&" );
- $signature += [System.Uri]::EscapeDataString("oauth_nonce=" + $oauth_nonce + "&" );
- $signature += [System.Uri]::EscapeDataString("oauth_signature_method=HMAC-SHA1&" );
- $signature += [System.Uri]::EscapeDataString("oauth_timestamp=" + $oauth_timestamp + "&" );
- $signature += [System.Uri]::EscapeDataString("oauth_token=" + $oauth_token + "&" );
- $signature += [System.Uri]::EscapeDataString("oauth_version=1.0&" );
- $signature += [System.Uri]::EscapeDataString("track=" + $track);
- $signature_key = [System.Uri]::EscapeDataString($oauth_consumer_secret) +"&" +[System.Uri]::EscapeDataString($oauth_token_secret);
- $hmacsha1 =new - object System.Security.Cryptography.HMACSHA1;
- $hmacsha1.Key = [System.Text.Encoding]::ASCII.GetBytes($signature_key);
- $oauth_signature =[System.Convert]::ToBase64String($hmacsha1.ComputeHash([System.Text.Encoding]::ASCII.GetBytes($signature)));
- $oauth_authorization ='OAuth ' ;
- $oauth_authorization +='oauth_consumer_key="' +[System.Uri]::EscapeDataString($oauth_consumer_key) + '",' ;
- $oauth_authorization +='oauth_nonce="' + [System.Uri]::EscapeDataString($oauth_nonce) + '",' ;
- $oauth_authorization +='oauth_signature="' +[System.Uri]::EscapeDataString($oauth_signature) + '",' ;
- $oauth_authorization +='oauth_signature_method="HMAC-SHA1",'
- $oauth_authorization +='oauth_timestamp="' +[System.Uri]::EscapeDataString($oauth_timestamp) + '",'
- $oauth_authorization +='oauth_token="' + [System.Uri]::EscapeDataString($oauth_token) + '",' ;
- $oauth_authorization +='oauth_version="1.0"' ;
- $post_body = [System.Text.Encoding]::ASCII.GetBytes("track=" + $track);
Read the tweets
Read the tweets as in the following:
- Write-Host "signature= " + $signature
- [System.Net.HttpWebRequest] $request =[System.Net.WebRequest]::Create("https://stream.twitter.com/1.1/statuses/filter.json " );
- $request.Method ="POST" ;
- $request.Headers.Add("Authorization" , $oauth_authorization);
- $request.ContentType ="application/x-www-form-urlencoded" ;
- $body = $request.GetRequestStream();
- $body.write($post_body, 0, $post_body.length);
- $body.flush();
- $body.close();
- $response = $request.GetResponse() ;
- $memStream = New-Object System.IO.MemoryStream
- $writeStream = New-Object System.IO.StreamWriter $memStream
- $sReader = New-Object System.IO.StreamReader($response.GetResponseStream())
- $inrec = $sReader.ReadLine()
- $count = 0
- while (($inrec -ne $ null ) -and ($count -le $lineMax))
- {
- if ($inrec -ne "" )
- {
- Write-Host"`n`t $count tweets received." -ForegroundColor Yellow
- $writeStream.WriteLine($inrec)
- $count ++
- }
- $inrec=$sReader.ReadLine()
- }
Save the tweets to the BLOB storage as in the following:
- $writeStream.Flush()
- $memStream.Seek(0,"Begin" )
- $destBlob.UploadFromStream($memStream)
- $sReader.close ()
At this stage, the file has been uploaded to the BLOB storage in the default container at the path Tweets/MRUTweets.txt.
The file may also be downloaded to view its contents.
Process the Tweets using Hive
The following procedure describes how to read the Tweets from the BLOB Storage and analyze them using Hive on HDInsight.
- Open the Query Console
From your Hadoop Cluster, click on Query Console.Fill in your credentials and go to the Hive Editor.
- Create Staging table RAW_TWEETS
Load all the data from the file in the table RAW_TWEETS.
- DROP TABLE IF EXISTS RAW_TWEETS;
- CREATE EXTERNAL TABLE RAW_TWEETS(json_response STRING)
- STOREDAS TEXTFILE LOCATION 'wasb://chervinehadoop@chervinestoragehadoop.blob.core.windows.net/Tweets/' ;
The following are the contents of the table RAW_TWEETS.
- SELECT * FROM RAW_TWEETS;
- Create table TWEETS
This is where the processed (parsed) JSON Twitter data will be stored.
- DROP TABLE IF EXISTS TWEETS;
- CREATE TABLE TWEETS(
- idBIGINT ,
- created_at STRING,
- created_at_date STRING,
- created_at_year STRING,
- created_at_month STRING,
- created_at_day STRING,
- created_at_time STRING,
- in_reply_to_user_id_str STRING,
- text STRING,
- contributors STRING,
- retweeted STRING,
- truncated STRING,
- coordinates STRING,
- source STRING,
- retweet_countINT ,
- url STRING,
- hashtags array<STRING>,
- user_mentions array<STRING>,
- first_hashtag STRING,
- first_user_mention STRING,
- screen_name STRING,
- name STRING,
- followers_countINT ,
- listed_countINT ,
- friends_countINT ,
- lang STRING,
- user_location STRING,
- time_zone STRING,
- profile_image_url STRING,
- json_response STRING);
- Load table TWEETS
Parse the JSON tweets from the table RAW_TWEETS and store them into the table TWEETS.
- FROM RAW_TWEETS
- INSERT OVERWRITE TABLE TWEETS
- SELECT
- CAST (get_json_object(json_response, '$.id_str' ) as BIGINT ),
- get_json_object(json_response,'$.created_at' ),
- CONCAT(SUBSTR (get_json_object(json_response,'$.created_at' ),1,10), ' ' ,
- SUBSTR (get_json_object(json_response,'$.created_at' ),27,4)),
- SUBSTR (get_json_object(json_response,'$.created_at' ),27,4),
- CASE SUBSTR (get_json_object(json_response, '$.created_at' ),5,3)
- WHEN 'Jan' then '01'
- WHEN 'Feb' then '02'
- WHEN 'Mar' then '03'
- WHEN 'Apr' then '04'
- WHEN 'May' then '05'
- WHEN 'Jun' then '06'
- WHEN 'Jul' then '07'
- WHEN 'Aug' then '08'
- WHEN 'Sep' then '09'
- WHEN 'Oct' then '10'
- WHEN 'Nov' then '11'
- WHEN 'Dec' then '12' end ,
- SUBSTR (get_json_object(json_response,'$.created_at' ),9,2),
- SUBSTR (get_json_object(json_response,'$.created_at' ),12,8),
- get_json_object(json_response,'$.in_reply_to_user_id_str' ),
- get_json_object(json_response,'$.text' ),
- get_json_object(json_response,'$.contributors' ),
- get_json_object(json_response,'$.retweeted' ),
- get_json_object(json_response,'$.truncated' ),
- get_json_object(json_response,'$.coordinates' ),
- get_json_object(json_response,'$.source' ),
- CAST (get_json_object(json_response, '$.retweet_count' ) as INT ),
- get_json_object(json_response,'$.entities.display_url' ),
- ARRAY(
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[0].text' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[1].text' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[2].text' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[3].text' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[4].text' )))),
- ARRAY(
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[0].screen_name' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[1].screen_name' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[2].screen_name' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[3].screen_name' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[4].screen_name' )))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.hashtags[0].text' ))),
- TRIM(LOWER (get_json_object(json_response, '$.entities.user_mentions[0].screen_name' ))),
- get_json_object(json_response,'$.user.screen_name' ),
- get_json_object(json_response,'$.user.name' ),
- CAST (get_json_object(json_response, '$.user.followers_count' ) as INT ),
- CAST (get_json_object(json_response, '$.user.listed_count' ) as INT ),
- CAST (get_json_object(json_response, '$.user.friends_count' ) as INT ),
- get_json_object(json_response,'$.user.lang' ),
- get_json_object(json_response,'$.user.location' ),
- get_json_object(json_response,'$.user.time_zone' ),
- get_json_object(json_response,'$.user.profile_image_url' ),
- json_response;
- SELECT * FROM TWEETS
The result can also be downloaded and viewed locally.
- Create Summarized Hive table for Analysis
- View top users who are tweeting about Mauritius
- DROP TABLE IF EXISTS topusers;
- CREATE TABLE IF NOT EXISTS topusers( name STRING, screen_name STRING, tweet_count INT );
- INSERT OVERWRITE TABLE topusers
- SELECT name , screen_name, count (1) as cc
- FROM TWEETS
- WHERE UPPER (text) LIKE '%MAURITIUS%'
- GROUP BY name , screen_name;
- View from which region people are tweeting about Mauritius
- DROP TABLE IF EXISTS topregion;
- CREATE TABLE IF NOT EXISTS topregion (region STRING, tweet_count INT );
- INSERT OVERWRITE TABLE topregion
- select user_location, count (1)
- from TWEETS
- group by user_location
- SELECT * FROM topregion
- View top users who are tweeting about Mauritius
Analyze the results in Microsoft Excel
- Install the Microsoft HDInsight Hive Driver
The driver can be found at the following location: http://www.microsoft.com/en-us/download/details.aspx?id=40886Note: It was noticed that both the 32 and 64 bit versions of it work.
- Configure the Data Source
Open the ODBC Data Source Administrator by clicking Start > Control Panel > Additional Options > Data Sources (ODBC). If you're prompted for an administrator password or confirmation, type the password or provide confirmation.Under User DSN, click add and select, Microsoft Hive ODBC Driver.
Fill in the required information as in the following. Of course include your password.
- View the result on Excel
- In Excel, go to the Data tab then from other sources, Microsoft Query.
- Select your data source.
- Add your required tables.
- View your data in Excel.
- In Excel, go to the Data tab then from other sources, Microsoft Query.
Conclusion
This article focused on demonstrating how Twitter feeds can be analyzed using Hive and HDInsight. However, the Analysis does not end here. This can be enhanced to discover lots of information about the customers of a company.
Imagine a company extracting Twitter feeds about its products, retrieve the data into its data warehouse and link the Twitter data to its existing customer base. The possibilities of customer information here is of a really high scope, from discovering where customers have negative views on its products, hence doing more advertising to understanding which customers needs which products.
Social Media analytics is definitely crucial to the understanding of customer behaviors these days.
Moreover, having technologies like HDInsight where everything is managed by Azure and the user just focuses on the business aspects makes Social Media / Big data analytics much easier and affordable.
References
- Analyze Twitter data using Hive in HDInsight
- Using the ODBC Data Source Administrator
Source: https://www.c-sharpcorner.com/UploadFile/a5470d/analyze-twitter-data-with-hive-in-azure-hdinsight/
0 Response to "Create Table Hive for Twitter Feeds"
Post a Comment