librdkafka使用VS2015进行编译
抄了那么久的《kafka权威指南》,开始实操了,按照书本的介绍,kafka本身提供针对Java的原生API,其它语言如果需要使用kafka,那么就需要通过第三方库来做了,对了再书中一直提及的kafka官方文档,在网站中的DOCUMENTATION里。在kafka的官网上找到Clients,点击进入,此页介绍了一下各语言的推荐库,如下:


好了,接下来要做的事情就是点击C++那一项,到页面指示的网址去下载库即可。官方网站上一共推荐了5种C++库,本次试验 选择librdkafka,因为它支持的kafka版本比较多。
1.下载librdkafka库的源码,并在windows系统下进行编译(使用VS2015)
librdkafka的API文档地址:https://docs.confluent.io/2.0.0/clients/librdkafka/dir_b60aae235eacf49413d63ea05b937558.html。在librdkafka库的下载页有对应的编译要求,如下图所示:(我在这篇文章里讲的是编译为64位的库,编译32位库也可以按照这个步骤进行操作,但对应的软件要安装成32位的,下载地址是:https://github.com/edenhill/librdkafka)


注:将源码包解压后可以找到win32文件夹,这里面就是VS的解决方案(.sln文件 sln:solutions),但是现在还无法编译,因为它需要依赖openssl。
下载源码的时候注意一下分支的选择:

选择release,一般master分支是正在开发中的分支,里面可能会有一些bug或者未经过测试的新代码。在正式使用或者研究的时候使用release下的源码包即可。
1.下载并安装ActivePerl,下载地址:https://www.activestate.com/activeperl,安装后可以执行perl命令即可,这个在接下来编译openssl的时候会用到

安装完后,在Perl的安装目录下的eg文件夹里(我的是:C:\Perl64\eg)打开windows的命令行工具,如果出现下图,说明你的Perl是安装成功的。因为openssl的配置是用Perl写的。

或者cmd,在命令行中输入perl -v,如下图则表示安装成功:

2.安装dmake,如果没有dmake的话,编译openssl会提示你的机器没有安装dmake。
dmake、cmake、nmake、gmake、make。
gmake:就是linux下的GNU make,gmake是GNU make在其它操作系统下的移植版,但是别的平台上,一般make这个名字被占用了,所以就起了个gmake的名字。windows下自带的make叫做nmake。如果你使用nmake的时候,发现命令行提示nmake不是内部命令,那么需要添加环境变量,环境变量是 :VS的安装目录/VC/bin。
dmake是一款跨平台的编译工具。dmake是一款与GNU make类似的编译工具,Dmake是同GNU Make类似的一个工具。其命令格式自成一体,但是可以适用于Linux, Solaris, and Win32 and other platforms。Dmake有一个变种,被OpenOffice.org使用。dmake 是一个命令行工具,与 make(1) 兼容。dmake 能够以网格、分布、并行或串行模式生成目标。如果使用的是标准 make(1) 实用程序,在对 makefile 进行任何更改时可以毫不费力地过渡到使用 dmake。dmake 是 make 实用程序的超集。
cmake是另一款跨平台的编译工具。 Visual Studio 的 .sln,Xcode 的 .xcodebuild 文件,依赖现有编译工具 (make, nmake, vcbuild, xcodebuild) 来编译。
在windows下安装dmake工具:

图 VS2015 命令行工具
打开图中的VS2015开发人员命令提示,进入VS的命令行工具,然后执行命令:ppm install dmake。如果出现如下错误:ppm install failed: DBD::SQLite::db selectrow_array failed: database disk image is malformed,那么删除路径:C:\Users\Admin\AppData\Local\ActiveState\ActivePerl 下的文件(和ppm有关的文件)即可。

如上图,第一次安装dmake失败,经过上面讲的处理方式处理之后,安装成功。
要编译openssl源码的话,建议详细阅读源码包里的INSTALL文件。
3.下载并安装64位的openssl。(因为本次的目的仅是为了编译librdkafka,而不是做基于openssl的开发,所以就先下载个安装版的,进行安装,下载地址:http://slproweb.com/products/Win32OpenSSL.html)

所以看东西要认真啊,虽然网站地址上写明的是Win32Openssl,但是这个站点是有Win64Openssl下载的。这个站点并不是openssl官方提供的。
开始安装openssl。开始下载的是最新的版本:Win64OpenSSL-1.1.1,但是安装完后,发现lib文件夹里没有编译librdkafka需要的lib,所以换了一个,下载了Win64OpenSSL-v_1.0.2p。图片中的选项要注意下,别选错了,待会编译librdkafka的时候会用到。

安装成功之后,可以看到目录结构如下:

然后在lib文件夹里就有你编译librdkafka时需要用到的lib。
4.编译librdkafka。我下载的是master分支。
解压后,文件夹树结构如下:

然后打开win32文件夹,打开解决方案,剩下的就是你很熟悉的配置附加库路径的事情了……



编译的时候先编译librdkafka。然后再编译其他的。编译的结果默认是动态库,你要是想使用静态库也可以修改。
到了这一步库的编译过程就结束了。如下图:

头文件的话,在你的工程里需要引入的头文件有一个:rdkafkacpp.h。然后编译动态库生成的dll还有对应的lib文件,这个也是需要引入你的工程里的,它不是我们通常讲的静态库文件,只是编译器在编译阶段会用到它们。
librdkafka使用VS2015进行编译的更多相关文章
- vs2015下编译免费开源的jpeg库,ijg的jpeg.lib
vs2015下编译免费开源的jpeg库,ijg的jpeg.lib 1. 去Independent JPEG Group官网www.ijg.org下载jpegsrc,我下载的版本是jpegsrc9c.z ...
- VS2015 dlib编译 x64 Release .lib生成
VS2015 dlib编译 x64 Release >------ 已启动生成: 项目: ZERO_CHECK, 配置: Release x64 ------ > Checking Bui ...
- VS2015 dlib编译 x64 Debug .lib生成
VS2015 dlib编译 x64 Debug >------ 已启动生成: 项目: ZERO_CHECK, 配置: Debug x64 ------ > Checking Build S ...
- [libpng]CMake+VS2015下编译libpng,及使用小例
编译前的工作 在编译libpng前,需要把zlib编译好,并加载到编译环境里. CMake + VS2015 下编译zlib,及使用小例 下载与解压 libpng的官网是 http://www.lib ...
- 关于VS2015支持编译Linux程序的问题
现状 目前已经发布的VS2015中包括VS2015 Preview 以及 VS2015 CTP6,这两个版本均不支持直接编译C++代码为Linux程序,具体情况可以参考 Visual Studio 2 ...
- VS2015下编译64位GDAL总结
使用VS2015编译最新的64位GDAL(最新gdal2.11),确实有一些问题,看来双方还是太新了,有点不兼容,特总结如下. 以前经常用的通过VisualStudio IDE进行编译的方式现在似乎不 ...
- Win7 64位 VS2015环境编译cegui-0.8.5
首先是去官网下载源码与依赖库 http://cegui.org.uk/ 然后得提一下,编译DX11版本带Effects11框架的话会有问题,也就是默认情况编译有问题,这是因为VS2015升级后编译器对 ...
- Win10 + VS2015 下编译 Qt5.6.0
近期由于另外一个项目需要用 vs2015 ,于是把 Qt 也升级到了 5.6.0 .由于项目需要兼容 Windows xp ,所以需要自己编译 Qt .这里大致整理一下编译的过程. 安装 Active ...
- VS2015 加快编译速度
在使用VS2015 编译的时候,每次修改工程中的某一个文件,启动调试时,往往都是整个工程都需要重新编译一遍.由于这个工程代码量太大,每次编译完成都需要将近10分钟左右的时间编译.最烦人的时候是当编译完 ...
随机推荐
- 运用NP求解 “跳跃游戏”---计蒜客
计蒜客里面有一道“跳跃游戏的问题” 给定一个非负整数数组,假定你的初始位置为数组第一个下标. 数组中的每个元素代表你在那个位置能够跳跃的最大长度. 你的目标是到达最后一个下标,并且使用最少的跳跃次数. ...
- bzoj 2809: [Apio2012]dispatching【dfs序+主席树】
可并堆就可以,但是想复健一下主席树. 考虑枚举管理者,然后选忍者的时候在子树中贪心的从小到大选.做成dfs序就是选区间内和小于等于k的最多点.可以用主席树,查询的时候在主席树上二分即可 这里注意,为了 ...
- 洛谷 P4014 分配问题 【最小费用最大流+最大费用最大流】
其实KM更快--但是这道题不卡,所以用了简单粗暴的费用流,建图非常简单,s向所有人连流量为1费用为0的边来限制流量,所有工作向t连流量为1费用为0的边,然后对应的人和工作连(i,j,1,cij),跑一 ...
- glance镜像服务
一.glance介绍: 因为云平台是提供Iass层的基础设施服务,我们拿到的是一台虚拟机,那么要用虚拟机的话必须有底层的镜像做支撑,所以说镜像的话也有一个服务来管理.但是我们云平台用的镜像不是装操作系 ...
- [浏览器美化]去除 Firefox 当前选中标签页顶端的线条
Firefox 当前选中的标签页的最上方会显示有一条线,我觉得很丑,如图: 在地址栏输入 about:support ,然后点击打开目录. 在此目录中创建一个 chrome 文件夹(若没有),然后进入 ...
- Visual Studio 2015 个版本下载
Visual Studio 2015是一个基本完整的开发工具集,它包括了整个软件生命周期中所需要的大部分工具,如UML工具.代码管控工具.集成开发环境(IDE)等等.所写的目标代码适用于微软支持的所有 ...
- SpringMVC传递multiple类型select后台Controller的接收方法
Spring MVC在接收集合请求参数时,需要在Controller方法的集合参数里前添加@RequestBody,而@RequestBody默认接收的enctype (MIME编码)是applica ...
- Unix\Linux | 总结笔记 |文件系统
1. ls [选项] [文件] 显示目录中的文件信息 -a 显示全部文件(包括隐藏文件) -l 查看文件的属性.大小等详细信息 (ls -l 详解) -al 查看当前目录中 ...
- 1.1.2最小生成树(Kruskal和Prim算法)
部分内容摘自 勿在浮沙筑高台 http://blog.csdn.net/luoshixian099/article/details/51908175 关于图的几个概念定义: 连通图:在无向图中,若任意 ...
- php 遇到报错 Call to a member function fetch_object()
1.检查语法 ,没问题 <?php require "fun.php"; $kc_sql="select distinct KCM from KCB"; ...