 9af249a1fc
			
		
	
	9af249a1fc
	
	
	
		
			
			* A integrations: minot style fix - apply sentence style capitalization - add refs to glossary terms * Fix glossary * Apply suggestions from code review Co-authored-by: Joakim Sørensen <joasoe@gmail.com> --------- Co-authored-by: Joakim Sørensen <joasoe@gmail.com>
		
			
				
	
	
	
		
			2.8 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	title, description, ha_category, ha_release, ha_codeowners, ha_domain, ha_iot_class, ha_integration_type
| title | description | ha_category | ha_release | ha_codeowners | ha_domain | ha_iot_class | ha_integration_type | ||
|---|---|---|---|---|---|---|---|---|---|
| Apache Kafka | Send data and events to Apache Kafka. | 
 | 0.97 | 
 | apache_kafka | Local Push | integration | 
The Apache Kafka {% term integration %} sends all state changes to a Apache Kafka topic.
Apache Kafka is a real-time data pipeline that can read and write streams of data. It stores its data safely in a distributed, replicated, fault-tolerant cluster.
To use the Apache Kafka {% term integration %} in your installation, add the following to your
configuration.yaml file:
apache_kafka:
  ip_address: localhost
  port: 9092
  topic: home_assistant_1
{% configuration %}
ip_address:
description: The IP address or hostname of an Apache Kafka cluster.
required: true
type: string
port:
description: The port to use.
required: true
type: integer
username:
description: The username of Apache Kafka cluster for authentication.
required: false
type: string
password:
description: The password of Apache Kafka cluster for authentication.
required: false
type: string
security_protocol:
description: The protocol used to communicate with brokers. Use SASL_SSL for authentication.
required: false
default: PLAINTEXT
type: string
topic:
description: The Kafka topic to send data to.
required: true
type: string
filter:
description: Filters for entities to be included/excluded. (Configure Filter)
required: false
type: map
keys:
include_domains:
description: Domains to be included.
required: false
type: list
include_entity_globs:
description: Include all entities matching a listed pattern.
required: false
type: list
include_entities:
description: Entities to be included.
required: false
type: list
exclude_domains:
description: Domains to be excluded.
required: false
type: list
exclude_entity_globs:
description: Exclude all entities matching a listed pattern.
required: false
type: list
exclude_entities:
description: Entities to be excluded.
required: false
type: list
{% endconfiguration %}
Configure filter
By default, no entity will be excluded. To limit which entities are being exposed to Apache Kafka, you can use the filter parameter.
# Example filter to include specified domains and exclude specified entities
apache_kafka:
  ip_address: localhost
  port: 9092
  topic: home_assistant_1
  filter:
    include_domains:
      - alarm_control_panel
      - light
    include_entity_globs:
      - binary_sensor.*_occupancy
    exclude_entities:
      - light.kitchen_light
{% include common-tasks/filters.md %}