Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fsanaulla/spark-http-rdd
RDD primitive for fetching data from an HTTP source
https://github.com/fsanaulla/spark-http-rdd
scala spark
Last synced: 27 days ago
JSON representation
RDD primitive for fetching data from an HTTP source
- Host: GitHub
- URL: https://github.com/fsanaulla/spark-http-rdd
- Owner: fsanaulla
- License: apache-2.0
- Created: 2021-02-19T22:38:07.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-02-27T19:48:10.000Z (8 months ago)
- Last Synced: 2024-05-01T14:57:34.473Z (6 months ago)
- Topics: scala, spark
- Language: Scala
- Homepage:
- Size: 104 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# spark-http-rdd
[![Scala CI](https://github.com/fsanaulla/spark-http-rdd/actions/workflows/scala.yml/badge.svg)](https://github.com/fsanaulla/spark-http-rdd/actions/workflows/scala.yml)
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.github.fsanaulla/spark2-http-rdd_2.12/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.github.fsanaulla/spark2-http-rdd_2.12)
[![Scala Steward badge](https://img.shields.io/badge/Scala_Steward-helping-blue.svg?style=flat&logo=)](https://scala-steward.org)## Installation
Add it into your `build.sbt`
### Spark 3
Compiled for scala 2.12
```
libraryDependencies += "com.github.fsanaulla" %% "spark3-http-rdd" %
```### Spark 2
Cross-compiled for scala 2.11, 2.12
```
libraryDependencies += "com.github.fsanaulla" %% "spark2-http-rdd" %
```## Usage
Let's define our source URI:
```scala
val baseUri: URI = ???
```We will build our partitions on top of it using array of `URIModifier` that looks like:
```scala
val uriPartitioner: Array[URIModifier] = Array(
URIModifier.fromFunction { uri =>
// uri modification logic,
// for example appending path, adding query params etc
},
...
)
```**Important**: Number of `URIModifier` should be equal to desired number of partitions. Each URI will be used as a
base URI for separate partitionThen we should define the way how we will work with http endpoint responses. By default it expect to receive line
separated number of rows where each row will be processed as separate entity during process of response mapping```scala
val mapping: String => T = ???
```And then you can create our RDD:
```scala
val rdd: RDD[T] =
HttpRDD.create(
sc,
baseUri,
uriPartitioner,
mapping
)
```More details available in the source code. Also as an example you can use integration tests