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

问题描述

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

追踪问题

django测试

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

Python代码测试

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

查看源码

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

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

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

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

寻找答案

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

  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



你可能感兴趣的:(apache,mysql,django,mod_wsgi,AutoTester)