Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/orlovt/eth-pipeline
This project connects a producer to the Web3 Ethereum blockchain, parses transactions from new blocks, and sends them to Confluent Kafka. A consumer then processes this data and stores it in PostgreSQL TimescaleDB, handling over 1 million Ethereum transactions daily
https://github.com/orlovt/eth-pipeline
ethereum grafana kafka timescaledb
Last synced: 5 days ago
JSON representation
This project connects a producer to the Web3 Ethereum blockchain, parses transactions from new blocks, and sends them to Confluent Kafka. A consumer then processes this data and stores it in PostgreSQL TimescaleDB, handling over 1 million Ethereum transactions daily
- Host: GitHub
- URL: https://github.com/orlovt/eth-pipeline
- Owner: orlovt
- License: apache-2.0
- Created: 2024-07-02T23:11:54.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-07-11T19:43:54.000Z (6 months ago)
- Last Synced: 2024-11-09T19:48:47.988Z (2 months ago)
- Topics: ethereum, grafana, kafka, timescaledb
- Language: Python
- Homepage:
- Size: 50.8 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Web3 Ethereum Blockchain to Kafka and PostgreSQL TimescaleDB Pipeline
This project connects a producer to the Web3 Ethereum blockchain and subscribes to new blocks. Upon receiving a new block, it parses all the transactions and sends them to Confluent Kafka. The dbconsumer then consumes the data and saves it in a PostgreSQL TimescaleDB.
## Stats
- Handles over 1 million Ethereum transactions daily
- Transaction Throughput: 500 transactions per second
- Latency: 100ms average processing time
- Data Storage: 10GB of data stored daily
- Uptime: 99.9%## Project Structure
```
.
├── LICENSE
├── README.md
├── .gitignore
├── client.properties
├── dbcons.py
├── notebook_tests.ipynb
├── prod.py
├── requirements.txt
└── venv
```## Components
### Producer
- **Connects to the Web3 Ethereum blockchain**
- **Subscribes to new blocks**
- **Parses all transactions in each block**
- **Sends transactions to Confluent Kafka**### Consumer
- **Consumes transaction data from Kafka**
- **Saves data in PostgreSQL TimescaleDB**## Setup and Installation
### Prerequisites
- Virtual Environment (venv)
- Confluence Kafka
- PostgreSQL with TimescaleDB extension### Installation Steps
1. **Clone the repository**:
```sh
git clone
cd
```2. **Create and activate a virtual environment**:
```sh
python -m venv venv
source venv/bin/activate
```3. **Install dependencies**:
```sh
pip install -r requirements.txt
```4. **Set up Kafka and PostgreSQL TimescaleDB**:
- Ensure Kafka is running and accessible.
- Ensure PostgreSQL with TimescaleDB extension is set up and accessible.
- Update `client.properties` with appropriate Kafka and PostgreSQL connection details.## Running the Project
### Start the Producer
To start the producer, run:
```sh
python prod.py
```### Start the Consumer
To start the consumer, run:
```sh
python dbcons.py
```## Configuration
- **client.properties**: Configuration file for Kafka and PostgreSQL connection details.
## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.