编译rocksdb源码导致的部署失败

这几天经历了一次心酸的历程,使用了rocksdb第三方库,编译器是7.2,rocksdb是20190701从github上取下来的,由于rocksdb自己的CMakeList.txt中使用了-march=native编译参数,强制使用了编译代码服务器的cpu指令集,由于是一个集群,集群中的服务器cpu型号信息不一定都一致,导致集群中部分服务器起不来。引起了大领导的关注,自己一下子提起了精神

事情的经过是这样的:

我们发布了一款数据库产品,部署在一个大的集群中,集群中大概有200台服务器,但是部分服务器节点的进程启动不起来。在一台服务器A上编译打包之后部署到其他的服务器,当时其他的服务器是一个大集群里面有几十台服务器,就用B来代表其中的一台服务器吧,但是B启动时直接失败,可以看到的有用信息比较少。

(1)、后来改成了可以调试的版本,优先分析coredump,可以看到,有用的gdb信息比较少,直接在进程启动时就崩溃了。

(2)、尝试在main函数入口处加打印来获取崩溃的模块的信息,但是在测试过程中main函数中的打印一个也没有出现,log文件也没有生成,我个人直接崩溃

(3)、跟其他组的资深同事聊了半天,也没有得到实质的帮助,此时2天已经过去了,MP催了几次了

(4)、直接领导也给了一些帮助,让加一些编译参数,经过漫长的尝试测试结果也是失败了

经过直接领导的指导,应该调整下测试的方式,但是领导也不清楚具体原因,我也懵了,让自己研究,作为入职公司16个月的资深工程师来说觉得应该好好深入的研究下rocksdb的源码

(1)、各大网站一顿查找,国内网站没有给什么帮助,stackflow给了一部分帮助

(2)、开始研究rocksdb源码中编译部分,经过一整夜的研究查找资料,最后得出的是rocksdb内部开启的对cpu指令集的调整参数-march=native,修改rocksdb的编译参数,编译下代码这个过程比较长,这时已经早上6::55,就让机器自己编译吧,洗了把脸去外面找点吃的,回来经过2小时的验证,就是这个问题。由于需要在各种版本上验证,因此需要考虑各种情况。

(3)、经过测试ok了

 

总结:

      本人以前是搞通信的,硕士毕业,最早是做C开发的,现在从事分布式数据库方面的工作,这次居然使用到了了os + 计算机组成原理+CPU架构等方面的知识,由于以前所学基础知识扎实,这次对问题的解决得到了帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/463360.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

跌倒的收获

有个"渔王"非常苦恼,就因为三个儿子的捕鱼技术都很一般。他常向人诉苦:"我从儿子们刚懂事起就传授技术,怎么他们都比不上平常人的孩子?" 一位路人听后,问:"你一直是手把手地教他们…

检测APK是否混淆

目录 为什么要检测APK是否混淆混淆的优点混淆的缺点APK的混淆的分类检测工具检测人工检测自动化检测为什么要检测APK是否混淆 apk代码混淆就是为了保护代码安全,防止被反编译拿到源码做审计找出危险漏洞,现在大部分的APK都会做混淆。 下面分析混淆APK后的…

基于asp.net的Web开发架构探索(转)

问题由来 最近在研究适合团队开发的web架构解决方案,该架构即要适合分工协作又要有一定扩展性,适合不同的数据库需要,因此我查阅了一些资料,初步构想出了一套架构,请各位多多指教。 探索 web开发架构最经典莫过于三层架…

ubuntu要更新18.04了,lei了lei了~~~

Ubuntu 18.04 LTS将于2018年4月26日发布。开发商现在有六个月的时间来打造“Bionic Beaver 仿生海狸”。 对于那些你不知道Ubuntu 4 (xx.04)版本遵循27周的时间表(而不是10月发行的25周时间表,由于圣诞节和新年的小事情&#xff0…

SkipList 以及高度的确定

转载:https://www.cnblogs.com/lnlvinso/p/8848883.html 结果:skiplist的高度是个随机值。 SkipList理解 记下自己对跳表SkipList的理解。 SkipList采用空间换时间的思想,通过增加数据间的链接,达到加快查找速度的目的。 数据库L…

20个正则表达式,举一反三,相信对你很有用

转载:https://www.cnblogs.com/wxd0108/p/5580772.html 正则表达式经常被用于字段或任意字符串的校验,如下面这段校验基本日期格式的JavaScript代码: var reg /^(\\d{1,4})(-|\\/)(\\d{1,2})\\2(\\d{1,2})$/; var r fieldValue.match(reg); if(rnull)a…

约瑟夫环问题---循环单链表

约瑟夫环问题是比较经典的问题,原来做的题目是依次输出数字,而原来的循环链表结构不改变,今天遇到一道题是要求按照顺序重新组成一个循环单链表。 题目:一些人围坐一圈报数,形成一个循环单链表,当报数是m或…

IIS AppCreate子目录的错误(0x80020006)

这几天做了升级用的安装包,需要在原来的ASP 的虚拟目录下,再创建一个新的ASPNet 虚拟目录。上网查了C# iis设定的资料,按照上面一路做下来,还是无法成功过。 代码只有两行,如下:DirectoryEntry siteVDir new Director…

网络通信TCP协议三次握手

刚刚看linux公社看见里面一个讲TCP的文章,文章讲的很有意思生动形象,很有助于对TCP协议的理解和掌握,所以转载过来方便以后看一下HAHA~~~TCP是什么? TCP(Transmission Control Protocol 传输控制协议)是一种面向连接(连接导向)的、可靠的、 …

聊聊RocksDB Compact

导语 对于 LevelCompact 策略,RocksDB会根据每一层不同的策略计算出CompactScore,根据CompactScore大小来决定那一层将会优先进行Compact,然后选择Level-N 和Level-(N1)的文件进行Compact。如何计算CompactScore? 如何…

Android入门逆引手册 - 12 评分条(RatingBar)的使用

这里介绍评分条android.widget.RatingBar类的使用。 ● 评分(星)的最大数的设置,调用setNumStars()方法。● 现在的评分的设置,调用setRating()方法。 例程源码(Java)[java]RatingBar ratingBar (RatingBar)findViewById(id.rati…

数据库事务的四大特性以及事务的隔离级别

本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别。 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务包含…

程序员面试的一些注意点

一、前言 自己即将踏上求职的征程,所以整理一篇有关于程序员面试的小窍门,帮助自己和正在求职、即将求职的一些小伙伴跳过一些坑。 二、简历制作1. 不要放头像普通人大概率都不是帅哥美女,所以不想让外观成为评判标准的就不要放照片上去了。2…

如何解决数据倾斜问题?

转载:https://blog.csdn.net/Mr_HHH/article/details/89399518 今天在工作中遇到了数据倾斜的问题,一条SQL执行了8小时才执行完,看计划是先join再做distinct,卡在了join上,数据量比较大,并且重复数据比较多…

白盒测试不是测试,更不高级

测试不仅仅是软件概念,但白盒测试仅仅是软件概念。 上面这句话足以说明白盒测试不是测试,至少不等同于测试。 认为白盒测试更牛逼的一个常用论据是白盒测试需要对代码本身更高的熟悉程度,但说这样的话的人往往没有搞清楚测试究竟需要什么样的…

剑指Offer题解(Python版)

https://blog.csdn.net/tinkle181129/article/details/79326023# 二叉树的镜像 链表中环的入口结点 删除链表中重复的结点 从尾到头打印链表 斐波那契数列 跳台阶 变态跳台阶 矩形覆盖 把字符串转换成整数 平衡二叉树 和为S的连续正数序列 左…

Paypal 在线支付接口应用从零开始,第2节,[支付API原理及流程]

今天看看Paypal支付流程和简单的认证原理,我画了一张图.应该能表达这两点意思了我们的站点名字,为了好理解,暂且就定为西狐的网站吧.点此查看清晰原图恩,理论知识很重要哈,先把这图理解了,下一步我们编程使用沙盒测试就很简单了.如果想更多研究一下还可直接查看Paypal官方提供的…

C语言指针深度理解

指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; 能很方便地使用数组和字符串; 并能象汇编语言一样处理内存地址,从而编出精练而高效的程序。指针极大…

PLSQL DEVELOPER 使用技巧

为什么80%的码农都做不了架构师?>>> 1、右键菜单 在PL/SQL Developer(下面简称PLD)中的每一个文本编辑窗口,如SQL Window,Command Window和Porgram Window,右键点击某个对象名称,会…

为什么不能同时用const和static修饰成员函数?

const修饰的函数: 表示在该函数体内不能修改成员的值,会在函数中添加一个隐式的参数const this*. static修饰的函数没有this指针,与const的用法冲突。 但可以使用static和const修饰成员。 例子如下: class Singleton { public: stati…