.net windows Kafka 安装与使用入门(入门笔记)
【备注:kafka相关的入门,使用demo资料来源于互联网!本文是根据实际实践成功安装使用经验的总结,:)】
完整解决方案请参考:
Setting Up and Running Apache Kafka on Windows OS
在环境搭建过程中遇到两个问题,在这里先列出来,以方便查询:
搭建环境
1. 安装JDK
1.1 安装文件:http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html下载Server JRE.
1.2 安装完成后需要添加以下的环境变量(右键点击“我的电脑” -> "高级系统设置" -> "环境变量" ):
- JAVA_HOME: C:\Program Files (x86)\Java\jre1.8.0_60(这个是默认安装路径,如果安装过程中更改了安装目录,把更改后的路径填上就行了)
- PATH: 在现有的值后面添加"; %JAVA_HOME%\bin"
1.3 打开cmd运行 "java -version" 查看当前系统Java的版本:
2. 安装Zookeeper
Kafka的运行依赖于Zookeeper,所以在运行Kafka之前我们需要安装并运行Zookeeper
- ZOOKEEPER_HOME: G:\zookeeper-3.4.8
- Path: 在现有的值后面添加 ";%ZOOKEEPER_HOME%\bin;"
2.7 运行Zookeeper: 打开cmd然后执行
- zkserver
3. 安装并运行Kafka
- .\bin\windows\kafka-server-start.bat .\config\server.properties
4. 创建topics
- kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test
5. 打开一个Producer:
- cd /d G:\kafka_2.11-0.10.0.1\bin\windows
- kafka-console-producer.bat --broker-list localhost:9092 --topic test
6. 打开一个Consumer:
- cd /d G:\kafka_2.11-0.10.0.1\bin\windows
- kafka-console-consumer.bat --zookeeper localhost:2181 --topic test
至此,Kafka运行环境的搭建就完成了:-)
web管理方面(正式运维部署):
网上有人说 kafka manage
.net sdk方面:
有人建议:https://github.com/Microsoft/CSharpClient-for-Kafka (微软提供的sdk,看了源码个人感觉有些复杂)
还有
kafka-net 这个感觉会简单很多(看了源码感觉一些Task写法并不喜欢)
推荐:kafka-net 简单易用些。
地址: https://github.com/Jroland/kafka-net
以上sdk 可以搜索nuget 查看开源地址和最新release包,当然.net sdk 还有很多其他选择。
个人开发工具(windows支持),windows 开发环境使用
kafkaTool
下载地址: http://www.kafkatool.com/download.html
kafka-net sdk使用demo
参考来源:http://www.cnblogs.com/Wulex/p/5619425.html
详细请查看官方开源地址的demo: https://github.com/Jroland/kafka-net
KafkaProducer程序:

- class Program
- {
- static void Main(string[] args)
- {
- do
- {
- Produce(GetKafkaBroker(), getTopicName());
- System.Threading.Thread.Sleep(3000);
- } while (true);
- }
- private static void Produce(string broker, string topic)
- {
- var options = new KafkaOptions(new Uri(broker));
- var router = new BrokerRouter(options);
- var client = new Producer(router);
- var currentDatetime =DateTime.Now;
- var key = currentDatetime.Second.ToString();
- var events = new[] { new Message("Hello World " + currentDatetime, key) };
- client.SendMessageAsync(topic, events).Wait(1500);
- Console.WriteLine("Produced: Key: {0}. Message: {1}", key, events[0].Value.ToUtf8String());
- using (client) { }
- }
- private static string GetKafkaBroker()
- {
- string KafkaBroker = string.Empty;
- const string kafkaBrokerKeyName = "KafkaBroker";
- if (!ConfigurationManager.AppSettings.AllKeys.Contains(kafkaBrokerKeyName))
- {
- KafkaBroker = "http://localhost:9092";
- }
- else
- {
- KafkaBroker = ConfigurationManager.AppSettings[kafkaBrokerKeyName];
- }
- return KafkaBroker;
- }
- private static string getTopicName()
- {
- string TopicName = string.Empty;
- const string topicNameKeyName = "Topic";
- if (!ConfigurationManager.AppSettings.AllKeys.Contains(topicNameKeyName))
- {
- throw new Exception("Key \"" + topicNameKeyName + "\" not found in Config file -> configuration/AppSettings");
- }
- else
- {
- TopicName = ConfigurationManager.AppSettings[topicNameKeyName];
- }
- return TopicName;
- }
- }

4.KafkaConsumer程序:

- class Program
- {
- static void Main(string[] args)
- {
- Consume(getKafkaBroker(), getTopicName());
- }
- private static void Consume(string broker, string topic)
- {
- var options = new KafkaOptions(new Uri(broker));
- var router = new BrokerRouter(options);
- var consumer = new Consumer(new ConsumerOptions(topic, router));
- //Consume returns a blocking IEnumerable (ie: never ending stream)
- foreach (var message in consumer.Consume())
- {
- Console.WriteLine("Response: Partition {0},Offset {1} : {2}",
- message.Meta.PartitionId, message.Meta.Offset, message.Value.ToUtf8String());
- }
- }
- private static string getKafkaBroker()
- {
- string KafkaBroker = string.Empty;
- var KafkaBrokerKeyName = "KafkaBroker";
- if (!ConfigurationManager.AppSettings.AllKeys.Contains(KafkaBrokerKeyName))
- {
- KafkaBroker = "http://localhost:9092";
- }
- else
- {
- KafkaBroker = ConfigurationManager.AppSettings[KafkaBrokerKeyName];
- }
- return KafkaBroker;
- }
- private static string getTopicName()
- {
- string TopicName = string.Empty;
- var TopicNameKeyName = "Topic";
- if (!ConfigurationManager.AppSettings.AllKeys.Contains(TopicNameKeyName))
- {
- throw new Exception("Key \"" + TopicNameKeyName + "\" not found in Config file -> configuration/AppSettings");
- }
- else
- {
- TopicName = ConfigurationManager.AppSettings[TopicNameKeyName];
- }
- return TopicName;
- }
- }

5.Consumer结果:
.net windows Kafka 安装与使用入门(入门笔记)的更多相关文章
- Windows 下 安装 laravel(一些小笔记)
首先 安装完composer 下载地址 https://getcomposer.org/ 在 cmd 进入到 自己的项目访问目录 然后 输入命令:composer creat ...
- net windows Kafka
net windows Kafka 安装与使用入门(入门笔记) 完整解决方案请参考: Setting Up and Running Apache Kafka on Windows OS 在环境搭建 ...
- kafka安装以及入门
一.安装 下载最新版kafka,Apache Kafka,然后上传到Linux,我这里有三台机器,192.168.127.129,130,131 . 进入上传目录,解压到/usr/local目录下 - ...
- ElasticSearch入门 第一篇:Windows下安装ElasticSearch
这是ElasticSearch 2.4 版本系列的第一篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...
- ElasticSearch入门 :Windows下安装ElasticSearch
这是ElasticSearch 2.4 版本系列的第一篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...
- MySQL入门——在Windows下安装MySQL
MySQL入门——在Windows下安装MySQL 摘要:本文主要说明了如何下Windows环境下安装MySQL. 查看电脑上是否安装了MySQL 打开cmd窗口,输入 services.msc 命令 ...
- Windows & Linux 安装使用 Vim 编辑器 3分钟入门 - 精简归纳
Windows & Linux 安装使用 Vim 编辑器 3分钟入门 - 精简归纳 JERRY_Z. ~ 2020 / 8 / 25 转载请注明出处! 目录 Windows & Lin ...
- 2016最新 wamp2.5+windows 10安装CoedSgniffer代码格式检查:5分钟安装 30分钟入门和浏览常用命令
14:59 2016/1/112016最新 wamp2.5+windows 10安装CoedSgniffer代码格式检查:注意问题:1.手动安装2.5.0和pear安装方式都成功但是执行时无任何反映, ...
- Kafka 安装及入门
什么是Kafka? Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写.Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流 ...
随机推荐
- ABP文档 - Mvc 视图
文档目录 本节内容: 简介 AbpWebViewPage 基类 简介 ABP通过nuget包Abp.Web.Mvc集成到Mvc视图里,你可以像往常那样创建常规的视图. AbpWebViewPage 基 ...
- ExtJS 4.2 第一个程序
本篇介绍如何创建一个ExtJS应用程序.并通过创建目录.导入文件.编写代码及分析代码等步骤来解释第一个ExtJS程序. 目录 1. 创建程序 1.1 创建目录建议 1.2 实际目录 1.3 index ...
- Convert BSpline Curve to Arc Spline in OpenCASCADE
Convert BSpline Curve to Arc Spline in OpenCASCADE eryar@163.com Abstract. The paper based on OpenCA ...
- android 使用Tabhost 发生could not create tab content because could not find view with id 错误
使用Tabhost的时候经常报:could not create tab content because could not find view with id 错误. 总结一下发生错误的原因,一般的 ...
- NLP点滴——文本相似度
[TOC] 前言 在自然语言处理过程中,经常会涉及到如何度量两个文本之间的相似性,我们都知道文本是一种高维的语义空间,如何对其进行抽象分解,从而能够站在数学角度去量化其相似性.而有了文本之间相似性的度 ...
- [转]Patch文件结构详解
N久不来 于是不知道扔在哪儿于是放这里先 如果你觉得碍事的话 帮我扔到合适的版块去.. 导读这是一篇说明文 它介绍了标准冒险岛更新文件(*.patch;*.exe)的格式文章的最后附了一段C#的参考代 ...
- [修正] Firemonkey TFrame 存档后,下次载入某些事件连结会消失(但源码还在)
问题:Firemonkey TFrame 存档后,下次载入某些事件连结会消失(但源码还在) 解决:(暂时方法) type TTestFrame = class(TFrame) public const ...
- redis大幅性能提升之使用管道(PipeLine)和批量(Batch)操作
前段时间在做用户画像的时候,遇到了这样的一个问题,记录某一个商品的用户购买群,刚好这种需求就可以用到Redis中的Set,key作为productID,value 就是具体的customerid集合, ...
- T-SQL学习记录
T-sql是对SQL(structure query language )的升级.可以加函数. 系统数据库:master管理数据库.model模版数据库,msdb备份等操作需要用到的数据库,tempd ...
- mac下生成ssh keys 并上传github仓储
使用github仓储需要本机生成一个公钥key 添加到自己的git账户SSH keys中 mac 生成方法: 1. 打开终端 输入 ssh-keygen 然后系统提示输入文件保存位置等信息 ...