django2+python3+uwsgi+centos7部署网站
Centos7中安装Python虚拟环境
1.为什么要搭建虚拟环境?
- 问题:如果在一台电脑上, 想开发多个不同的项目, 需要用到同一个包的不同版本, 如果使用上面的命令, 在同一个目录下安装或者更新, 新版本会覆盖以前的版本, 其它的项目就无法运行了.
- 解决方案 : 虚拟环境
作用 : 虚拟环境可以搭建独立的python运行环境, 使得单个项目的运行环境与其它项目互不影响.
在开发过程中, 便于控制python的web框架或工具包的版本,创建多个虚拟环境,就相当于我们在一台电脑上拥有了多个python解释器。
好了,接下来我们开始安装了~
2.搭建python虚拟环境
1.我们先创建一个隐藏目录 .virtualenvs,所有的虚拟环境都放在此目录下
2.安装虚拟环境
pip3 install virtualenv
pip3 install virtualenvwrapper
- 1
- 2
3.配置环境变量,增加最后两行 vim ~/.bashrc
export WORKON_HOME=/root/.virtualenvs
source /usr/local/python3.6.5/bin/virtualenvwrapper.sh
运行测试:source ~/.bashrc
发现报错了,是说 /usr/bin/python 没有 virtualenvwrapper 模块,我们把 /usr/bin/python 换成 python3
报错截图
思路:/usr/bin/python → /usr/bin/python2
操作:mv /usr/bin/python /usr/bin/python2
然后把 python3 执行文件通过软链接的方式放到 /usr/bin/python
操作:ln -s /usr/local/python3.6.5/bin/python3 /usr/bin/python
再次执行source ~/.bashrc
成功!
4.创建虚拟环境
- 在python3中,创建虚拟环境,需要联网!!!
mkvirtualenv -p python3 虚拟环境名称
例 :
mkvirtualenv -p python3 Django_virtualenv
出现这种错误,是因为 virtualenv 这个基础依赖包被安装在默认 Python 目录下,就需要做一个软连接 ln -s
首先还是用 find / -name "virtualenv" 去找到位置
然后做软连接ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv
创建成功
提示 :
1.创建虚拟环境需要联网
2.创建成功后, 会自动工作在这个虚拟环境上
3.工作在虚拟环境上, 提示符最前面会出现 “虚拟环境名称”
- 1
- 2
- 3
- 4
3.使用虚拟环境的命令
选择虚拟环境:
workon 两次tab键退出虚拟环境
deactivate删除虚拟环境
rmvirtualenv 虚拟环境名称
例 :删除虚拟环境py3_flask先退出:deactivate
再删除:rmvirtualenv py3_flask
4.在虚拟环境中安装工具包
工具包安装的位置 :
~/.virtualenvs/py3_flask/lib/python3.5/site-packages安装工具包,先使用 workon Django_virtualenv 进入到 虚拟环境
pip install 包名称例 : 安装 django==1.11.11 的包
pip install django==1.11.11查看虚拟环境中已经安装的包
pip list
OK,到此虚拟环境安装完成,你也可以根据自己的需要创建多个虚拟环境
部署

nginx配置:
nginx配置文件内容
vim /etc/nginx/conf.d/students.conf (students.conf自定义起名字)
upstream students{
server unix:///root/django-demo/students.sock;
}
server{
listen 80;#端口号
server_name 192.168.254.67;服务器ip
charset utf-8;设置中文
client_max_body_size 75M;文件传输最大75M
location /static{
alias /root/django-demo/static_dist;静态文件存放位置
}
location /{
uwsgi_pass students;
include /etc/nginx/uwsgi_params;加载参数
}
}
students_uwsgi.ini文件内容
[uwsgi]
chdir = /root/django-demo #项目名字
module = students.wsgi #模块加载
home = /root/.virtualenvs/django-env-py3#虚拟环境
socket = /root/django-demo/students.sock
chmod-socket = 666 #设置权限
django2+python3+uwsgi+centos7部署网站的更多相关文章
- Django+uWSGI+Nginx 部署网站
Django 1.11设置 保证Django在本地调试没有问题: 当然这是前提^_^ 收集静态文件至指定文件夹 Django静态文件设置具体参考:https://docs.djangoproject. ...
- 「Linux+Django」Django+CentOs7+uwsgi+nginx部署网站记录
转自:http://www.usday.cn/blog/51 部署前的准备: 1. 在本地可以运行的django项目 2. 一台云服务器,这里选用Centos系统 开始部署: 首先在本地导出项目需要的 ...
- Python3 + django2.0 + apache2 + ubuntu14部署网站上线
自己尝试在本地搭建了 Django 项目后,想部署到自己云服务器上,经常多次尝试和多次踩坑(捂脸),总结如下: 环境:ubuntu14, django2.0, apache2. 1.首先安装需要的库包 ...
- 基于腾讯云CentOS7.4+MySQL5.7+Python3+uwsgi+nginx的Django项目部署
准备知识 1.django一个基于python的开源web框架,请确保自己熟悉它的框架目录结构. 2.uWSGI一个基于自有的uwsgi协议.wsgi协议和http服务协议的web网关 3.nginx ...
- Linux 集群概念 , wsgi , Nginx负载均衡实验 , 部署CRM(Django+uwsgi+nginx), 部署学城项目(vue+uwsgi+nginx)
Linux 集群概念 , wsgi , Nginx负载均衡实验 , 部署CRM(Django+uwsgi+nginx), 部署学城项目(vue+uwsgi+nginx) 一丶集群和Nginx反向代理 ...
- 使用uWSGI+nginx部署Django项目
最近使用django写了一些项目,不过部署到服务器上碰到一些问题,还有静态文件什么的一堆问题,这里总结一下碰到的问题和解决方案,总体思路是按照官方文档走的. 原文地址:http://uwsgi-doc ...
- Python基础 - Ubuntu+Nginx+uwsgi+supervisor部署Flask应用
网上找了许多讲关于Flask应用部署的文章几乎都是一个helloworld的Demo,按照helloworld来部署都没问题,但实际项目部署时还是遇到了不少问题.在这里简单写下自己成功部署的过程,防止 ...
- virtualvenv+django+uWSGI+nginx 部署
原创博文 转载请注明出处! 1. virtualvenv 2. django 3. uWSGI 4. nginx 5. 踩坑记录 1. virtualvenv virtualvenv install ...
- centosflask+uWSGI+nginx部署
centosflask+uWSGI+nginx部署 1. 概念 Flask自带webserver--Werkzeug,可以搭建服务,运行网站.但在开发时,一般会用专业的--uWSGI. 另外 ...
随机推荐
- python 从大到小排序
a = [3,7,4,9]a = sorted(a,reverse=True)print(a)#[9, 7, 4, 3]
- 毕设之iframe跳转子页面问题
我的Django项目中的index.html分为三个层次,head.body.footer.其中body细分为left和right两部分,right的地图是使用iframe嵌入的map.html页面, ...
- mybatis generator 源码学习
mybatis/generator 源码地址mybatis/parent 源码地址1. 分别点击Download ZIP下载到本地. 2. 解压generator-master.zip中的core到g ...
- c#线程池中的异常
static void Main(string[] args) { //写日志 //使用线程池 ; i < ; i++) { ThreadPool.QueueUserWorkItem(new W ...
- vue父子组件实现v-model
话不多说,直接上代码 <div id="app"> <price-input v-bind:value="price" v-on:input= ...
- VBA 生成XML(转)
需要引用连个库,Microsoft ADO Ext. 6.0 for DDL and Security, Miscrosoft ActiveX Data Objects 2.7 Library . ...
- jQuery的1.x版本的$(element).css()设置元素字体颜色时出现的问题(在IE8以下)
最近赶项目,自己写了个基于jQuery的弹出层插件,中间遇到一个问题,怎么也找不到解决方法,最后发现就是空格的问题...欲哭无泪啊... 在给函数传参时,因为写css代码时习惯在:后面加个空格在写样式 ...
- swift 实现拍照 选择相册
//点击按钮的方法 func photos() { self.showBottomAlert() } /// 屏幕底部弹出的Alert func showBottomAlert(){ let aler ...
- 30. pt-upgrade
用来测试新老版本数据库对sql的结果是否一致.两台开发测试数据库,一台是老版本,一台是新版本,来做比较,生产库别用. pt-upgrade h=192.168.100.101,P=3306,u=adm ...
- Mad Libs游戏,华氏与摄氏转换
华氏温度 与 摄氏温度的相互转换 公式:摄氏 ℃=5/9(°F-32) 华氏°F= ℃×9/5+32 # -*- coding: UTF-8 -*- num=input('输入摄氏温度:') num ...
