Présentation
Spark Streaming est un ajout à l'API Spark pour la diffusion en direct et le traitement de données à grande échelle. Au lieu de traiter d'énormes quantités de données brutes non structurées et de les nettoyer ensuite, Spark Streaming effectue un traitement et une collecte de données en temps quasi réel.
Cet article explique ce qu'est Spark Streaming, comment il fonctionne et fournit un exemple d'utilisation de données en streaming.
Prérequis
- Apache Spark installé et configuré (Suivez nos guides :Comment installer Spark sur Ubuntu, Comment installer Spark sur Windows 10)
- Environnement configuré pour Spark (nous utiliserons Pyspark dans les notebooks Jupyter).
- Flux de données (nous utiliserons l'API Twitter).
- Bibliothèques Python tweepy , json , et prise pour diffuser des données depuis Twitter (utilisez pip pour les installer).
Qu'est-ce que la diffusion Spark ?
Spark Streaming est une bibliothèque Spark pour le traitement de flux de données quasi continus. L'abstraction de base est un flux discret créé par l'API Spark DStream pour diviser les données en lots. L'API DStream est alimentée par Spark RDD (Resilient Distributed Datasets), permettant une intégration transparente avec d'autres modules Apache Spark tels que Spark SQL et MLlib.
Les entreprises exploitent la puissance de Spark Streaming dans de nombreux cas d'utilisation différents :
- ETL de diffusion en direct – Nettoyage et combinaison des données avant stockage.
- Apprentissage continu – Mise à jour constante des modèles de machine learning avec de nouvelles informations.
- Déclenchement sur événements – Détecter les anomalies en temps réel.
- Enrichir les données – Ajout d'informations statistiques aux données avant stockage.
- Sessions complexes en direct – Regroupement de l'activité des utilisateurs à des fins d'analyse.
L'approche de diffusion en continu permet une analyse plus rapide du comportement des clients, des systèmes de recommandation plus rapides et une détection des fraudes en temps réel. Pour les ingénieurs, toute sorte d'anomalie de capteur provenant d'appareils IoT est visible au fur et à mesure que les données sont collectées.
Aspects du streaming Spark
Spark Streaming prend en charge nativement les charges de travail par lots et par streaming, ce qui apporte des améliorations intéressantes aux flux de données. Cet aspect unique répond aux exigences suivantes des systèmes de flux de données modernes :
- Équilibrage de charge dynamique. Étant donné que les données se divisent en micro-lots, les goulots d'étranglement ne sont plus un problème. L'architecture traditionnelle traite un enregistrement à la fois, et une fois qu'une partition intensive en calcul arrive, elle bloque toutes les autres données sur ce nœud. Avec Spark Streaming, les tâches sont réparties entre les travailleurs, certains traitant des tâches plus longues et d'autres des tâches plus courtes en fonction des ressources disponibles.
- Reprise après échec. Les tâches ayant échoué sur un nœud se discrétisent et se répartissent entre les autres travailleurs. Pendant que les noeuds worker effectuent le calcul, le retardataire a le temps de récupérer.
- Analyses interactives. Les DStreams sont une série de RDD. Des lots de flux de données stockés dans la mémoire du nœud de calcul interrogent de manière interactive.
- Analyses avancées. Les RDD générés par DStreams sont convertis en DataFrames qui interrogent avec SQL et s'étendent aux bibliothèques, telles que MLlib, pour créer des modèles d'apprentissage automatique et les appliquer aux données en continu.
- Amélioration des performances de diffusion. Le streaming par lots augmente les performances de débit, en exploitant des latences aussi faibles que quelques centaines de millisecondes.
Avantages et inconvénients du streaming Spark
Chaque technologie, y compris Spark Streaming, présente des avantages et des inconvénients :
Avantages | Inconvénients |
Performances de vitesse exceptionnelles pour les tâches complexes | Grande consommation de mémoire |
Tolérance aux pannes | Difficile à utiliser, déboguer et apprendre |
Facile à mettre en œuvre sur des clusters cloud | Pas bien documenté et les ressources d'apprentissage sont rares |
Prise en charge multilingue | Mauvaise visualisation des données |
Intégration pour les frameworks Big Data tels que Cassandra et MongoDB | Lent avec de petites quantités de données |
Capacité à joindre plusieurs types de bases de données | Peu d'algorithmes d'apprentissage automatique |
Comment fonctionne la diffusion Spark ?
Spark Streaming traite des analyses complexes et à grande échelle en temps quasi réel. Le pipeline de traitement de flux distribué passe par trois étapes :
1. Recevoir diffuser des données à partir de sources de diffusion en direct.
2. Processus les données sur un cluster en parallèle.
3. Sortie les données traitées dans les systèmes.
Architecture de diffusion Spark
L'architecture de base de Spark Streaming est en streaming discrétisé de lots. Au lieu de passer par le pipeline de traitement de flux un enregistrement à la fois, les micro-lots sont affectés et traités dynamiquement. Par conséquent, les données sont transférées aux travailleurs en fonction des ressources disponibles et de la localité.
Lorsque les données arrivent, le récepteur les divise en partitions de RDD. La conversion en RDD permet de traiter des lots à l'aide de codes et de bibliothèques Spark, car les RDD sont une abstraction fondamentale des ensembles de données Spark.
Sources de diffusion Spark
Les flux de données nécessitent des données reçues des sources. Le streaming Spark divise ces sources en deux catégories :
- Sources de base. Les sources directement disponibles dans l'API Streaming core, telles que les connexions socket et les systèmes de fichiers compatibles avec le HDFS
- Sources avancées. Les sources nécessitent des dépendances de liaison et ne sont pas disponibles dans l'API principale de streaming, comme Kafka ou Kinesis.
Chaque entrée DStream se connecte à un récepteur. Pour les flux de données parallèles, la création de plusieurs DStream génère également plusieurs récepteurs.
Activer les opérations de streaming
Spark Streaming inclut l'exécution de différents types d'opérations :
1. Opérations de transformation modifier les données reçues des DStreams d'entrée, similaires à celles appliquées aux RDD. Les opérations de transformation sont évaluées paresseusement et ne s'exécutent pas tant que les données n'ont pas atteint la sortie.
2. Opérations de sortie poussez les DStreams vers des systèmes externes, tels que des bases de données ou des systèmes de fichiers. Le déplacement vers des systèmes externes déclenche les opérations de transformation.
3. Opérations DataFrame et SQL se produisent lors de la conversion de RDD en DataFrames et de leur enregistrement en tant que tables temporaires pour effectuer des requêtes.
4. Opérations MLlib sont utilisés pour exécuter des algorithmes d'apprentissage automatique, notamment :
- Algorithmes de diffusion s'appliquent aux données en direct, telles que la régression linéaire en continu ou les k-moyennes en continu.
- Algorithmes hors ligne pour apprendre un modèle hors ligne avec des données historiques et appliquer l'algorithme pour diffuser des données en ligne.
Exemple de diffusion Spark
L'exemple de flux a la structure suivante :
L'architecture est divisée en deux parties et fonctionne à partir de deux fichiers :
- Exécuter le premier fichier pour établir une connexion avec l'API Twitter et créer un socket entre l'API Twitter et Spark. Gardez le fichier en cours d'exécution.
- Exécutez le deuxième fichier pour demander et commencer à diffuser les données, en imprimant les Tweets traités sur la console. Les données envoyées non traitées s'impriment dans le premier fichier.
Créer un objet écouteur Twitter
Le TweetListener l'objet écoute les Tweets du flux Twitter avec le StreamListener de tweepy . Lorsqu'une requête est faite sur le socket au serveur (local), le TweetListener écoute les données et extrait les informations du Tweet (le texte du Tweet). Si l'objet Tweet étendu est disponible, le TweetListener récupère l'objet étendu champ, sinon le texte champ est récupéré. Enfin, l'auditeur ajoute __end à la fin de chaque Tweet. Cette étape nous aide ensuite à filtrer le flux de données dans Spark.
import tweepy
import json
from tweepy.streaming import StreamListener
class TweetListener(StreamListener):
# tweet object listens for the tweets
def __init__(self, csocket):
self.client_socket = csocket
def on_data(self, data):
try:
# Load data
msg = json.loads(data)
# Read extended Tweet if available
if "extended_tweet" in msg:
# Add "__end" at the end of each Tweet
self.client_socket\
.send(str(msg['extended_tweet']['full_text']+" __end")\
.encode('utf-8'))
print(msg['extended_tweet']['full_text'])
# Else read Tweet text
else:
# Add "__end" at the end of each Tweet
self.client_socket\
.send(str(msg['text']+"__end")\
.encode('utf-8'))
print(msg['text'])
return True
except BaseException as e:
print("error on_data: %s" % str(e))
return True
def on_error(self, status):
print(status)
return True
Si des erreurs se produisent dans la connexion, la console imprime les informations.
Recueillir les identifiants de développeur Twitter
Le portail des développeurs de Twitter contient les informations d'identification OAuth pour établir une connexion API avec Twitter. Les informations sont dans l'application Clés et jetons onglet.
Pour collecter les données :
1. Générez la clé API et le secret situé dans les Consumer Keys section du projet et enregistrez les informations :
Les Clés du consommateur vérifier sur Twitter votre identité, comme un nom d'utilisateur.
2. Générer le jeton d'accès et le secret à partir des jetons d'authentification section et enregistrez les informations :
Les jetons d'authentification autoriser l'extraction de données spécifiques de Twitter.
Envoyer des données de l'API Twitter au socket
À l'aide des informations d'identification du développeur, remplissez la API_KEY , API_SECRET , ACCESS_TOKEN , et ACCESS_SECRET pour accéder à l'API Twitter.
La fonction sendData exécute le flux Twitter lorsqu'un client fait une demande. La demande de flux est d'abord vérifiée, puis un objet écouteur est créé et les données de flux sont filtrées en fonction du mot-clé et de la langue.
Par exemple :
from tweepy import Stream
from tweepy import OAuthHandler
API_KEY = "api_key"
API_SECRET = "api_secret"
ACCESS_TOKEN = "access_token"
ACCESS_SECRET = "access_secret"
def sendData(c_socket, keyword):
print("Start sending data from Twitter to socket")
# Authentication based on the developer credentials from twitter
auth = OAuthHandler(API_KEY, API_SECRET)
auth.set_access_token(ACCESS_TOKEN, ACCESS_SECRET)
# Send data from the Stream API
twitter_stream = Stream(auth, TweetListener(c_socket))
# Filter by keyword and language
twitter_stream.filter(track = keyword, languages=["en"])
Créer un socket TCP d'écoute sur le serveur
La dernière partie du premier fichier comprend la création d'un socket d'écoute sur un serveur local. L'adresse et le port sont liés et écoutent les connexions du client Spark.
Par exemple :
import socket
if __name__ == "__main__":
# Create listening socket on server (local)
s = socket.socket()
# Host address and port
host = "127.0.0.1"
port = 5555
s.bind((host, port))
print("Socket is established")
# Server listens for connections
s.listen(4)
print("Socket is listening")
# Return the socket and the address of the client
c_socket, addr = s.accept()
print("Received request from: " + str(addr))
# Send data to client via socket for selected keyword
sendData(c_socket, keyword = ['covid'])
Une fois que le client Spark a fait une demande, le socket et l'adresse du client s'impriment sur la console. Ensuite, le flux de données est envoyé au client en fonction du filtre de mot-clé sélectionné.
Cette étape conclut le code dans le premier fichier. Son exécution imprime les informations suivantes :
Gardez le fichier en cours d'exécution et continuez à créer un client Spark.
Créer un récepteur Spark DStream
Dans un autre fichier, créez un contexte Spark et un contexte de diffusion local avec des intervalles de lot d'une seconde. Le client lit à partir du nom d'hôte et du socket de port.
import findspark
findspark.init()
from pyspark import SparkContext
from pyspark.streaming import StreamingContext
sc = SparkContext(appName="tweetStream")
# Create a local StreamingContext with batch interval of 1 second
ssc = StreamingContext(sc, 1)
# Create a DStream that conencts to hostname:port
lines = ssc.socketTextStream("127.0.0.1", 5555)
Prétraiter les données
Le prétraitement des RDD comprend le fractionnement des lignes de données reçues où __end apparaît et transforme le texte en minuscules. Les dix premiers éléments s'impriment sur la console.
# Split Tweets
words = lines.flatMap(lambda s: s.lower().split("__end"))
# Print the first ten elements of each DStream RDD to the console
words.pprint()
Après avoir exécuté le code, rien ne se passe puisque l'évaluation est paresseuse. Le calcul commence lorsque le contexte de diffusion commence.
Commencer à diffuser le contexte et le calcul
Le démarrage du contexte de diffusion envoie une requête à l'hôte. L'hôte renvoie les données collectées de Twitter au client Spark, et le client prétraite les données. La console imprime alors le résultat.
# Start computing
ssc.start()
# Wait for termination
ssc.awaitTermination()
Le démarrage du contexte de diffusion imprime dans le premier fichier une demande reçue et diffuse le texte de données brutes :
Le deuxième fichier lit les données toutes les secondes à partir du socket et le prétraitement s'applique aux données. Les deux premières lignes sont vides jusqu'à ce que la connexion soit établie :
Le contexte de diffusion est prêt à être interrompu à tout moment.