自己尝试在本地搭建了 django 项目后,想部署到自己云服务器上,经常多次尝试和多次踩坑(捂脸),总结如下:
环境:ubuntu14, django2.0, apache2。
1.首先安装需要的库包,在 ubuntu 下执行如下指令,为了能顺利安装建议使用 root 用户登录 ubuntu 或在 apt-get 前加上 sudo :
安装 apache2
1
2
|
apt - get update #获取更新列表 apt - get install apache2 #安装 apache2apt-get install libapache2-mod-wsgi-py3 #让 apache2识别 python 程序的请求,安装 mod-wsgi模块 |
确认安装的 apache2 版本号
1
|
apachectl - v |
安装和配置 git(这是为了从远程文档库中推送远程仓库到本地,如需上线的 django 项目)
1
2
3
|
apt - get install git git config - - global user.name 'yourname' git config - - global user.email 'youremail' |
安装 python 的 pip 组件管理程序和虚拟机环境程序 virtualenv
1
2
|
apt - get install python3 - pip pip3 install virtualenv |
2.配置远程的 django 项目
linux 操作系统中的 apache 网页服务器一般会把网页放在 /var/www/html 中,(安装 apache2后便生成 /var/www 目录),所以我们也将 django 项目放在 /var/www 下。首先在 /var/www 下使用 virtualenv 创建虚拟环境并启用,然后再使用 git clone 命令推送远程 django 项目分支到本地(这里以我自己的仓库为例https://github.com/weixuqin/mydjango.git),操作如下:
1
2
3
4
5
6
|
cd / var / www #移动到 /var/www 目录下 virtualenv venv #创建虚拟环境 venv source venv / bin / activate #激活虚拟环境 venv git clone https: / / github.com / weixuqin / mydjango.git #克隆远程仓库到本地 cd mydjango / mblog #移动到项目目录 pip install - r requirements.txt #安装 requirements.txt文件中的库包 |
接下来我们可以使用下列命令来启动 django 来访问看看网站内容是否完整呈现。
1
|
python manage.py runserver 0 : 8000 |
3.修改settings.py,增加静态文件等设置
正式上线的网站我们不能通过使用 python manage.py runserver 这样的方式启用。应该通过网页服务器(如 apache)把远程浏览器的请求转送到 django 程序中执行,再把执行后的结果通过 apache 传回给浏览器。
主要涉及到两个文件,setting.py 和 wsgi.py。setting.py 负责做 django 网站的相关设置,而 wsgi.py 负责创建一个可以让 apache 顺利转交程序代码以及返回执行结果的设置文件。
setting.py 中修改如下:
1
2
3
4
5
6
7
8
9
|
# security warning: keep the secret key used in production secret! #基于安全考虑,把原有 secret_keys的内容创建为/etc/secret_key.txt 文件,并使用读取的方式获取 secret_keys 的内容 with open ( '/etc/secret_key.txt' ) as f: secret_key = f.read().strip() # security warning: don't run with debug turned on in production! debug = false #关闭 debug 模式,关闭后静态文件不会自动加载,需指定路径 allowed_hosts = [ '*' ] #指定允许存取此网站的 ip 地址为'*',表示不做任何限制 |
然后我们修改 setting.py,让静态文件正常加载:
1
2
3
4
5
|
static_url = '/static/' staticfiles_dirs = [ os.path.join(base_dir, 'static' ) ] statc_root = '/var/www/staticfiles' |
然后运行
1
|
python manage.py collectstatic |
将所有staticfiles_dirs中所有文件夹中的文件,以及各app中static中的文件都复制到 static_root 指定的文件夹中,把这些文件放到一起是为了用apache等部署的时候更方便。
linux 对文件权限很敏感,我们还需要修改文件权限让 apache2 能够正确读取到。
一般目录权限设置为 755,文件权限设置为 644 。
1
2
3
|
cd / var / www / mydjango / mblog sudo chmod - r 644 zqxt sudo find mblog - type d | xargs chmod 755 |
4.修改 apache 中的文件,让网站上线
创建一个网站的配置文件
1
|
sudo vim / etc / apache2 / sites - available / sitename.conf |
这里以我的配置文件为例,可根据实际需求自行更改
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<virtualhost * : 80 > #添加 wsgi.py 文件路径和虚拟环境路径 wsgiscriptalias / / var / www / mydjango / mblog / mblog / wsgi.py wsgidaemonprocess mblog python - path = / var / www / mydjango / mblog: / var / www / venv / lib / python3. 4 / site - packages wsgiprocessgroup mblog #添加静态文件路径 alias / static / / var / www / staticfiles / <directory / var / www / staticfiles> require all granted < / directory> #获取 wsgi.py 中内容 <directory / var / www / mydjango / mblog / mblog> <files wsgi.py> require all granted < / files> < / directory> < / virtualhost> |
切换到目录:/etc/apache2/sites-available/ 运行:
1
2
3
|
sudo service apache2 reload sudo a2dissite 000 - default && sudo a2ensite sitename.conf sudo service apache2 restart |
接着输入 服务器 ip 地址,如果成功,你将看到网站显示正常的内容,后续可以通过将域名解析到服务器等方式来访问。
我自己的如下:
**ps:自己将域名解析到服务器后网站一直报500错误,但是自己通过 ip 地址访问却一切正常,查找下原因,发现是解析域名到服务器,服务器如果在国内的,需要备案,不然是无法访问的,而自己恰巧是腾讯云的国内服务器,查找了好久,才发现一直报错是什么原因(捂脸)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/weixuqin/p/9158919.html