.. _ksql-server-config:
Configuring KSQL Server
=======================
.. toctree::
:maxdepth: 1
security
config-reference
avro-schema
integrate-ksql-with-confluent-control-center
KSQL configuration parameters can be set for KSQL server and queries as well as for the underlying Kafka Streams and
Kafka Clients (producer and consumer).
.. include:: ../../../../includes/installation-types-zip-tar.rst
.. _set-ksql-server-properties:
------------------------------
Setting KSQL Server Parameters
------------------------------
You can specify KSQL server configuration parameters by using the server configuration file (``ksql-server.properties``)
or the ``KSQL_OPTS`` environment variable. Properties set with ``KSQL_OPTS`` take precedence over those specified in the
KSQL configuration file. A recommended approach is to configure a common set of properties using the KSQL configuration
file and override specific properties as needed, using the ``KSQL_OPTS`` environment variable.
.. tip::
If you deploy |cp| by using Docker containers, you can specify configuration
parameters as environment variables to the
`KSQL Server image `__.
For more information, see :ref:`install-ksql-with-docker`.
KSQL Server Configuration File
------------------------------
By default the KSQL server configuration file is located at ``/etc/ksql/ksql-server.properties``.
The file follows the syntax conventions of
`Java properties files `__.
.. code:: bash
=
For example:
.. code:: bash
bootstrap.servers=localhost:9092
listeners=http://localhost:8088
After you have updated the server configuration file, you can start the KSQL server with the configuration file
specified.
.. code:: bash
$ /bin/ksql-server-start /etc/ksql/ksql-server.properties
For more information, see :ref:`ksql-param-reference`.
KSQL_OPTS Environment Variable
------------------------------
You can override KSQL server configuration parameters by using the ``KSQL_OPTS`` environment variable. The properties are
standard Java system properties. For example, to set ``ksql.streams.num.streams.threads`` to ``1``:
.. code:: bash
$ KSQL_OPTS="-Dksql.streams.num.streams.threads=1" /bin/ksql-server-start \
/etc/ksql/ksql-server.properties
You can specify multiple parameters at the same time. For example, to configure ``ksql.streams.auto.offset.reset`` and ``ksql.streams.num.stream.threads``:
.. code:: bash
$ KSQL_OPTS="-Dksql.streams.auto.offset.reset=earliest -Dksql.streams.num.stream.threads=1" /bin/ksql-server-start \
/etc/ksql/ksql-server.properties
KSQL Server Runtime Environment Variables
-----------------------------------------
When KSQL Server starts, it checks for shell environment variables that
control the host Java Virtual Machine (JVM). Set the following environment
variables to control options like heap size and Log4j configuration. These
settings are applied by the `ksql-run-class `__
shell script when KSQL Server starts.
KSQL_CLASSPATH
Path to the Java deployment of KSQL Server and related Java classes. The
following command shows an example KSQL_CLASSPATH setting.
.. code:: bash
export CLASSPATH=/usr/share/java/my-base/*:/usr/share/java/my-ksql-server/*:/opt/my-company/lib/ksql/*:$CLASSPATH
export KSQL_CLASSPATH="${CLASSPATH}"
KSQL_LOG4J_OPTS
Specifies KSQL Server logging options by using the Log4j configuration settings.
The following example command sets the default Log4j configuration.
.. code:: bash
export KSQL_LOG4J_OPTS="-Dlog4j.configuration=file:$KSQL_CONFIG_DIR/log4j-rolling.properties"
For more information, see `Log4j Configuration `__.
KSQL_JMX_OPTS
Specifies KSQL metrics options by using Java Management Extensions (JMX).
The following example command sets the default JMX configuration.
.. code:: bash
export KSQL_JMX_OPTS="-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false "
For more information, see `Monitoring and Management Using JMX Technology `__.
KSQL_HEAP_OPTS
Specifies the initial size and maximum size of the JVM heap for the KSQL
Server process. The following example command sets the initial size and
maximum size to 15GB.
.. code:: bash
export KSQL_HEAP_OPTS="-Xms15G -Xmx15G"
For more information, see `JRockit JVM Heap Size Options `__.
KSQL_JVM_PERFORMANCE_OPTS
Specifies performance tuning options for the JVM that runs KSQL Server.
The following example command sets the default JVM configuration.
.. code:: bash
export KSQL_JVM_PERFORMANCE_OPTS="-server -XX:+UseConcMarkSweepGC -XX:+CMSClassUnload ingEnabled -XX:+CMSScavengeBeforeRemark -XX:+ExplicitGCInvokesConcurrent -XX:New Ratio=1 -Djava.awt.headless=true"
For more information, see
`D Command-Line Options `__.
JMX_PORT
Specifies the port that JMX uses to report metrics.
.. code:: bash
export JMX_PORT=1099
JAVA_HOME
Specifies the location of the ``java`` executable file.
.. code:: bash
export JAVA_HOME=
-----------
JMX Metrics
-----------
.. include:: ../../includes/ksql-includes.rst
:start-after: enable_JMX_metrics_start
:end-before: enable_JMX_metrics_end
Run the ``ksql-print-metrics`` tool to see the available JMX metrics for KSQL.
.. code:: bash
/bin/ksql-print-metrics
Your output should resemble:
::
_confluent-ksql-default_bytes-consumed-total: 926543.0
_confluent-ksql-default_num-active-queries: 4.0
_confluent-ksql-default_ksql-engine-query-stats-RUNNING-queries: 4
_confluent-ksql-default_ksql-engine-query-stats-NOT_RUNNING-queries: 0
_confluent-ksql-default_messages-consumed-min: 0.0
_confluent-ksql-default_messages-consumed-avg: 29.48784732897881
_confluent-ksql-default_num-persistent-queries: 4.0
_confluent-ksql-default_ksql-engine-query-stats-ERROR-queries: 0
_confluent-ksql-default_num-idle-queries: 0.0
_confluent-ksql-default_messages-consumed-per-sec: 105.07699698626074
_confluent-ksql-default_messages-produced-per-sec: 11.256903025105757
_confluent-ksql-default_error-rate: 0.0
_confluent-ksql-default_ksql-engine-query-stats-PENDING_SHUTDOWN-queries: 0
_confluent-ksql-default_ksql-engine-query-stats-REBALANCING-queries: 0
_confluent-ksql-default_messages-consumed-total: 10503.0
_confluent-ksql-default_ksql-engine-query-stats-CREATED-queries: 0
_confluent-ksql-default_messages-consumed-max: 100.1243737430132
The following table describes the available KSQL metrics.
+---------------------------+------------------------------------------------------------------------------------------------------+
| JMX Metric | Description |
+===========================+======================================================================================================+
| bytes-consumed-total | Number of bytes consumed across all queries. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| error-rate | Number of messages that have been consumed but not processed across all queries. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-consumed-avg | Average number of messages consumed by a query per second. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-consumed-per-sec | Number of messages consumed per second across all queries. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-consumed-min | Number of messages consumed per second for the query with the fewest messages consumed per second. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-consumed-max | Number of messages consumed per second for the query with the most messages consumed per second. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-consumed-total | Number of messages consumed across all queries. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| messages-produced-per-sec | Number of messages produced per second across all queries. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| num-persistent-queries | Number of persistent queries that are currently executing. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| num-active-queries | Number of queries that are actively processing messages. |
+---------------------------+------------------------------------------------------------------------------------------------------+
| num-idle-queries | Number of queries with no messages available to process. |
+---------------------------+------------------------------------------------------------------------------------------------------+
.. _restrict-ksql-interactive:
-------------------------------------
Non-interactive (Headless) KSQL Usage
-------------------------------------
KSQL supports locked-down, "headless" deployment scenarios where interactive use of the KSQL cluster is disabled.
For example, the CLI enables a team of users to develop and verify their queries interactively on a shared testing
KSQL cluster. But when you deploy these queries in your production environment, you want to lock down access to KSQL
servers, version-control the exact queries, and store them in a .sql file. This prevents users from interacting
directly with the production KSQL cluster. For more information, see :ref:`ksql-server-headless-deployment`.
You can configure servers to exclusively run a predefined script (``.sql`` file) via the ``--queries-file`` command
line argument, or the ``ksql.queries.file`` setting in the :ref:`KSQL configuration file `. If a
server is running a predefined script, it will automatically disable its REST endpoint and interactive use.
.. tip:: When both the ``ksql.queries.file`` property and the ``--queries-file`` argument are present, the ``--queries-file`` argument will take precedence.
To start the KSQL Server in headless, non-interactive configuration via the ``--queries-file`` command line argument:
#. Create a predefined script and save as an ``.sql`` file.
#. Start the KSQL with the predefined script specified via the ``--queries-file`` argument.
.. code:: bash
$ /bin/ksql-start-server /etc/ksql/ksql-server.properties \
--queries-file /path/to/queries.sql
To start the KSQL Server in headless, non-interactive configuration via the ``ksql.queries.file`` in the server configuration file:
#. Configure the ``ksql-server.properties`` file. The ``bootstrap.servers`` and ``ksql.queries.file``
are required. For more information about configuration, see :ref:`ksql-server-config`.
.. code:: bash
# Inform the KSQL server where the Kafka cluster can be found:
bootstrap.servers=localhost:9092
# Define the location of the queries file to execute
ksql.queries.file=/path/to/queries.sql
#. Start the KSQL server with the configuration file specified.
.. code:: bash
$ /bin/ksql-start-server /etc/ksql/ksql-server.properties