MySQL "fatal error: my_config.h: No such file or directory"的解决方法
时间:2018-09-18
本文章向大家介绍MySQL "fatal error: my_config.h: No such file or directory"的解决方法,需要的朋友可以参考一下
Issue
I encountered an error when I run the python script which need to import the module of "MySQLdb".The error shows like this:
[root@docker1 script]# python Xtrabackup.py
Traceback (most recent call last):
File "backup.py", line 11, in <module>
import MySQLdb
ImportError: No module named MySQLdb
Then I downloaded and installed the latest version of pip to install MySQLdb module:
[root@docker1 pip-18.0]# python setup.py install
...
[root@docker1 pip-18.0]# pip --version
pip 18.0 from /usr/lib/python2.7/site-packages/pip-18.0-py2.7.egg/pip (python 2.7)
But it still doesn't work.it showed "fatal error: my_config.h: No such file or directory":
[root@docker1 script]# easy_install pip
Searching for pip
Best match: pip 18.0
Processing pip-18.0-py2.7.egg
pip 18.0 is already the active version in easy-install.pth
Installing pip script to /usr/bin
Installing pip2.7 script to /usr/bin
Installing pip2 script to /usr/bin
Using /usr/lib/python2.7/site-packages/pip-18.0-py2.7.egg
Processing dependencies for pip
Finished processing dependencies for pip
[root@docker1 script]# pip install mysql-python
Collecting mysql-python
Using cached https://files.pythonhosted.org/packages/a5/e9/51b544da85a36a68debe7a7091f068d802fc515a3a202652828c73453cad/MySQL-python-1.2.5.zip
Installing collected packages: mysql-python
Running setup.py install for mysql-python ... error
Complete output from command /usr/bin/python -u -c "import setuptools, tokenize;__file__='/tmp/pip-install-pm5hyO/mysql-python/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('rn', 'n');f.close();exec(compile(code, __file__, 'exec'))" install --record /tmp/pip-record-GBdMPj/install-record.txt --single-version-externally-managed --compile:
running install
running build
running build_py
creating build
creating build/lib.linux-x86_64-2.7
copying _mysql_exceptions.py -> build/lib.linux-x86_64-2.7
creating build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/__init__.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/converters.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/connections.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/cursors.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/release.py -> build/lib.linux-x86_64-2.7/MySQLdb
copying MySQLdb/times.py -> build/lib.linux-x86_64-2.7/MySQLdb
creating build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/__init__.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/CR.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/FIELD_TYPE.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/ER.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/FLAG.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/REFRESH.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
copying MySQLdb/constants/CLIENT.py -> build/lib.linux-x86_64-2.7/MySQLdb/constants
running build_ext
building '_mysql' extension
creating build/temp.linux-x86_64-2.7
gcc -pthread -fno-strict-aliasing -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -D_GNU_SOURCE -fPIC -fwrapv -DNDEBUG -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -D_GNU_SOURCE -fPIC -fwrapv -fPIC -Dversion_info=(1,2,5,'final',1) -D__version__=1.2.5 -I/usr/local/mysql/include -I/usr/include/python2.7 -c _mysql.c -o build/temp.linux-x86_64-2.7/_mysql.o
_mysql.c:44:23: fatal error: my_config.h: No such file or directory
#include "my_config.h"
^
compilation terminated.
error: command 'gcc' failed with exit status 1
----------------------------------------
Command "/usr/bin/python -u -c "import setuptools, tokenize;__file__='/tmp/pip-install-pm5hyO/mysql-python/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('rn', 'n');f.close();exec(compile(code, __file__, 'exec'))" install --record /tmp/pip-record-GBdMPj/install-record.txt --single-version-externally-managed --compile" failed with error code 1 in /tmp/pip-install-pm5hyO/mysql-python/
[root@docker1 script]#
I even download the MySQL-python package without pip tool to install MySQLdb module,but it turned out to be the same error like using pip.
[root@docker1script]# cd MySQL-python-1.2.5
[root@docker1 MySQL-python-1.2.5]# ll
total 171
drwxrwxrwx 1 mysql mysql 4096 Sep 18 10:17 doc
-rwxrwxrwx 1 mysql mysql 18092 Oct 8 2012 GPL-2.0
-rwxrwxrwx 1 mysql mysql 5687 Jan 1 2013 HISTORY
-rwxrwxrwx 1 mysql mysql 6636 Oct 8 2012 INSTALL
-rwxrwxrwx 1 mysql mysql 309 Jan 2 2014 MANIFEST.in
-rwxrwxrwx 1 mysql mysql 2039 Jan 2 2014 metadata.cfg
-rwxrwxrwx 1 mysql mysql 84709 Jan 2 2014 _mysql.c
drwxrwxrwx 1 mysql mysql 4096 Sep 18 10:17 MySQLdb
-rwxrwxrwx 1 mysql mysql 2352 Oct 8 2012 _mysql_exceptions.py
drwxrwxrwx 1 mysql mysql 4096 Sep 18 10:17 MySQL_python.egg-info
-rwxrwxrwx 1 mysql mysql 1689 Jan 2 2014 PKG-INFO
-rwxrwxrwx 1 mysql mysql 3203 Oct 8 2012 pymemcompat.h
-rwxrwxrwx 1 mysql mysql 1266 Oct 4 2012 README.md
-rwxrwxrwx 1 mysql mysql 398 Jan 2 2014 setup.cfg
-rwxrwxrwx 1 mysql mysql 1088 Oct 8 2012 setup_common.py
-rwxrwxrwx 1 mysql mysql 3392 Jan 2 2014 setup_posix.py
-rwxrwxrwx 1 mysql mysql 609 Jan 2 2014 setup.py
-rwxrwxrwx 1 mysql mysql 1334 Oct 8 2012 setup_windows.py
-rwxrwxrwx 1 mysql mysql 665 Oct 8 2012 site.cfg
drwxrwxrwx 1 mysql mysql 4096 Sep 18 10:17 tests
[root@docker1 MySQL-python-1.2.5]# python setup.py install
...
_mysql.c:44:23: fatal error: my_config.h: No such file or directory
#include "my_config.h"
^
compilation terminated.
error: command 'gcc' failed with exit status 1
After that,I search for a workaround in google,someone says that I need't to install mysql-devel package first:
[root@docker1 MySQL-python-1.2.5]# yum install mysql-devel
...
Error: mariadb101u-common conflicts with 1:mariadb-libs-5.5.60-1.el7_5.x86_64
Error: mariadb101u-config conflicts with 1:mariadb-libs-5.5.60-1.el7_5.x86_64
Error: mariadb101u-libs conflicts with 1:mariadb-libs-5.5.60-1.el7_5.x86_64
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
There were some confilcts with package mariadb-llibs when installing mysql-devel package.Then I have to erase it first:
[root@docker1 MySQL-python-1.2.5]# rpm -e mariadb-libs
error: Failed dependencies:
libmysqlclient.so.18()(64bit) is needed by (installed) perl-DBD-MySQL-4.023-6.el7.x86_64
libmysqlclient.so.18()(64bit) is needed by (installed) python27-MySQL-python-1.2.3-11.el7.x86_64
libmysqlclient.so.18(libmysqlclient_18)(64bit) is needed by (installed) perl-DBD-MySQL-4.023-6.el7.x86_64
libmysqlclient.so.18(libmysqlclient_18)(64bit) is needed by (installed) python27-MySQL-python-1.2.3-11.el7.x86_64
[root@docker1 MySQL-python-1.2.5]# rpm -e --force mariadb-libs
rpm: only installation and upgrading may be forced
rpm -e -Va --nofiles --nodigest mariadb-libs
[root@docker1 MySQL-python-1.2.5]# rpm -e --nodeps mariadb-libs
warning: /etc/my.cnf saved as /etc/my.cnf.rpmsave
After I've erased the package of mariadb-lib,the my.cnf will be saved as my.cnf.rpmnew and my.cnf.rpmsave.The default my.cnf was missing.
[root@docker1 etc]# ll|grep my
-rw-r--r-- 1 mysql mysql 2540 Sep 17 10:05 my3306.cnf
-rw-r--r-- 1 root root 570 Aug 16 22:00 my.cnf.rpmnew
-rw-r--r-- 1 root root 83 Sep 12 13:34 my.cnf.rpmsave
[root@docker1 etc]# cat my.cnf
cat: my.cnf: No such file or directory
And then the afterward installation was extremly successful.
[root@docker1 MySQL-python-1.2.5]# yum install mysql-devel
...
Installed:
mariadb101u-devel.x86_64 1:10.1.32-1.ius.centos7
Dependency Installed:
mariadb101u-common.x86_64 1:10.1.32-1.ius.centos7 mariadb101u-config.x86_64 1:10.1.32-1.ius.centos7
mariadb101u-libs.x86_64 1:10.1.32-1.ius.centos7
Complete!
[root@docker1 MySQL-python-1.2.5]# pip install mysql-python
Collecting mysql-python
Using cached https://files.pythonhosted.org/packages/a5/e9/51b544da85a36a68debe7a7091f068d802fc515a3a202652828c73453cad/MySQL-python-1.2.5.zip
Installing collected packages: mysql-python
Running setup.py install for mysql-python ... done
Successfully installed mysql-python-1.2.5
[root@docker1 MySQL-python-1.2.5]#
- VS 2010一步步开发windows服务(windows service)
- 运算符重载,以及迭代器[foreach]示例
- 牛津大学王宁博士:大数据与有限理性
- 侃哥:苹果服软了就“降速门”公开致歉并祭出优惠
- 委托示例(利用委托对不同类型的对象数组排序)
- event & delegate Demo(事件&委托示例)
- 最简单的匿名方法与委托示例
- Eclipse与Android源码中ProGuard工具的使用
- VSTS知识整理
- msmq在Internet上访问的问题(只能发送,不能接收)
- .Net3.0中的自动属性(示例)
- .net3.0中的扩展方法(示例)
- .NET3.5新特性,Lambda表达式
- 通过XML签名和加密更安全地交换数据
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- iOS逆向之文件系统
- Kettle构建Hadoop ETL实践(四):建立ETL示例模型
- Java并发总篇
- 逻辑漏洞之密码找回漏洞(semcms)
- 逻辑漏洞之越权、支付漏洞
- 多线程基础(二): Thread源码分析
- JeecgBoot环境搭建及前后端项目启动
- Windows下MySQL 8.x和8.x以前版本的安装步骤
- Confluence 6 移动应用 app 管理员需要考虑什么
- leetcode链表之反转链表
- Prometheus监控神器-Kubernetes篇(一)
- Elastic:Elasticsearch 的分片管理策略
- 【Vulnhub】SkyDogCTF
- 「搜索引擎」TF-IDF 文档相关度评分
- 36.Python的字符串方法format