本文将介绍如何在Linux上部署Django + Mysql + Apache环境。我们知道,Django内置的http服务器只能工作在单线程下,做开发和调试时候是可以的,但是生产环境通常都会有多用户并发,而且django的simple HTTP server处理大量静态文件的性能太差,所以要用apache做前端。Django自带的SQLite数据库权限只依赖于文件系统,没有用户帐户的概念,这里我们使用典型的关系型数据库Mysql。看似简单的环境搭建,在实际操作过程中还是遇到了不少的大坑,所以特地将过程记录下来,也希望对大家有小小的帮助。
CentOS 7.5 + python 2.7.5 + Django 1.11.14 + Apache 2.4.6 + Mysql 5.7.23
1. 安装Django
Linux上我们可以直接使用pip安装Django
1.1 安装python(使用CentOS 7.5自带的python即可)
[root@localhost ~]# python --version Python 2.7.5
1.2 网上下载get-pip.py文件安装pip:
wget https://bootstrap.pypa.io/get-pip.py
1.3 pip安装django
[root@localhost ~]# pip install django [root@localhost ~]# python Python 2.7.5 (default, Jul 13 2018, 13:06:57) [GCC 4.8.5 20150623 (Red Hat 4.8.5-28)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> import django >>> django.get_version() '1.11.14'
2. 安装Apache
Linux上使用yum安装Apache即可
[root@localhost ~]# yum install httpd [root@localhost ~]# httpd -V [Thu Aug 16 20:57:04.487586 2018] [so:warn] [pid 1605] AH01574: module wsgi_module is already loaded, skipping Server version: Apache/2.4.6 (CentOS) Server built: Jun 27 2018 13:48:59 Server's Module Magic Number: 20120211:24 Server loaded: APR 1.4.8, APR-UTIL 1.5.2 Compiled using: APR 1.4.8, APR-UTIL 1.5.2 Architecture: 64-bit Server MPM: prefork threaded: no forked: yes (variable process count)
注意:使用yum安装的httpd,其安装目录位于/etc/httpd/,我们只需要配置/etc/httpd/conf/httpd.conf即可
3. 安装Mysql
我们使用yum安装Mysql,需要先更新yum源
[root@localhost ~]# wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm [root@localhost ~]# rpm -ivh mysql57-community-release-el7-8.noarch.rpm [root@localhost ~]# yum install mysql-community-server
[root@localhost ~]# yum install mysql-community-devel
注意:yum安装的Mysql其文件目录如下
- 配置文件:/etc/my.cnf
- 日志文件:/var/log/mysqld.log
- 服务启动脚本:/usr/lib/systemd/system/mysqld.service
- socket文件:/var/run/mysqld/mysqld.pid
4. 配置(重点)
以上三步都非常容易,但是将这三个环境配置好,还是费了我不少的时间...
4.1 配置Mysql
[root@localhost ~]# systemctl start mysqld # 开启Mysql服务后,会为root设置一个默认密码,我们首先重置密码 # 获得默认密码 [root@localhost ~]# cat /var/log/mysqld.log | grep -i password [root@localhost ~]# mysql -uroot -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 8 Server version: 5.7.23 MySQL Community Server (GPL) mysql>ALTER USER 'root'@'localhost' IDENTIFIED BY 'Sam_tech_0912'; # 重置密码后,我们创建一个数据库,因为后续django连接Mysql时需要输入数据库名称 mysql> create database Platform default charset=utf8; Query OK, 1 row affected (0.00 sec) mysql> quit Bye
4.2 django中配置Mysql
django中关于Mysql的配置:
DATABASES = { 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 'ENGINE': 'django.db.backends.mysql', 'NAME': 'Platform', 'HOST': '127.0.0.1', 'PORT': '3306', 'USER': 'root', 'PASSWORD': 'Sam_tech_0912', } }
django中其他的部分的配置:
DEBUG = True ALLOWED_HOSTS = ["*",] TEMPLATES = [ { 'BACKEND'