Ubuntu+Django+Nginx+uWSGI+Mysql搭建Python Web服务器

闲着无聊的时候部署了一个Django项目玩,用vm虚拟机部署的。

准备工作

我使用的系统是Ubuntu16.04,大家可以去官网下载

1. 更新apt-get

sudo apt-get update
sudo apt-get upgrade

2. 安装SSH

sudo apt-get install ssh

装好以后,用ifconfig查看一下IP地址

可以看到IP地址是192.168.0.154,下面我们就使用XSHELL连接192.168.0.154进行操作了。

3. 安装Git

这一步不是必须的,因为我的测试项目是放在git.oschina.com上的,安装git获取项目代码就很方便了

sudo apt-get install git

安装配置MySQL

1. 安装

sudo apt-get install mysql-server

安装过程中会提示让你设置root密码

2. 配置

2.1 数据库初始化:

sudo mysql_install_db

2.2 运行数据库Mysql安全配置向导

sudo mysql_secure_installation

输入root密码

是否修改root密码,因为前面已经设置过了,选n

是否移除匿名用户,肯定是要选y的

是否允许远程登陆,如果选n的话,只能在本机访问数据库,建议选y

是否移除test数据库,建议选是

重新加载权限表,选y

All done!

安装配置Python环境

1.安装python-dev包

sudo apt-get install python-dev

2.安装pip

sudo apt-get install python-pip

3.更换pip源
因为国内使用默认的pip源速度很慢,所以需要更换,在用户根目录下新建.pip目录,在该目录下新建pip.conf文件

sudo mkdir ~/.pip
sudo vi ~/.pip/pip.conf

然后在文件里写上:

[global]
index-url = http://mirrors.aliyun.com/pypi/simple/ [install]
trusted-host=mirrors.aliyun.com

4.安装配置VirtualEnv和VirtualEnvWrapper
VirtualEnv可以管理多个开发环境,VirtualEnvWrapper使得VirtualEnv变得更好用

sudo pip install virtualenv virtualenvwrapper

安装完成以后,需要在环境变量中加入一些配置:
下面这句话是使用python3才需要执行的,python2不需要

echo "export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3" >> ~/.bashrc

不管python是什么版本,都要执行下面两句:

echo "export WORKON_HOME=~/Env" >> ~/.bashrc
echo "source /usr/local/bin/virtualenvwrapper.sh" >> ~/.bashrc

可以重启系统激活,也可以运行:

source ~/.bashrc

然后就可以开始建立一个虚拟环境:

mkvirtualenv first

你会发现,提示符变成(first)user@hostname:~$,表示现在已经进入first的虚拟环境,在此环境下进行的pip等操作,只会在当前环境下生效,当前虚拟环境在/home/siva/Env/first目录下

Django项目配置

1.安装django

我使用选择版本来安装:

pip install django==1.10.1

2.下载或拷贝项目

安装完成以后,使用git把项目clone下来,此处填写你自己的地址:

git clone https://git.oschina.net/xxx/Siva_First.git

此例子的项目名称是Siva_First,路径是在/home/siva/下

3.配置django

用Mysql建好项目的数据库,然后进入Siva_First目录,用django应用数据模型:

python manage.py makemigrations
python manage.py migrate

建立后台超级用户:


python manage.py createsuperuser

静态文件安置:

python manage.py collectstatic

4.测试项目

运行开发服务器测试一下是否可以正常运行:

python manage.py runserver 0.0.0.0:8000

这时,用浏览器打开http://192.168.0.154:8000/可以看到网站

5.退出虚拟环境

因为当前是在first虚拟环境下,为了下一步的安装,必须退出当前的虚拟环境:

deactivate

uWSGI安装和配置

1.安装uWSGI
pip下安装很简单:

sudo pip install uwsgi

我们可以测试一下uwsgi是否安装成功

uwsgi --http :8000 --home /home/siva/Env/first --chdir /home/siva/Siva_First -w Siva_First.wsgi

上面的命令是使用8000端口,虚拟环境在/home/siva/Env/first,项目在/home/siva/Siva_First下

2.配置uWSGI

使用上面的命令行来部署网站肯定是不行的,我们需要使用“Emperor mode”,建立一个目录来放配置文件:

sudo mkdir -p /etc/uwsgi/sites
cd /etc/uwsgi/sites

以项目名称来命名这个配置文件:

sudo vi Siva_First.ini

内容如下:

[uwsgi]
project = Siva_First
base = /home/siva chdir = %(base)/%(project)
home = %(base)/Env/%(project)
module = %(project).wsgi:application master = true
processes = 5 socket = %(base)/%(project)/%(project).sock
chmod-socket = 664
vacuum = true

project是项目名称,base是项目所在位置

现在,配置文件建好了,但是uwsgi还不能自动运行我们需要在/etc/init目录中建一个启动脚本:


sudo vi /etc/init/uwsgi.conf

内容如下:

description "uWSGI application server in Emperor mode"

start on runlevel [2345]
stop on runlevel [!2345] setuid siva
setgid www-data exec /usr/local/bin/uwsgi --emperor /etc/uwsgi/sites

这一步完成以后,uwsgi还是不能正常启动,是因为www-data用户组还没有创建,等我们装完nginx以后就可以了。

反向代理:Nginx的安装和配置

1.安装

sudo apt-get install nginx

2.创建配置文件

sudo vi /etc/nginx/sites-available/Siva_First

内容如下:

server {
listen 80;
server_name 192.168.0.154; location = /favicon.ico { access_log off; log_not_found off; }
location /static/ {
root /home/siva/Siva_First;
} location / {
include uwsgi_params;
uwsgi_pass unix:/home/siva/Siva_First/Siva_First.sock;
}
}

然后把这个配置文件链接到sites-enabled目录下

sudo ln -s /etc/nginx/sites-available/Siva_First /etc/nginx/sites-enabled/

检查一下配置文件的语法是否有问题

sudo service nginx configtest

如果没问题,那么重启一下nginx和uwsgi的服务就可以访问了

 
sudo service nginx restart
sudo service uwsgi restart

Ubuntu+Django+Nginx+uWSGI+Mysql搭建Python Web服务器的更多相关文章

  1. [阿里云部署] Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器

    部署地址:123.56.7.181 Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器 这个标题就比之前的"ECS服务器配置Web环境的全过程及参考资料&qu ...

  2. ubuntu+Django + nginx + uwsgi 部署

    ubuntu+Django + nginx + uwsgi 部署 0.前期准备 注意:以下几件事都必须在激活虚拟环境下完成 运行以下命令生成项目所需的依赖列表,会在项目根目录生成一个requireme ...

  3. ubuntu12.04 安装nginx+php+mysql (lnmp)的web服务器环境

    1.Ubuntu12.04 安装nginx+php+mysql (lnmp)的web服务器环境 http://blog.db89.org/ubuntu12-04-install-nginx-php-m ...

  4. Linux(8)- nginx+uWSGI+virtualenv+supervisor 发布web服务器

    一.理论梳理 WSGI是web服务器的网关接口,它是一个规范,描述了web服务器(下图中的WEB server)如何与web应用程序(下图中的Application)通信,以及web应用程序如何链接在 ...

  5. Ubuntu django+nginx 搭建python web服务器文件日志

    uwsgi 配置文件 [uwsgi] http-socket = 127.0.0.1:8080 # 项目目录 chdir=/home/ubuntu/mkweb # 指定项目的application m ...

  6. Ubuntu + Django + Nginx + uwsgi

    环境 Ubuntu 14.04 Python 2.7 Django 1.8.4 1 安装Nginx     sudo apt-get install nginx 测试  sudo /etc/init. ...

  7. 分享关于搭建高性能WEB服务器的一篇文章

    这篇文章主要介绍了Centos5.4+Nginx-0.8.50+UWSGI-0.9.6.2+Django-1.2.3搭建高性能WEB服务器的相关资料,需要的朋友可以参考下(http://m.0813s ...

  8. Nginx+uWSGI+Django+Python+ MySQL 搭建可靠的Python Web服务器

    一.安装所需工具 yum -y install gcc gcc-c++ rpm-build mysql* libtool-ltdl* libtool automake autoconf libtool ...

  9. Django+Nginx+MongoDB+Mysql+uWsgi的搭建

    搭建目标如下: 图:系统架构图 这个系统可以提供web服务及其它查询应用服务,我用其做一个二手房信息搜集.处理及分发的系统,可以通过浏览器访问,也可以通过定制的客户端进行访问. 一.安装篇 1.下载安 ...

随机推荐

  1. JavaScript实现八大内部排序算法

    注:基数排序中:r是关键字的基数,d是长度,n是关键字的个数 1.插入排序 基本思想:在序号i之前的元素(0到i-1)已经排好序,本趟需要找到i对应的元素x (此时即arr[i]) 的正确位置k,在寻 ...

  2. TextMesh Pro Emoji Align With Text(表情和文字对齐)

    前言 MMO游戏中需要富文件组件,大体功能包括图文混排,表情,超链接,文字动画等富文本功能,且DC数占用少. 本文选择Unity免费提供的TextMesh Pro 解决方案. 软件环境 Unity3D ...

  3. ESL翻译:Linear Methods for Regression

    chapter 3: Linear Methods for Regression 第3章:回归的线性方法 3.1 Introduction A linear regression model assu ...

  4. 1. 生成三行文本,过滤文本,cp不覆盖,find查找文件,sed打印行,查看系统信息,磁盘分区

  5. 【MySQL】查看支持的字符集show character set;

  6. Solr集群搭建详细教程(二)

    注:欢迎大家转载,非商业用途请在醒目位置注明本文链接和作者名dijia478,商业用途请联系本人dijia478@163.com. 之前步骤:Solr集群搭建详细教程(一) 三.solr集群搭建 注意 ...

  7. springboot swagger-ui结合

    随着移动互联的发展,前后端的分离已经是趋势.前后端已不是传统部门的划分,而是它们各有一套的生态系统,包括不同的开发语言.不同的开发流程.构建方式.测试流程等.做前端的不需要会maven作为构建工具,后 ...

  8. JavaWeb之ssm框架整合,用户角色权限管理

    SSM框架整合 Spring SpringMVC MyBatis 导包: 1, spring 2, MyBatis 3, mybatis-spring 4, fastjson 5, aspectwea ...

  9. 零基础学习webpack打包管理

    这些天在项目之余的时间学习了webpack打包项目的东西,非常荣幸的找到一些大神的文章来学习,死劲嚼了几天,终于略知一二.在以后的工作上还需继续学习,下面我将分享我这几天学到的一点东西,希望能让我一个 ...

  10. 每周.NET前沿技术文章摘要(2017-06-07)

    汇总国外.NET社区相关文章,覆盖.NET ,ASP.NET等内容: .NET .NET Core and .NET Framework Working Together, Or: The Magic ...