You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
flink/flink-python
Weijie Guo c065920c1c Update version to 2.1-SNAPSHOT 3 days ago
..
apache-flink-libraries [FLINK-36336] Remove deprecated dataset API exclude table module 4 months ago
bin [FLINK-21732][python] Bundle Java libraries into apache-flink-libraries 4 years ago
dev [FLINK-35282][python] Upgrade Apache Beam >=2.54 (#25541) 3 days ago
docs [FLINK-32647][pyflink] Support create catalog in pyflink table environment (#25986) 6 days ago
lib [hotfix][python] Update the incomplete cloudpickle package 2 years ago
pyflink Update version to 2.1-SNAPSHOT 3 days ago
src [FLINK-37168][python] Clean up TimerRegistrationAction in unregisteredTimers list after timers are registered (#26011) 3 days ago
MANIFEST.in [FLINK-22095][python] Remove bundled licenses in apache-flink distributed package 4 years ago
README.md [FLINK-35282][python] Upgrade Apache Beam >=2.54 (#25541) 3 days ago
pom.xml Update version to 2.1-SNAPSHOT 3 days ago
pyproject.toml [FLINK-35282][python] Upgrade Apache Beam >=2.54 (#25541) 3 days ago
setup.cfg [FLINK-12962][python] Allows pyflink to be pip installed. 6 years ago
setup.py [FLINK-35282][python] Upgrade Apache Beam >=2.54 (#25541) 3 days ago
tox.ini [FLINK-34012][python] Fix mypy error (#24043) 1 year ago

README.md

Apache Flink

Apache Flink is a framework and distributed processing engine for stateful computations over unbounded and bounded data streams. Flink has been designed to run in all common cluster environments, perform computations at in-memory speed and at any scale.

Learn more about Flink at https://flink.apache.org/

Python Packaging

PyFlink is a Python API for Apache Flink that allows you to build scalable batch and streaming workloads, such as real-time data processing pipelines, large-scale exploratory data analysis, Machine Learning (ML) pipelines and ETL processes. If youre already familiar with Python and libraries such as Pandas, then PyFlink makes it simpler to leverage the full capabilities of the Flink ecosystem. Depending on the level of abstraction you need, there are two different APIs that can be used in PyFlink: PyFlink Table API and PyFlink DataStream API.

The PyFlink Table API allows you to write powerful relational queries in a way that is similar to using SQL or working with tabular data in Python. You can find more information about it via the tutorial https://nightlies.apache.org/flink/flink-docs-stable/docs/dev/python/table_api_tutorial/

The PyFlink DataStream API gives you lower-level control over the core building blocks of Flink, state and time, to build more complex stream processing use cases. Tutorial can be found at https://nightlies.apache.org/flink/flink-docs-stable/docs/dev/python/datastream_tutorial/

You can find more information via the documentation at https://nightlies.apache.org/flink/flink-docs-stable/docs/dev/python/overview/

The auto-generated Python docs can be found at https://nightlies.apache.org/flink/flink-docs-stable/api/python/

Python Requirements

Apache Flink Python API depends on Py4J (currently version 0.10.9.7), CloudPickle (currently version 2.2.0), python-dateutil (currently version >=2.8.0,<3), Apache Beam (currently version >= 2.54.0, <= 2.61.0).

Development Notices

Protobuf Code Generation

Protocol buffer is used in file flink_fn_execution_pb2.py and flink_fn_execution_pb2.pyi, the file is generated from flink-fn-execution.proto. Whenever flink-fn-execution.proto is updated, please re-generate flink_fn_execution_pb2.py and flink_fn_execution_pb2.pyi by executing:

python pyflink/gen_protos.py

PyFlink depends on the following libraries to execute the above script:

  1. grpcio-tools (>=1.29.0,<=1.50.0)
  2. setuptools (>=37.0.0)
  3. pip (>=20.3)

Running Test Cases

Currently, we use conda and tox to verify the compatibility of the Flink Python API for multiple versions of Python and will integrate some useful plugins with tox, such as flake8. We can enter the directory where this README.md file is located and run test cases by executing

./dev/lint-python.sh

To use your system conda environment, you can set FLINK_CONDA_HOME variable:

export FLINK_CONDA_HOME=$(dirname $(dirname $CONDA_EXE))

Create a virtual environment:

conda create -n pyflink_38 python=3.8

Then you can activate your environment and run tests, for example:

conda activate pyflink_38
pip install -r ./dev/dev-requirements.txt
./dev/lint-python.sh