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