Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oracle-samples/oracle-dataflow-samples
Sample examples Examples demonstrating how to use OCI Data Flow
https://github.com/oracle-samples/oracle-dataflow-samples
dataflow java oracle-cloud oracle-cloud-infrastructure paas python scala serverless spark
Last synced: 6 days ago
JSON representation
Sample examples Examples demonstrating how to use OCI Data Flow
- Host: GitHub
- URL: https://github.com/oracle-samples/oracle-dataflow-samples
- Owner: oracle-samples
- License: upl-1.0
- Created: 2021-05-06T20:17:49.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-12-06T16:56:19.000Z (about 2 months ago)
- Last Synced: 2025-01-10T07:30:43.827Z (13 days ago)
- Topics: dataflow, java, oracle-cloud, oracle-cloud-infrastructure, paas, python, scala, serverless, spark
- Language: Scala
- Homepage: https://www.oracle.com/in/big-data/data-flow/
- Size: 27.2 MB
- Stars: 35
- Watchers: 7
- Forks: 30
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Security: SECURITY.md
Awesome Lists containing this project
README
# Oracle Cloud Infrastructure Data Flow Samples
This repository provides examples demonstrating how to use Oracle Cloud Infrastructure Data Flow, a service that lets you run any Apache Spark Application at any scale with no infrastructure to deploy or manage.
## What is Oracle Cloud Infrastructure Data Flow
Oracle Cloud Infrastructure (OCI) Data Flow is a cloud-based serverless platform with a rich user interface. It allows Spark developers and data scientists to create, edit, and run Spark jobs at any scale without the need for clusters, an operations team, or highly specialized Spark knowledge. Being serverless means there is no infrastructure for you to deploy or manage. It is entirely driven by REST APIs, giving you easy integration with applications or workflows. You can:
* Connect to Apache Spark data sources.
* Create reusable Apache Spark applications.
* Launch Apache Spark jobs in seconds.
* Manage all Apache Spark applications from a single platform.
* Process data in the Cloud or on-premises in your data center.
* Create Big Data building blocks that you can easily assemble into advanced Big Data applications.
## Before you Begin
You must have Set Up Your Tenancy and be able to Access Data Flow
* Setup Tenancy : Before Data Flow can run, you must grant permissions that allow effective log capture and run management.See the [Set Up Administration](https://docs.oracle.com/iaas/data-flow/using/dfs_getting_started.htm#set_up_admin) section of Data Flow Service Guide, and follow the instructions given there.
* Access Data Flow : Refer to this section on how to [Access Data Flow](https://docs.oracle.com/en-us/iaas/data-flow/data-flow-tutorial/getting-started/dfs_tut_get_started.htm#access_ui)## Sample Examples
| Example | Description | Python | Java | Scala |
|--------------------|:-----------:|:------:|:----:|:-----:|
| CSV to Parquet |This application shows how to use PySpark to convert CSV data store in OCI Object Store to Apache Parquet format which is then written back to Object Store. |[CSV to Parquet](./python/csv_to_parquet)| [CSV to Parquet](./java/csv_to_parquet)| [CSV to Parquet](./scala/csv_to_parquet)|
| Load to ADW |This application shows how to read a file from OCI Object Store, perform some transformation and write the results to an Autonomous Data Warehouse instance. |[Load to ADW](./python/loadadw)| [Load to ADW](./java/loadadw)|[Load to ADW](./scala/loadadw)|
| Structured Streaming Kafka Word Count |This Structured Streaming application shows how to read Kafka stream and calculate word frequencies over one minute window interval|[Structured Kafka Word Count](./python/structured_streaming_kafka_word_count)| [Structured Kafka Word Count](./java/structured_streaming_kafka_word_count)||
| Random Forest Regression |This application shows how to build a model and make prediction using Random Forest Regression. |[Random Forest Regression](./python/random_forest_regression)|
| Oracle NoSQL Database cloud service |This application shows how to interface with Oracle NoSQL Database cloud service. |[Oracle NoSQL Database cloud service](./python/oracle_nosql)|For step-by-step instructions, see the README files included with each sample.
## Running the Samples
These samples show how to use the OCI Data Flow service and are meant to be deployed to and run from Oracle Cloud. You can optionally test these applications locally before you deploy them. When they are ready, you can deploy them to Data Flow without any need to reconfigure them, make code changes, or apply deployment profiles.To test these applications locally, Apache Spark needs to be installed. Refer to section on how to set the Prerequisites before you deploy the application locally [Setup locally](https://docs.oracle.com/en-us/iaas/data-flow/data-flow-tutorial/develop-apps-locally/front.htm).
### MLFlow Tracking Server
Set up MLFlow Tracking Server: Refer to this section [dataflow-mlflow-integration](https://github.com/nilayp2107/oracle-dataflow-samples/dataflow-mlflow-integration)
## Install Spark
To install Spark, visit [spark.apache.org](https://spark.apache.org/docs/latest/api/python/getting_started/index.html)
and pick the installation path that best suits your environment.## Documentation
You can find the online documentation for Oracle Cloud Infrastructure Data Flow at [docs.oracle.com](https://docs.oracle.com/en-us/iaas/data-flow/using/dfs_getting_started.htm).
## Get Support
* Open a [GitHub issue](https://github.com/oracle/oracle-dataflow-samples/issues) for bug reports, questions, or requests for enhancements.
* Post your question on the [OCI Data flow Community](https://community.oracle.com/community/groundbreakers/database/nosql_database).## Security
Please consult the [security guide](./SECURITY.md) for our responsible security
vulnerability disclosure process.## Contributing
This project welcomes contributions from the community. Before submitting a pull
request, please [review our contribution guide](./CONTRIBUTING.md).## License
See [LICENSE](./LICENSE.txt)