在线演示: http://47.244.22.82

python3+django2.0的环境

需要安装的库
pip install django-simple-captcha django-pure-pagination

Ueditor安装注册
到github中搜索djangoueditor,发现一个liyaopinner/DjangoUeditor3_imooc
下载后把DjangoUeditor文件夹放在python指定目录下,我的是D:\Program Files\python3.5\Lib\site-packages

linux中路径查看方式,进入python3命令行后执行

>>> from distutils.sysconfig import get_python_lib
>>> print(get_python_lib())

 一般是/usr/lib/python3/dist-packages
 
 
 
 
一. 准备工作
 
1. 正式环境安装好nginx后,配置文件在/etc/nginx/sites-enable,默认访问首页放在/var/www/html中
当访问该地址的时候,nginx 会按照 index.html,index.htm ,index.php 的先后顺序在根目录中查找文件。如果这三个文件都不存在,那么nginx就会返回403 Forbidden。
 
 
2. 如果某个包下载的比较慢,可以试试豆瓣源,比如pip install -i https://pypi.douban.com/simple pillow==3.4.1
 
3. http://projectsedu.com/  讲解通过nginx和uwsgi部署django应用
 
4. 准备虚拟环境
windows安装
pip install virtualenv,pip install virtualenvwrapper-win
 
ubuntu16安装
pip3 install virtualenv virtualenvwrapper
在~/.bashrc中添加
export WORKON_HOME=$HOME/.virtualenvs 
export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3 
source /usr/local/bin/virtualenvwrapper.sh
重新加载.bashrc文件
source  ~/.bashrc
 
保存退出后,建立一个目录来存放虚拟环境
mkdir $HOME/.virtualenvs
 
新建虚拟环境
mkvirtualenv mxonline
 
进入虚拟环境
workon mxonline
 
测试环境中mxonline如果是跑在虚拟环境中的,使用pip list查看该项目安装了那些第三方包,然后使用pip freeze > requirements.txt把这些第三方包的名字导出来,然后把此文件拷贝到linux正式的虚拟环境中,使用pip install -r requirements.txt就可以全部安装了
 
 
 
5. linux数据库中新建库mxonline3, 然后用navicat把原先的数据传过来
 
 
 
 
二. 服务器配置
 
1. 安装uwsgi
pip install uwsgi
 
 
2. 测试uwsgi
uwsgi --http :8000 --module MxOnline.wsgi
 
 
3. 配置nginx
在项目目录中新建conf/uc_nginx.conf
 
upstream django {
server 127.0.0.1:8000 ;
}
 
server {
listen      80;
server_name 你的ip地址 www.mxonline.com;  #也可以指定对应域名
charset     utf-8;
 
# max upload size
client_max_body_size 75M;   # adjust to taste
 
# Django media
location /media  {
    alias 你的目录/Mxonline/media;  # 指向django的media目录
}
 
location /static {
    alias 你的目录/Mxonline/static; # 指向django的static目录
}
 
# Finally, send all non-media requests to the Django server.
location / {
    uwsgi_pass  django;
    include     uwsgi_params; # the uwsgi_params file you installed
}
}
 
 
4. 将该配置文件加入到nginx的启动配置文件中
sudo ln -s 你的目录/Mxonline/conf/nginx/uc_nginx.conf /etc/nginx/conf.d/
 
 
5. 拉取所有需要的static file 到同一个目录
在django的setting文件中,添加下面一行内容:
STATIC_ROOT = os.path.join(BASE_DIR, "static/"),同时注释掉之前的STATICFILES_DIRS = (...)
   
运行命令
    python manage.py collectstatic
 
 
6. 运行nginx
sudo /usr/sbin/nginx
这里需要注意 一定是直接用nginx命令启动, 不要用systemctl启动nginx不然会有权限问题
 
 
7. 通过配置文件启动uwsgi,根据情况自行修改
在项目目录Mxonline中,新建conf/uwsgi.ini 配置文件, 内容如下:
 
    # mysite_uwsgi.ini file
    [uwsgi]
 
    # Django-related settings
    # the base directory (full path)
    chdir           = 你的目录/MxOnline
    # Django's wsgi file
    module          = MxOnline.wsgi
    # the virtualenv (full path)
 
    # process-related settings
    # master
    master          = true
    # maximum number of worker processes
    processes       = 10
    # 使用socket的启动方式,比http更高效
    socket          = 127.0.0.1:8000
    # ... with appropriate permissions - may be needed
    # chmod-socket    = 664
    # clear environment on exit
    vacuum          = true
    # 你的虚拟环境目录
    virtualenv = /home/bobby/.virtualenvs/mxonline 
    logto = /tmp/mylog.log
 
注:
    chdir: 表示需要操作的目录,也就是项目的目录
    module: wsgi文件的路径
    processes: 进程数
    virtualenv:虚拟环境的目录
 
workon mxonline
uwsgi -i 你的目录/Mxonline/conf/uwsgi.ini &
 
 
8.  windows上测试用未注册域名访问linux上部署的项目
c/windows/system32/drivers/etc/HOSTS文件中添加
47.52.136.86    www.mxonline.com  # 当访问域名时自动跳转到ip地址,因为我们之前在nginx配置文件中添加了这个域名,所以可访问
 
 
9. pkill -f uwsgi 会自动重启uwsgi,在修改配置文件时可用
 
 
10. 正式上线后需要修改的配置
settings.py中修改
DEBUG=False
ALLOWED_HOSTS = ['*']
 
项目urls.py中添加如下,使样式和图片生效
from mxonline.settings import STATIC_ROOT
re_path('static/(?P<path>.*)', serve, {"document_root": STATIC_ROOT}),
 
 
11. 当使用centos普通用户部署环境的时候,有时会出现502错误,是权限问题,只需要修改/etc/nginx/nginx.conf第一行 user root,然后重启nginx:/usr/sbin/nginx -s reload
 
 
12设置自定义的404, 500页面(经测试可成功设置自定义404)

mxonline实战17,上线部署的更多相关文章

  1. Walle - 瓦力上线部署系统搭建攻略

    背景知识:Walle - 瓦力是一个支持svn.git.多用户.多项目.多环境同时部署的上线部署系统,http://www.oschina.net/news/68610/walle-0-9-2 实验系 ...

  2. [实战]MVC5+EF6+MySql企业网盘实战(17)——思考2

    写在前面 今天吃饭回来,突然有一个更好的想法,这里做一下记录. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战(1) [实战 ...

  3. Saiku上线部署准备(三十)

    Saiku上线部署准备 零零散散琢磨了快5个月了,终于快要上线了哈哈哈哈哈.....  激动!!! 以下是本地打包编译saiku至部署到服务器上使用的完整步骤哦 saiku部署到服务器 源码编译需要注 ...

  4. 玩转Django2.0---Django笔记建站基础十二(Django项目上线部署)

    第十二章 Django项目上线部署 目前部署Django项目有两种主流方案:Nginx+uWsGI+Django或者Apache+uWSGI+Django.Nginx作为服务器最前端,负责接收浏览器的 ...

  5. 前端vue开发中的跨域问题解决,以及nginx上线部署。(vue devServer与nginx)

    前言 最近做的一个项目中使用了vue+springboot的前后端分离模式 在前端开发的的时候,使用vue cli3的devServer来解决跨域问题 上线部署则是用的nginx反向代理至后台服务所开 ...

  6. Flask实战第68天:项目上线部署

    在开发机上的准备工作 1.确认项目没有bug 2.用pip freeze >requirements.txt将当前环境的包导出到requirements.txt文件中,方便部署的时候安装 3.将 ...

  7. dcoker实战,使用docker部署NodeJs应用

    docker简介   docker是一个开源的应用容器引擎,可以为我们提供安全.可移植.可重复的自动化部署的方式.docker采用虚拟化的技术来虚拟化出应用程序的运行环境.如上图一样.docker就像 ...

  8. BI之SSAS完整实战教程4 -- 部署至SSAS进行简单分析

    上一篇已经创建了多维数据集的结构. 接下来我们将多维数据集的架构定义发送到Analysis Services实例,部署到AS上去. 文章提纲 部署和浏览多维数据集 SSMS使用简介 总结 一.部署和浏 ...

  9. 如何将java web项目上线/部署到公网

    关于如何将java web上线,部署到公网,让全世界的人都可以访问的问题. 1.在myeclipse中开发好项目,打包成war格式,不会的同学参考以下 http://zhidao.baidu.com/ ...

随机推荐

  1. SOAP 版本可能不匹配: 出现意外的 Envelope 命名空间 http://schemas.xmlsoap.org/wsdl/

    原错误描述:SOAP 版本可能不匹配: 出现意外的 Envelope 命名空间 http://schemas.xmlsoap.org/wsdl/.应为 http://schemas.xmlsoap.o ...

  2. Python_07-常用函数

    1     python常用常用函数 1.1      常用内置函数 1.2      类型转换函数 1.3      和操作系统相关的调用 1.3.1       操作举例 1.4      用os ...

  3. 从值栈获取List集合

    -------------------siwuxie095 从值栈获取 List 集合 1.具体步骤 (1)在 Action 中向值栈放 List 集合 (2)在 JSP 页面中从值栈获取 List ...

  4. 打劫房屋 · House Robber

    [抄题]: 假设你是一个专业的窃贼,准备沿着一条街打劫房屋.每个房子都存放着特定金额的钱.你面临的唯一约束条件是:相邻的房子装着相互联系的防盗系统,且 当相邻的两个房子同一天被打劫时,该系统会自动报警 ...

  5. jrebel+idea 进行热部署配置

    1.安装和激活jrebel这里不在叙说 2.部署项目工程的两种方式 第一:打开项目配置project structure    配置Artificials 第二:tomcat加载项目  然后填写应用名 ...

  6. HTTP Cookie 详解

    参考: http://blog.csdn.net/lijing198997/article/details/22174151

  7. Spring Boot配置FastJson报错'Content-Type' cannot contain wildcard type '*'

    升级到最新版本的fastjson以后报的错,查了一下资料,发现 fastjson从1.1.41升级到1.2.28之后,请求报错:json java.lang.IllegalArgumentExcept ...

  8. Redis数据结构(五)

    存储set (1)和List类型不同的是,Set集合中不允许出现重复的元素 (2)set可包含的最大元素数量是4294967295 存储set常用命令: (1)添加/删除元素 添加 sadd myli ...

  9. thinkphp ajax分页加载更多最简单的实现方法

    <div class="li_list"> <volist name="list" id="vo"> <div ...

  10. uva 10169 - Urn-ball Probabilities !(概率)

    题目链接:uva 10169 - Urn-ball Probabilities ! 题目大意:在一个箱子中,原本有1个红球,然后任意取出(有放回)一个球,然后再往里放一个白球(每次取都要放进一个白球) ...