×
新网 > 建站推广 > 正文

你会将 Laravel 的日志推到 Kafka吗

  • 作者:zccc
  • 来源:网络
  • 2020-08-10 15:02:47

下面由Laravel教程栏目给大家介绍将 Laravel 的日志推到 Kafka的方法,希望对需要的朋友有所帮助!Laravel Kafka

下面由Laravel教程栏目给大家介绍将 Laravel 的日志推到 Kafka的方法,希望对需要的朋友有所帮助!

Laravel Kafka Logger

使用扩展包 laravel-kafka-logger 将 Laravel 的日志推到 Kafka,然后由 ELK 消费、存储、呈现。

要求依赖要求php-rdkafka>=4.0.0依赖安装

1.安装 rdkafka

git clone --depth 1 https://github.com/edenhill/librdkafka.git /tmp/librdkafka && cd /tmp/librdkafka && ./configure && make -j$(nproc) && make install && rm -rf /tmp/librdkafka
pecl install rdkafka

2.安装 laravel-kafka-logger

# Laravel 5.x
composer require "hhxsv5/laravel-kafka-logger:~1.0.0"
# Laravel 6.x & 7.x
composer require "hhxsv5/laravel-kafka-logger:~2.0.0"
开始使用

1.修改配置文件 config/logging.php

return [
    'channels' => [
        // ...
        'kafka' => Hhxsv5\\LKL\\KafkaLogger::getDefinition(['topic' => env('LOG_KAFKA_TOPIC', 'laravel-logs')]),
    ],
];

2.修改 .env

LOG_CHANNEL=kafka
LOG_KAFKA_BROKER_LIST=kafka:9092
LOG_KAFKA_TOPIC=laravel-logs

3.好了,开始记日志

Log::info('用户登录', ['uid-hhxsv5']);

注:

在什么情况下才需要使用到 kafka 来做日志存储?

一是便于集中收集日志,不必每台机器装个客户端收集日志;

二是 Kafka 是异步写入,性能更高。

  • 相关专题

免责声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,也不承认相关法律责任。如果您发现本社区中有涉嫌抄袭的内容,请发送邮件至:operations@xinnet.com进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。

免费咨询获取折扣

Loading