服务器Centos系统下部署Django应用

 

1.安装数据库

yum install mysql-devel
pip install mysqlclient

2.安装Django,uwsgi

pip install Django
pip install uwsgi

3.安装virtualenv ,建议大家都安装一个virtualenv,方便不同版本项目管理。

pip install virtualenv

建立virtualenv软链接

ln -s /usr/local/lib/python3.6/site-packages/virtualenv  /usr/bin/virtualenv

在根目录建立存放env和网站的文件夹------个人习惯

mkdir -p /data/env
mkdir -p /data/wwwroot

4.创建指定版本的python虚拟环境

virtualenv --python=/usr/bin/python pyweb

切换到 /data/env/pyweb/bin/,启动虚拟环境

source  activate

注意左下角的pyweb,说明启动成功了

##进入虚拟机的方式:

cd pyweb #pyweb虚拟机名字
source ./bin/activate #启动

退出虚拟机方式:

deactivate

5.在虚拟环境里安装django和uwsgi

pip install django (如果用于生产的话,则需要指定安装和你项目相同的版本)
pip install uwsgi

留意:uwsgi要安装两次,先在系统里安装一次,然后进入对应的虚拟环境安装一次。

给uwsgi建立软链接,方便使用

ln -s /usr/local/lib/python3.6/site-packages/uwsgi /usr/bin/uwsgi

6.###建项目练练手

切换到网站目录/data/wwwroot,创建Django项目

django-admin.py startproject mysite

然后新建立一个名叫blog的APP

python3 manage.py startapp blog

然后问题来了,Django2.2以上针对Sqlite3最低版本是3.8,而一般电脑默认3.7

a.下载

# 下载
$ wget http://www.sqlite.org/2019/sqlite-autoconf-3280000.tar.gz

# 解包
$ tar -zxvf sqlite-autoconf-3280000.tar.gz

# 进入目录
$ cd sqlite-autoconf-3280000

# 配置 
$ ./configure 

# 编译
$ make 
$ make install

b.备份


# 备份默认的sqlite
$ sudo mv -v /usr/bin/sqlite3 /usr/bin/sqlite3.7.17

"/usr/bin/sqlite3" -> "/usr/bin/sqlite3.7.17"

# 复制新版本的sqlite文件夹
# 此时目录 sqlite-autoconf-3280000
$ sudo cp -v sqlite3 /usr/bin 

"sqlite3" -> "/usr/bin/sqlite3"

# 查看一下文件是否成功
$ ls /usr/bin |grep sqlite

sqlite3
sqlite3.7.17

# 共享库
$ export LD_LIBRARY_PATH="/usr/local/lib"
# 如果登出后失效的,可以写进~/.bashrc 或 ~/.bash_profile

c.检查

# 版本查看
$ sqlite3 --version
3.28.0 2019-04-16 19:49:53 884b4b7e502b4e991677b53971277adfaf0a04a284f8e483e2553d0f83156b50

重新输入

python manage.py  startapp blog

成功了

自行建项目测试

7.Django正常运行之后我们就开始配置一下uwsgi

我们网站项目路径是 /data/wwwroot/mysite/,在项目根目录下创建
mysite.xml文件,输入如下内容:






<uwsgi>
   <socket>127.0.0.1: 8997 </socket> <!-- 内部端口,自定义 --> 
   <chdir>/data/wwwroot/mysite/</chdir> <!-- 项目路径 -->
   <module>mysite.wsgi</module>  <!-- mysite为wsgi.py所在目录名--> 
   <processes>4</processes> <!-- 进程数 -->     
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>

注意<module>里的mysite,为wsgi.py所在的目录名。

8.安装nginx和配置nginx.conf文件

cd /home/
wget http://nginx.org/download/nginx-1.13.7.tar.gz
tar -zxvf nginx-1.13.7.tar.gz
./configure
make
make install

nginx一般默认安装好的路径为/usr/local/nginx
在/usr/local/nginx/conf/中先备份一下nginx.conf文件,以防意外。

cp nginx.conf nginx.conf.bak

然后打开nginx.conf,把原来的内容删除,直接加入以下内容:

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 80;
        server_name  www.lian.cn; #改为自己的域名,没域名修改为127.0.0.1:80
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1: 8997;  #端口要和uwsgi里配置的一样
           uwsgi_param UWSGI_SCRIPT mysite.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /data/wwwroot/mysite/; #项目路径
           
        }
        location /static/ {
        alias /data/wwwroot/mysite/static/; #静态资源路径
        }
    }
}

要留意备注的地方,要和UWSGI配置文件mysite.xml,还有项目路径对应上。 
进入/usr/local/nginx/sbin/目录
执行./nginx -t命令先检查配置文件是否有错,没有错就执行以下命令:

./nginx

 若出现端口被占用的情况:

nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)

解决方案:使用netstat -ntpl查看端口被哪个占用了,使用kill杀死进程

终端没有任何提示就证明nginx启动成功。可以使用你的服务器地址查看,成功之后就会看到一个nginx欢迎页面。

 

在settings.py里设置:

a.、关闭DEBUG模式。

DEBUG = False  

b.、ALLOWED_HOSTS设置为* 表示任何IP都可以访问网站。

ALLOWED_HOSTS = ['*']

9.访问项目的页面。
进入网站项目目录

cd /data/wwwroot/mysite/
执行下面命令:
uwsgi -x mysite.xml
以上步骤都没有出错的话。
进入/usr/local/nginx/sbin/目录
执行:
./nginx -s reload

重启nginx 。
然后在浏览器里访问你的项目地址!

 

留意:一定要注意Uwsgi和Nginx配置文件里的项目路径和静态资源路径,填写正确了才能成功访问。不然会出现502错误。还有就是,修改Django文件和其它配置文件之后,一定要重启Uwsgi和Nginx,不然不生效。

Uwsgi和Nginx重启方法:

#查看Uwsgi进程
ps -ef|grep uwsgi 
#用kill方法把uwsgi进程杀死,然后启动uwsgi
killall -9 uwsgi
#启动方法
uwsgi -x mysite.xml

#Nginx平滑重启方法
/usr/local/nginx/sbin/nginx -s reload

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值