Standalone

    The standalone mode is the most barebone way of deploying Flink: The Flink services described in the deployment overview are just launched as processes on the operating system. Unlike deploying Flink with a resource provider such as or YARN, you have to take care of restarting failed processes, or allocation and de-allocation of resources during operation.

    In the additional subpages of the standalone mode resource provider, we describe additional deployment methods which are based on the standalone mode: , and on Kubernetes.

    Preparation

    Flink runs on all UNIX-like environments, e.g. Linux, Mac OS X, and Cygwin (for Windows). Before you start to setup the system, make sure your system fulfils the following requirements.

    Starting a Standalone Cluster (Session Mode)

    These steps show how to launch a Flink standalone cluster, and submit an example job:

    1. # (1) Start Cluster
    2. # (2) You can now access the Flink Web Interface on http://localhost:8081
    3. # (3) Submit example job
    4. $ ./bin/flink run ./examples/streaming/TopSpeedWindowing.jar
    5. # (4) Stop the cluster again
    6. $ ./bin/stop-cluster.sh

    In step (1), we’ve started 2 processes: A JVM for the JobManager, and a JVM for the TaskManager. The JobManager is serving the web interface accessible at localhost:8081. In step (3), we are starting a Flink Client (a short-lived JVM process) that submits an application to the JobManager.

    To start a Flink JobManager with an embedded application, we use the bin/standalone-job.sh script. We demonstrate this mode by locally starting the TopSpeedWindowing.jar example, running on a single TaskManager.

    The application jar file needs to be available in the classpath. The easiest approach to achieve that is putting the jar into the lib/ folder:

    1. $ cp ./examples/streaming/TopSpeedWindowing.jar lib/

    Then, we can launch the JobManager:

    1. $ ./bin/standalone-job.sh start --job-classname org.apache.flink.streaming.examples.windowing.TopSpeedWindowing

    The web interface is now available at . However, the application won’t be able to start, because there are no TaskManagers running yet:

    1. $ ./bin/taskmanager.sh start

    Note: You can start multiple TaskManagers, if your application needs more resources.

    Stopping the services is also supported via the scripts. Call them multiple times if you want to stop multiple instances, or use stop-all:

    1. $ ./bin/taskmanager.sh stop
    2. $ ./bin/standalone-job.sh stop

    Per-Job Mode

    Per-Job Mode is not supported by the Standalone Cluster.

    Session Mode

    Local deployment in Session Mode has already been described in the introduction above.

    All available configuration options are listed on the , in particular the Basic Setup section contains good advise on configuring the ports, memory, parallelism etc.

    Debugging

    If Flink is behaving unexpectedly, we recommend looking at Flink’s log files as a starting point for further investigations.

    The log files are located in the logs/ directory. There’s a .log file for each Flink service running on this machine. In the default configuration, log files are rotated on each start of a Flink service – older runs of a service will have a number suffixed to the log file.

    Alternatively, logs are available from the Flink web frontend (both for the JobManager and each TaskManager).

    By default, Flink is logging on the “INFO” log level, which provides basic information for all obvious issues. For cases where Flink seems to behave wrongly, reducing the log level to “DEBUG” is advised. The logging level is controlled via the conf/log4.properties file. Setting will bootstrap Flink on the DEBUG log level.

    There’s a dedicated page on the logging in Flink.

    Component Management Scripts

    Starting and Stopping a cluster

    bin/start-cluster.sh and bin/stop-cluster.sh rely on conf/masters and conf/workers to determine the number of cluster component instances.

    If password-less SSH access to the listed machines is configured, and they share the same directory structure, the scripts also support starting and stopping instances remotely.

    Example 1: Start a cluster with 2 TaskManagers locally

    conf/masters contents:

    conf/workers contents:

    1. localhost
    2. localhost
    Example 2: Start a distributed cluster JobManagers

    This assumes a cluster with 4 machines (master1, worker1, worker2, worker3), which all can reach each other over the network.

    1. master1

    conf/workers contents:

    1. worker1
    2. worker2
    3. worker3

    Note that the configuration key needs to be set to master1 for this to work.

    We show a third example with a standby JobManager in the high-availability section.

    The bin/jobmanager.sh and bin/taskmanager.sh scripts support starting the respective daemon in the background (using the start argument), or in the foreground (using start-foreground). In the foreground mode, the logs are printed to standard out. This mode is useful for deployment scenarios where another process is controlling the Flink daemon (e.g. Docker).

    The scripts can be called multiple times, for example if multiple TaskManagers are needed. The instances are tracked by the scripts, and can be stopped one-by-one (using stop) or all together (using stop-all).

    Windows Cygwin Users

    If you are installing Flink from the git repository and you are using the Windows git shell, Cygwin can produce a failure similar to this one:

    1. c:/flink/bin/start-cluster.sh: line 30: $'\r': command not found

    This error occurs because git is automatically transforming UNIX line endings to Windows style line endings when running on Windows. The problem is that Cygwin can only deal with UNIX style line endings. The solution is to adjust the Cygwin settings to deal with the correct line endings by following these three steps:

    1. Start a Cygwin shell.

    2. Determine your home directory by entering

      1. cd; pwd

      This will return a path under the Cygwin root path.

    3. Using NotePad, WordPad or a different text editor open the file .bash_profile in the home directory and append the following (if the file does not exist you will have to create it):

    In order to enable HA for a standalone cluster, you have to use the .

    Additionally, you have to configure your cluster to start multiple JobManagers.

    • masters file: The masters file contains all hosts, on which JobManagers are started, and the ports to which the web user interface binds.
    1. master1:webUIPort1
    2. [...]
    3. masterX:webUIPortX

    By default, the JobManager will pick a random port for inter process communication. You can change this via the high-availability.jobmanager.port key. This key accepts single ports (e.g. 50010), ranges (50000-50025), or a combination of both (50010,50011,50020-50025,50050-50075).

    Example: Standalone HA Cluster with 2 JobManagers

    1. Configure high availability mode and ZooKeeper quorum in conf/flink-conf.yaml:
    1. high-availability: zookeeper
    2. high-availability.zookeeper.quorum: localhost:2181
    3. high-availability.zookeeper.path.root: /flink
    4. high-availability.cluster-id: /cluster_one # important: customize per cluster
    5. high-availability.storageDir: hdfs:///flink/recovery
    1. Configure masters in conf/masters:
    1. localhost:8081
    2. localhost:8082
    1. Configure ZooKeeper server in conf/zoo.cfg (currently it’s only possible to run a single ZooKeeper server per machine):
    1. server.0=localhost:2888:3888
    1. Start ZooKeeper quorum:
    1. $ ./bin/start-zookeeper-quorum.sh
    2. Starting zookeeper daemon on host localhost.
    1. Start an HA-cluster:
    1. Stop ZooKeeper quorum and cluster:
    1. $ ./bin/stop-cluster.sh
    2. Stopping taskexecutor daemon (pid: 7647) on localhost.
    3. Stopping standalonesession daemon (pid: 7495) on host localhost.
    4. Stopping standalonesession daemon (pid: 7349) on host localhost.
    5. Stopping zookeeper daemon (pid: 7101) on host localhost.