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

MySQL Connector/C++使用过程中的问题

Linux环境下,使用mysql connector cpp的时候,链接的时候报错:

/usr/bin/ld: warning: libssl.so.10, needed by /usr/lib64/libssh2.so.1, may conflict with libssl.so.1.1
/usr/bin/ld: ext/openssl/.libs/xp_ssl.o: undefined reference to symbol 'SSLv3_server_method@@libssl.so.10'
/usr/lib64/libssl.so.10: error adding symbols: DSO missing from command line
collect2: error: ld returned 1 exit status

类似于上面这种,总之是libmysqlcppconn.so使用的libssl与现在开发环境其他库(如boost,rbmq等)使用的libssl版本不一样。

比如当前我们使用的是libssl.so.10, 也就是libssl.so.1.0.2的版本,所以我要找到一个同样使用libssl.so.1.0.2的 libmysqlcppconn,或者至少是libssl.so.1.0.*

但是这样的libmysqlcppconn是比较老的版本,至少要是1.1.9之前的版本,发布时间是2017年以前。而我们的编译环境使用的是c++17(试了c++11似乎也不行)。 比如用libmysqlcppconn.so.1.1.9 和c++17编译,链接的时候会报这样的错误:

***/cppconn/exception.h:39:34: error: ISO C++17 does not allow dynamic exception specificationsvoid* operator new(size_t size) throw (std::bad_alloc) { return ::operator new(size); }  \

看起来也是兼容性的问题,c++17已经抛弃了这种写法,从c++版本上考虑,必须使用较新版本的libmysqlcppconn。

而我们开发环境又不太好改,毕竟大家用的是同一套开发环境,到此,陷入了死胡同。

最终解决办法:库文件还使用ibmysqlcppconn.so.1.1.9, 以兼容libssl.so.10。把头文件替换成更新的版本,比如1.1.11(不敢版本跨度太大,否则可能会有问题),以兼容c++17。

这样链接成功,运行正常。

另外,兼容GLIBC也要,查看GBLIC的方式:

strings /lib64/libc.so.6 | grep GLIBC

下载的mysqlcppconn文件名中包含了GBLIC版本,比如mysql-connector-c++-1.1.11-linux-glibc2.12-x86-64bit.tar.gz 需要glibc2.12

Ref:
https://dev.mysql.com/doc/connector-cpp/1.1/en/connector-cpp-introduction.html
https://downloads.mysql.com/archives/c-cpp/
https://www.likecs.com/ask-163341.html

http://www.lryc.cn/news/36248.html

相关文章:

  • SpringBoot下的Spring——DAY04——动态代理总结、AOP、自定义注解进行拦截、动态获取注解参数、通知方法(内含源代码)
  • Spark MLlib概述
  • Git 命令行5步解决冲突方法(亲测有效)
  • 在线帮助文档——让用户更方便地获取帮助
  • 一小时轻松掌握Git,看这一篇就足够
  • spring cloud stream 自定义binder
  • 计算机网络之HTTP协议
  • 如何挖掘专利创新点?
  • 虚函数和纯虚函数
  • Framework源码面试——Handler与事件传递机制面试集合
  • iOS开发-bugly符号表自动上传发布自动化shell
  • MySQL OCP888题解046-哪些语句会被记录到binlog
  • 【前端学习】D5:CSS进阶
  • 【bioinfo】融合检测软件FusionMap分析流程和报告结果
  • C++基础了解-17-C++日期 时间
  • MOV压敏电阻的几种电路元件功能及不同优势讲解
  • uniapp+uniCloud实战项目报修小程序开发
  • 演唱会的火车票没了?Python实现12306查票以及zidong购票....
  • Linux发行版本与发行版的简单的介绍
  • 前后端分离项目学习-vue+springboot 博客
  • 关于指针运算的一道题
  • 【论文简述】Learning Optical Flow with Kernel Patch Attention(CVPR 2022)
  • Java学习-MySQL-列的数据类型
  • 终端配色-Docker容器终端
  • SQL基础培训04-插入数据
  • Apache HTTP Server <2.4.56 mod_proxy 模块存在请求走私漏洞(CVE-2023-25690)
  • SpringBoot 集成 elasticsearch 7.x和对应版本不一致异常信息处理
  • 求职季必看系列:Java如何高效面试?
  • 点云分割预研
  • 【数据结构】栈和队列 (栈 栈的概念结构 栈的实现 队列 队列的概念及结构 队列的实现 栈和队列面试题)