1.确认项目没有bug。
2.用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中,方便在部署的时候安装。
3.将项目上传到服务器上的/srv目录下。这里以git的形式为例,打开终端,依次输入如下命令 •git init
•git remote add origin xxx.git
•git add .
•git commit -m 'first commit'
•git pull origin master --allow-unrelated-histories
•git push origin master
1.安装好项目用到的Python。
•sudo apt install python
•sudo apt install python-pip
•pip install --upgrade pip
2.安装virtualenv以及virutalenvwrapper,并创建虚拟环境。
•pip install virtualenv
•pip install virtualenvwrapper
•sudo apt install vim
•vim ~/.bashrc 进入文件中,填入以下两行代码:
export WORKON_HOME=$HOME/.virtualenvssource /usr/local/bin/virtualenvwrapper.sh
•source ~/.bashrc
sudo apt install git
4.为了方便XShell或者CRT连接服务器,建议安装OpenSSH:
sudo apt install openssh-server openssh-clientservice ssh restart
5.安装MySQL服务器和客户端:
sudo apt install mysql-server mysql-clientsudo apt-get install libmysqld-dev
6.进入虚拟环境中,然后进入到项目所在目录,执行命令:pip install -r requirements.txt
,安装好相应的包。
7.在mysql数据库中,创建相应的数据库。
8.执行python manage.py migrate
命令,将迁移文件,映射到数据库中,创建相应的表。
9.执行python manage.py runserver 0.0.0.0:8000
,然后在你自己电脑上,在浏览器中输入http://你的服务器的ip地址:8000/,访问下网站所有页 面,确保所有页面都没有错误。
10.设置ALLOW_HOST为你的域名,以及ip地址。
11.设置DEBUG=False,避免如果你的网站产生错误,而将错误信息暴漏给用户。
12.收集静态文件:python manage.py collectstatic。
1.uwsgi是一个应用服务器,非静态文件的网络请求就必须通过他完成,他也可以充当静态文件服务器,但不是他的强项。uwsgi是使用python编写的,因此通过pip install uwsgi就可以了。(uwsgi必须安装在系统级别的Python环境中,不要安装到虚拟环境中)。
2.使用命令uwsgi --http :8000 --module test.wsgi --vritualenv=/root/.virtualenvs/django-env-py36
。用uwsgi启动项目,如果能够在浏览器中访问到这个页面,说明uwsgi可以加载项目了。
在项目的路径下面,创建一个文件叫做djangotest.ini的文件,然后填写以下代码:
[uwsgi]# Django相关的配置# 必须全部为绝对路径# 项目的路径chdir=/srv/djangotest# Django的wsgi文件module=djangotest.wsgi# Python虚拟环境的路径home=/root/.virtualenvs/django-env-py36# 进程相关的设置# 主进程master=true# 最大数量的工作进程processes=10# socket文件路径,绝对路径socket=/srv/djangotest/djangotest.sock# 设置socket的权限chmod-socket=666# 退出的时候是否清理环境vacuum=true
然后使用命令uwsgi --ini djangotest.ini
,看下是否还能启动这个项目。
1.nginx是一个web服务器。用来加载静态文件和接收http请求的。通过命令sudo apt install nginx即可安装。
2.nginx常用命令:
•启动nginx:service nginx start
•关闭nginx:service nginx stop
•重启nginx:service nginx restart
静态文件应该让nginx来服务,而不是让django来做。首先确保你的settings.py文件中有一个STATIC_ROOT配置,这个配置应该指定你的静态文件要放在哪个目录下。那么我们可以执行以下命令:python manage.py collectstatic来收集所有静态文件,将这些静态文件放在指定的目录下。
在/etc/nginx/conf.d目录下,新建一个文件,叫做djangotest.conf,然后将以下代码粘贴进去:
upstream djangotest { server unix:///srv/djangotest/djangotest.sock; }# 配置服务器server { # 监听的端口号 listen 80; # 域名 server_name 192.168.0.101; charset utf-8; # 最大的文件上传尺寸 client_max_body_size 75M; # 静态文件访问的url location /static { # 静态文件地址 alias /srv/djangotest/static_dist; } # 最后,发送所有非静态文件请求到django服务器 location / { uwsgi_pass djangotest; # uwsgi_params文件地址 include /etc/nginx/uwsgi_params; }}
写完配置文件后,为了测试配置文件是否设置成功,运行命令:service nginx configtest,如果不报错,说明成功。每次修改完了配置文件,都要记得运行service nginx restart。
让supervisor管理uwsgi,可以在uwsgi发生意外的情况下,会自动的重启。
1.supervisor的安装:在系统级别的python环境下pip install supervisor
。
2.在项目的根目录下创建一个文件叫做my_supervisor.conf。内容如下:
# supervisor的程序名字[program:mysite]# supervisor执行的命令command=uwsgi --ini zlkt_uwsgi.ini# 项目的目录directory = /srv/djangotest # 开始的时候等待多少秒startsecs=0# 停止的时候等待多少秒stopwaitsecs=0 # 自动开始autostart=true# 程序挂了后自动重启autorestart=true# 输出的log文件stdout_logfile=/srv/djangotest/log/supervisord.log# 输出的错误文件stderr_logfile=/srv/djangotest/log/supervisord.err[supervisord]# log的级别loglevel=info# 使用supervisorctl的配置[supervisorctl]# 使用supervisorctl登录的地址和端口号serverurl = http://127.0.0.1:9001# 登录supervisorctl的用户名和密码username = adminpassword = 123[inet_http_server]# supervisor的服务器port = :9001# 用户名和密码username = adminpassword = 123[rpcinterface:supervisor]supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
然后使用命令supervisord -c my_supervisor.conf
运行就可以了。 以后如果想要启动uwsgi,就可以通过命令supervisorctl -c my_supervisor.conf
进入到管理控制台,然后可以执行相关的命令进行管理:
# 查看状态status # 启动程序start program_name# 重新启动程序restart program_name# 关闭程序stop program_name# 重新加载配置文件reload# 退出控制台quit
总结
以上所述是小编给大家介绍的Ubuntu系统搭建django+nginx+uwsgi的教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对武林网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
新闻热点
疑难解答
图片精选