Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/singer-io/getting-started
This repository is a getting started guide to Singer.
https://github.com/singer-io/getting-started
data-analysis etl etl-framework python singer
Last synced: 3 days ago
JSON representation
This repository is a getting started guide to Singer.
- Host: GitHub
- URL: https://github.com/singer-io/getting-started
- Owner: singer-io
- Created: 2016-10-31T16:53:56.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-09-03T10:15:20.000Z (4 months ago)
- Last Synced: 2025-01-02T02:07:56.303Z (10 days ago)
- Topics: data-analysis, etl, etl-framework, python, singer
- Language: Makefile
- Homepage: https://singer.io
- Size: 198 KB
- Stars: 1,282
- Watchers: 44
- Forks: 147
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-starred - singer-io/getting-started - This repository is a getting started guide to Singer. (data-analysis)
- awesome-python-machine-learning-resources - GitHub - 52% open · ⏱️ 29.04.2021): (数据读写与提取)
README
# Singer
Singer is an open source standard for moving data between databases, web APIs, files, queues, and just about anything else you can think of. The Singer spec describes how data extraction scripts — called “Taps” — and data loading scripts — called “Targets” — should communicate using a standard JSON-based data format over stdout. By conforming to this spec, Taps and Targets can be used in any combination to move data from any source to any destination.
Join the [Singer Slack channel](https://singer-slackin.herokuapp.com/) to get help from members of the Singer
community.## Docs
- [Singer Specification](docs/SPEC.md#singer-specification)
- [Synopsis](docs/SPEC.md#synopsis)
- [Input](docs/SPEC.md#input)
- [Config](docs/SPEC.md#config)
- [State](docs/SPEC.md#state)
- [Example Invocations](docs/SPEC.md#example-invocations)
- [Output](docs/SPEC.md#output)
- [RECORD Message](docs/SPEC.md#record-message)
- [SCHEMA Message](docs/SPEC.md#schema-message)
- [STATE Message](docs/SPEC.md#state-message)
- [Example](docs/SPEC.md#example)
- [Versioning](docs/SPEC.md#versioning)
- [Running and Developing Singer Taps and Targets](docs/RUNNING_AND_DEVELOPING.md#running-and-developing-singer-taps-and-targets)
- [Running Singer with Python](docs/RUNNING_AND_DEVELOPING.md#running-singer-with-python)
- [Developing a Tap](docs/RUNNING_AND_DEVELOPING.md#developing-a-tap)
- [Developing a Target](docs/RUNNING_AND_DEVELOPING.md#developing-a-target)
- [Config and State](docs/CONFIG_AND_STATE.md#config-and-state)
- [Config File](docs/CONFIG_AND_STATE.md#config-file)
- [State File](docs/CONFIG_AND_STATE.md#state-file)
- [Discovery Mode](docs/DISCOVERY_MODE.md#discovery-mode)
- [Schemas](docs/DISCOVERY_MODE.md#schemas)
- [The Catalog](docs/DISCOVERY_MODE.md#the-catalog)
- [Metadata](docs/DISCOVERY_MODE.md#metadata)
- [Sync Mode](docs/SYNC_MODE.md#sync-mode)
- [Streams](docs/SYNC_MODE.md#streams)
- [Replication Method](docs/SYNC_MODE.md#replication-method)
- [Stream/Field Selection](docs/SYNC_MODE.md#streamfield-selection)
- [Metric Messages](docs/SYNC_MODE.md#metric-messages)
- [Best Practices for Building a Singer Tap](docs/BEST_PRACTICES.md#best-practices-for-building-a-singer-tap)
- [Rate Limiting](docs/BEST_PRACTICES.md#rate-limiting)
- [Memory Constraints](docs/BEST_PRACTICES.md#memory-constraints)
- [Dates](docs/BEST_PRACTICES.md#dates)
- [Logging and Exception Handling](docs/BEST_PRACTICES.md#logging-and-exception-handling)
- [Module Structure](docs/BEST_PRACTICES.md#module-structure)
- [Schemas](docs/BEST_PRACTICES.md#schemas)
- [Code Quality](docs/BEST_PRACTICES.md#code-quality)
- [Dependency Versioning](docs/BEST_PRACTICES.md#dependency-versioning)
- [FAQ](docs/FAQ.md#FAQ)
- [How do I prevent dependency conflicts between my tap and target?](docs/FAQ.md#how-do-i-prevent-dependency-conflicts-between-my-tap-and-target)---
Copyright © 2018 Stitch