1. Go to this page and download the library: Download fatihtuzlu/php-apache-kafka library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
fatihtuzlu / php-apache-kafka example snippets
use Fatihtuzlu\PHPKafkaCDC\ConsumerManager;
// Initialize consumer manager
$consumer = new ConsumerManager(
$topic, // Kafka topic to consume from
$groupId, // Consumer group ID
$bootstrapServers // Kafka bootstrap servers
);
// Fetch messages from Kafka
$message = $consumer->fetchMessages($topic, $partition, $offset, $timeMs);
use Fatihtuzlu\PHPKafkaCDC\ProducerManager;
// Initialize producer manager
$producer = new ProducerManager(
$topic, // Kafka topic to produce to
$bootstrapServers // Kafka bootstrap servers
);
// Send a message to Kafka
$producer->sendMessages($message, $flush = 1000, $debug = false);
$producer->debug();
$producer->addBrokers($brokerList);
use Fatihtuzlu\PHPKafkaCDC\ConsumerManager;
// Kafka broker and topic information
$bootstrapServers = "localhost:9092";
$topic = "my_topic";
$groupId = "my_group";
// Initialize the consumer
$consumer = new ConsumerManager($topic, $groupId, $bootstrapServers);
// Fetch messages
$message = $consumer->fetchMessages($topic, 0, RD_KAFKA_OFFSET_BEGINNING);
// Process the received message
if ($message !== null) {
echo "Received message: " . $message->payload . "\n";
} else {
echo "No messages available.\n";
}
use Fatihtuzlu\PHPKafkaCDC\ProducerManager;
// Kafka broker and topic information
$bootstrapServers = "localhost:9092";
$topic = "my_topic";
// Initialize the producer
$producer = new ProducerManager($topic, $bootstrapServers);
// Send a message
$messageToSend = "Hello, Kafka!";
$producer->sendMessages($messageToSend);
echo "Message sent to Kafka: " . $messageToSend . "\n";
composer
idealo/php-rdkafka-ffi: ^0.5.0
php: ^8.0.0
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.