apache mod_wsgi 部署django项目后链接不上mysql

问题描述

作好的django项目,使用python manage.py runserver 能够正常work. 然而当将项目使用mod_wsgi部署到apache上以后却不能链接mysql.一直报错:“Internal Server Error”,查看日志信息,除了“Can't connect mysql”仍是连不上mysql.python

追踪问题

django测试

分别在debug模式以及debug off模式下运行项目,无任何异常,足以证实项目自身配置没任何错误。mysql

Python代码测试

运行python manage.py shell,导入MySQLdb,使用驱动代码测试也无异常。说明驱动的版本什么的没有错误。web

查看源码

在django/admin/db/backend/mysql/base.py中直接修改链接数据库的参数信息,并在MySQLdb中的_init.py中打印传进来的参数信息。sql

  1. python manage.py runserver debug模式开与关打印出来的信息一致。shell

  2. 开启apache 访问主页打印出来的信息与上述信息无差别。数据库

这么以来就能够得出结论:项目组件以及配置没什么错误。apache

寻找答案

通过问题的一系列追踪,查询网络无果。想起mod_wsgi这货,再根据这个去搜得出结论apache在安装的时候所配置的系统用户apache/apache没有权限访问默认的mysql.sock配置文件所在路径。让修改这个权限,但是真不会修改。因而开始下面的尝试:django

  1. 直接修改apache配置文件中的user和group为root,比较系统中root的权限最高,没有他访问不了的东西。结果在重启apache的时候报错,不容许使用root用户。网络

  2. 又将其修改成mysql/mysql,因mysql/mysql是咱们在安装mysql时所使用的系统用户。重启却无任何影响,依然是Can't connect mysql测试

  3. 再想一想,通常项目生产环境也不会把web跟db配置在一台Server上倒不如换个其余机器上的mysql配置。果真如此能够正常访问了。

  4. 因SELinux阻止apache访问,另外一个问题就是须要为apache受权:

    setsebool -P httpd_can_network_connect 1

    setsebool -P httpd_can_network_connect_db 1

相关文章
相关标签/搜索