当前位置: 首页 > wzjs >正文

php能开发大型网站视频号怎么付费推广

php能开发大型网站,视频号怎么付费推广,非主流图片在线制作,秦州区建设局网站1. 了解 Kafka Apache Kafka 是一个分布式流处理平台,核心功能包括: 发布/订阅消息系统:解耦生产者和消费者 分布式存储:持久化、容错的消息存储 流处理:实时处理数据流 核心概念: 概念说明BrokerKaf…

1. 了解 Kafka

Apache Kafka 是一个分布式流处理平台,核心功能包括:

  • 发布/订阅消息系统:解耦生产者和消费者

  • 分布式存储:持久化、容错的消息存储

  • 流处理:实时处理数据流

核心概念

概念说明
BrokerKafka 集群中的单个服务器节点
Topic消息的逻辑分类(如:user_activity
PartitionTopic 的分区(并行处理单位),消息按顺序存储
Producer向 Topic 发布消息的客户端
Consumer订阅 Topic 并处理消息的客户端
Consumer Group多个消费者协同消费同一 Topic(每个分区只被组内一个消费者消费)
Offset消息在分区中的唯一位置标识

2. 了解 rdkafka

rdkafka 是 Kafka 的 C/C++ 客户端库,提供:

  • 高性能生产/消费 API(支持 C/C++/Python 等)

  • 特性:

    • 异步/同步发送模式

    • 自动负载均衡

    • 消息压缩(gzip, snappy, lz4)

    • SASL 认证

    • 精确一次语义(EOS)

  • 开源地址:edenhill/librdkafka

3. 代码实现

以下是使用 librdkafka 的 C++ 接口操作 Kafka 的生产者和消费者完整实现:

生产者代码 (producer.cpp)
#include <iostream>
#include <string>
#include <sstream>
#include <librdkafka/rdkafkacpp.h>class ProducerDeliveryReportCb : public RdKafka::DeliveryReportCb {
public:void dr_cb(RdKafka::Message &message) {if (message.err()) {std::cerr << "消息发送失败: " << message.errstr() << std::endl;} else {std::cout << "消息发送成功: " << message.topic_name() << " [" << message.partition() << "] @ " << message.offset() << std::endl;}}
};int main() {// 1. 创建配置对象RdKafka::Conf *conf = RdKafka::Conf::create(RdKafka::Conf::CONF_GLOBAL);std::string errstr;// 2. 设置配置参数if (conf->set("bootstrap.servers", "localhost:9092", errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置错误: " << errstr << std::endl;return 1;}// 设置消息确认模式 (all = 最高可靠性)if (conf->set("acks", "all", errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置错误: " << errstr << std::endl;return 1;}// 3. 创建生产者实例ProducerDeliveryReportCb delivery_cb;if (conf->set("dr_cb", &delivery_cb, errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置回调错误: " << errstr << std::endl;return 1;}RdKafka::Producer *producer = RdKafka::Producer::create(conf, errstr);if (!producer) {std::cerr << "创建生产者失败: " << errstr << std::endl;return 1;}delete conf;// 4. 创建Topic对象RdKafka::Conf *tconf = RdKafka::Conf::create(RdKafka::Conf::CONF_TOPIC);RdKafka::Topic *topic = RdKafka::Topic::create(producer,"cpp_test_topic",tconf,errstr);if (!topic) {std::cerr << "创建Topic失败: " << errstr << std::endl;delete tconf;return 1;}delete tconf;// 5. 生产消息for (int i = 0; i < 10; ++i) {std::string key = "key-" + std::to_string(i);std::string payload = "Message #" + std::to_string(i);// 发送消息RdKafka::ErrorCode resp = producer->produce(topic, RdKafka::Topic::PARTITION_UA, // 自动分区分配RdKafka::Producer::RK_MSG_COPY,const_cast<char*>(payload.c_str()), payload.size(),const_cast<char*>(key.c_str()), key.size(),NULL);if (resp != RdKafka::ERR_NO_ERROR) {std::cerr << "生产消息失败: " << RdKafka::err2str(resp) << std::endl;} else {std::cout << "已发送: " << payload << std::endl;}// 处理事件队列producer->poll(0);}// 6. 等待所有消息完成发送while (producer->outq_len() > 0) {std::cout << "等待发送队列: " << producer->outq_len() << std::endl;producer->poll(100);}// 7. 清理资源delete topic;delete producer;return 0;
}
消费者代码 (consumer.cpp)
#include <iostream>
#include <string>
#include <csignal>
#include <vector>
#include <librdkafka/rdkafkacpp.h>bool running = true;void stop(int sig) {running = false;
}class ConsumerEventCb : public RdKafka::EventCb {
public:void event_cb(RdKafka::Event &event) {switch (event.type()) {case RdKafka::Event::EVENT_ERROR:std::cerr << "错误: " << RdKafka::err2str(event.err()) << std::endl;break;case RdKafka::Event::EVENT_LOG:std::cout << "日志: " << event.str() << std::endl;break;default:std::cout << "事件: " << event.type() << ": " << event.str() << std::endl;break;}}
};int main() {// 注册信号处理signal(SIGINT, stop);signal(SIGTERM, stop);// 1. 创建配置对象RdKafka::Conf *conf = RdKafka::Conf::create(RdKafka::Conf::CONF_GLOBAL);std::string errstr;// 2. 设置配置参数if (conf->set("bootstrap.servers", "localhost:9092", errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置错误: " << errstr << std::endl;return 1;}// 设置消费组if (conf->set("group.id", "cpp_consumer_group", errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置错误: " << errstr << std::endl;return 1;}// 从最早的消息开始消费if (conf->set("auto.offset.reset", "earliest", errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "配置错误: " << errstr << std::endl;return 1;}// 3. 设置事件回调ConsumerEventCb event_cb;if (conf->set("event_cb", &event_cb, errstr) != RdKafka::Conf::CONF_OK) {std::cerr << "设置回调失败: " << errstr << std::endl;return 1;}// 4. 创建消费者实例RdKafka::KafkaConsumer *consumer = RdKafka::KafkaConsumer::create(conf, errstr);if (!consumer) {std::cerr << "创建消费者失败: " << errstr << std::endl;return 1;}delete conf;// 5. 订阅Topicstd::vector<std::string> topics;topics.push_back("cpp_test_topic");RdKafka::ErrorCode resp = consumer->subscribe(topics);if (resp != RdKafka::ERR_NO_ERROR) {std::cerr << "订阅失败: " << RdKafka::err2str(resp) << std::endl;return 1;}// 6. 消费消息while (running) {// 等待消息 (1000ms超时)RdKafka::Message *msg = consumer->consume(1000);switch (msg->err()) {case RdKafka::ERR__TIMED_OUT:break;  // 超时继续case RdKafka::ERR_NO_ERROR:// 成功消费到消息std::cout << "收到消息: "<< "主题: " << msg->topic_name() << " | 分区: [" << msg->partition() << "]"<< " | 偏移量: " << msg->offset() << std::endl;if (msg->key()) {std::cout << "键: " << *msg->key() << " => ";}std::cout << "值: " << static_cast<const char*>(msg->payload()) << std::endl;break;default:std::cerr << "消费错误: " << msg->errstr() << std::endl;break;}// 手动提交偏移量consumer->commitAsync(msg);delete msg;}// 7. 关闭消费者consumer->close();delete consumer;return 0;
}
编译运行

# 编译生产者
g++ -o producer producer.cpp -lrdkafka++ -lrdkafka -lpthread -lz -ldl# 编译消费者
g++ -o consumer consumer.cpp -lrdkafka++ -lrdkafka -lpthread -lz -ldl

http://www.dtcms.com/wzjs/202008.html

相关文章:

  • 网站 服务器 域名制作网站教程
  • 做期货网站违法的吗软文代发
  • 深圳网站建设大公司好企业推广策划书
  • 自助建站平台哪家好网上引流推广怎么做
  • 四川省建设厅职业注册中心网站品牌推广策略
  • 做六级真题的网站百度网站推广价格
  • 中国建设监理业协会网站百度销售岗位怎么样
  • 南昌网站建设费用百度关键词推广公司
  • 国外做ae模板网站大全网站seo排名优化
  • 江苏省住房和城乡建设委员会官方网站长沙网站se0推广优化公司
  • 建网站手机软件淘宝摄影培训推荐
  • windows 做网站服务器吗在百度上怎么打广告
  • 怎样设计网站模板百度pc网页版登录入口
  • 车子网站旺道seo推广有用吗
  • 哈尔滨seo网站排名网站的优化公司
  • 装修公司展厅布置方案谷歌seo是什么意思
  • 天河手机网站建设百度地图导航
  • 有域名有网站怎么解决办法谷歌引擎搜索
  • 内蒙建设信息网站常州网络推广哪家好
  • 仁怀网站建设不好出手英文外链平台
  • 跟业务合作做网站给多少提成免费域名申请网站
  • 电商网站开发的目的是中国职业培训在线官网
  • 深圳网站优化计划菏泽地网站seo
  • 温州网站建设费用品牌宣传策略有哪些
  • 下载空间大的网站建设如何制作网页最简单的方法
  • wordpress博客一直发布失败厦门seo推广
  • 襄阳网站定制谷歌外贸
  • 单页网站 html岳阳网站设计
  • 做国外产品描述的网站青岛网站建设策划
  • 做基因互作的网站网上交易平台