mysql交叉编译总结
来源:互联网 发布:python excel 编辑:程序博客网 时间:2024/05/17 22:01
版本:mysql-5.6.14.tar.gz
目标系统:基于linux的x86_64位系统
首先,在虚拟机里,正常配置(cmake ./ --xxx)、编译(sudo make)、安装(sudo make install)myslq。
为什么先要正常编译mysql?
(1)熟悉过程,整体的感受一下从配置到编译再到安装成功的过程;
(2)在后面的交叉编译过程中会用到正常编译生成的一些文件。
然后,创建一个交叉编译目录,把mysql解压的这个目录下。
第一步:修改mysql解压目录下的CMakeList.txt文件,在该文件的PROJECT(${MYSQL_PROJECT_NAME})之前添加
SET(CMAKE_SYSTEM_NAME Linux) #指定交叉编译目标系统(想要进行交叉编译,这一项是必配的,并且Linux要写对,不能写成linux,不然在cmake时会提示System is unknown to cmake,虽然配置可以通过,但是编译的时候会出很多奇怪的错)
SET(CMAKE_C_COMPILER xxx-gcc) #指定C交叉编译器SET(CMAKE_CXX_COMPILER xxx-g++) #指定C++交叉编译器
SET(CMAKE_FIND_ROOT_PATH "/opt/interl") #指定交叉编译环境安装目录
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) #从来不在指定目录下查找工具程序
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) #只在指定目录下查找库文件
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) #只在指定目录下查找头文件
以上参数详细解释,可查看http://www.cmake.org/Wiki/CMake_Cross_Compiling
第二步:进行配置,生成Makefile
执行cmake . --XXX(参数)
第三步:进行编译
sudo make && sodu make install
在mysql编译生成的安装目录下有个文件是INSTALL_BINARY,这个就是mysql的安装说明书。(我觉得每个正规的软件都应该带有安装说明书,不然用户怎么知道这个玩意怎么搞)
1,在cmake过程中,发生
---- Could NOT find Curses (missing: CURSES_LIBRARY CURSES_INCLUDE_PATH)
curses是mysql依赖的一个库,这个库也应该进行交叉编译。解决这个问题可在cmake后面添加-DCURSES_LIBRARY=/usr/lib/libcurses.so -DCURSES_INCLUDE_PATH=/usr/include/ncurses(或指定交叉编译该库目录和头文件目录)
可从正常编译过的mysql目录下查找该文件,并拷贝到/usr/bin/目录下
3,在编译过程中发生curses.h: No such file or directory的错误,
可在去编译目录下找到CMakeLists.txt,在该文件中的INCLUDE_DIRECTORY()中添加${CURSES_INCLUDE_PATH},如下
INCLUDE_DIRECTORY(
....
....
${CURSES_INCLUDE_PATH}
)
添加${CURSES_INCLUDE_PATH}的前提是在cmake的时候使用-DCURSES_INCLUDE_PATH指定的curses头文件目录
- mysql交叉编译总结
- mysql交叉编译总结
- MySQL交叉编译
- MySQL交叉编译
- 交叉编译总结
- Linux交叉编译总结
- Mysql交叉连接总结
- 交叉编译Apache+PHP+MySQL
- 交叉编译mysql客户端libmysql
- 交叉编译mysql客户端libmysql
- 交叉编译mysql客户端libmysql
- linux交叉编译的总结
- DM365交叉编译问题总结
- 那些交叉编译问题总结
- 交叉编译工具问题总结
- 对于嵌入式交叉编译总结
- MySQL c客户端的交叉编译
- net-snmp交叉编译时问题总结
- 为什么我们需要uCos
- JS中的indexOf和lastIndexOf
- win7 wamp服务器php访问缓慢的可能原因以及解决方便
- mitmproxy 自身代理设置
- 字符串统计
- mysql交叉编译总结
- 简要的Windows API函数大全(1)
- 自定义数字图象处理基类
- 函数:atexit
- sql 2005 用户 sa 登录失败,该用户与可信SQL Server连接无关联 错误18452
- 敏捷开发的Scrum晨会实践
- linux 正则应用例子。
- X86控制寄存器和系统地址寄存器+实模式和保护模式
- 简要的Windows API函数大全(2)