day24_雷神_django项目部署

django项目部署


...

curl -I www.baidu.com  得到响应头信息

vim 里shift + % 找括号的另一半

find / -name virtualenv

3.创建虚拟主机定义的网页根目录
mkdir -p /opt/static/{mytb,myjd}

nginx安装

1.dns解析流程

1.你要输入域名  pythonav.cn
2.你的机器首先在/etc/hosts文件中查找解析记录
3.会去本地dns缓存中查找记录,LDNS
4.就去/etc/resolv.conf去找到指定的公网dns服务器
5.假设你dns服务器是119.29.29.29
通过119.29.29.29找到对应的记录
pythonav.cn 123.206.16.61
6.找到记录后,机器会将此记录,缓存到LDNS中,用于下次加速解析
7.浏览器访问对应的ip ,123.206.16.61,发起http请求

nginx安装配置:

之前装的nginx要不要删
yum install nginx -y
systemctl start nginx
他会配置环境变量
/usr/local/bin/nginx 这个快捷启动命令
很可能扰乱你编译nginx的使用
因此
yum remove nginx -y

1.解决软件依赖

yum install gcc patch libffi-devel python-devel  zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel openssl openssl-devel -y

1.下载源码包

wget -c https://nginx.org/download/nginx-1.12.0.tar.gz --no-check-certificate

2.解压缩源码

tar -zxvf nginx-1.12.0.tar.gz

切换进入nginx目录

cd  nginx-1.12.0

3.配置,编译安装

./configure --prefix=/opt/nginx1-12/   #这里不会生成文件夹

make && make install    #此步结束,才会正式创建/opt/nginx1-12文件夹

4.启动nginx,进入sbin目录,找到nginx启动命令

cd /opt/nginx1-12  #进入nginx主目录,所有东西都在这了
#进入可执行命令目录
cd sbin #里面有一个nginx脚本 ./nginx #启动 ,检查端口和进程 ./nginx -s stop #关闭 ./nginx -s reload #重新加载ngix配置文件,不重启nginx ,提前,你的nginx必须得启动 ./nginx -t #检测nginx.conf语法是否正确 nginx博客
https://www.cnblogs.com/pyyu/p/9468680.html/

安装python

编码编译安装python3

1.解决依赖关系

yum install gcc patch libffi-devel python-devel  zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel -y

2.下载python源代码

yum install wget -y
cd /opt/
wget https://www.python.org/ftp/python/3.4.7/Python-3.4.7.tar.xz

3.解压缩python源代码

xz -d Python-3.4.7.tar.xz
tar -xf Python-3.4.7.tar

4.切换进入python源代码目录

cd /opt/Python-3.4.7

5.开始编译安装,释放编译文件

./configure --prefix=/opt/python347/    #此时还不会生成这个文件夹!

6.开始编译,编译安装

make
make install #直到这两步走完,才会生成。创建 /opt/python347/ ./configure是用来检测你的安装平台的目标特征的。比如它会检测你是不是有CC或GCC,并不是需要CC或GCC,它是个shell脚本。
#这个confiure脚本执行后,会生成一个Makefile文件 make是用来编译的,它从Makefile中读取指令,然后编译。 make install是用来安装的,它也从Makefile中读取指令,安装到指定的位置。 然后这两句可以一局就执行成功 make && make install

7.检查你自己制定的安装路径,/opt/python347/

查看/opt/python347/bin目录,python3的可执行命令都在bin底下了

8.配置软连接,快捷启动python3和pip3

ln -s /opt/python347/bin/python3    /usr/bin/python3
ln -s /opt/python347/bin/pip3 /usr/bin/pip3

9.配置系统环境变量,配置PATH,加入python3的目录

#尽量用这一步
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/opt/python347/bin/
#这一步尽量别用了
PATH=$PATH:/opt/python347/bin/ #配置环境变量需谨慎,如果配错了,你的其他命令也会丢失! 写入个人配置文件,永久生效/etc/profile
yum install vim -y
vim /etc/profile #编辑个人配置文件,写入PATH
PATH=$PATH:/opt/python347/bin/ source /etc/profile #读取一下配置文件,生效配置

安装启动django

创建django项目

pip3 install django==1.11.14

django-admin startproject mysite

#修改django  settings.py配置文件
ALLOWED_HOSTS = ['*']
#启动django python3 manage.py runserver 0.0.0.0:9000

可能出现的问题

网页访问不到
解决办法: iptables -F
setenforce 0
关闭防火墙 不要用win8 win10自带的浏览器
用chrome

提示命令pip找不到

pip install --upgrade pip

但是你系统现在是pip3
执行这条:
pip3 install --upgrade pip

Python环境安装之virtualenv虚拟环境

安装virtualenv:

#通过pip3安装
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv
#创建虚拟环境 venv
virtualenv --no-site-packages --python=python3 venv
#激活虚拟环境,进入虚拟环境!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!()
重点,这个虚拟环境不是什么虚拟的linux,只是复制了一份python解释器!
#激活虚拟环境
source /data/mydjango1.11.15/venv/bin/activate
#此时你的环境变量,已经被修改,添加了虚拟环境
可以查看echo $PATH #安装django1.11.15
pip3 install django==1.11.15 django-admin startproject mysite115
启动django1.11.15

确保开发环境一致性的操作

1.假设我们在本地开发环境,准备好了项目+依赖包环境
2.现在需要将项目上传至服务器,上线发布
3.那么就要保证服务器的python环境一致性
复制代码
解决方案:
1.通过命令保证环境的一致性,导出当前python环境的包
pip3 freeze > requirements.txt 这将会创建一个 requirements.txt 文件,其中包含了当前环境中所有包及 各自的版本的简单列表。
可以使用 “pip list”在不产生requirements文件的情况下, 查看已安装包的列表。 2.上传至服务器后,在服务器下创建virtualenv,在venv中导入项目所需的模块依赖
pip3 install -r requirements.txt

虚拟环境之virtualenvwrapper

虚拟环境的强大,我们已经知道,可以隔绝多个python解释器环境,但是他的弊端也很多

基本使用virtualenvwrapper,管理virtualenv

创建一个虚拟环境,默认会激活当前这个虚拟环境
mkvirtualenv my_django115 再创建一个虚拟环境,默认切换进入my_django2的虚拟环境
mkvirtualenv my_django2 #任意切换不同的虚拟环境,workon提供tab补全功能,非常方便 workon my_django115 workon my_django2
这个命令非常方便的用法就是,在物理环境下,快速进入虚拟环境 当然也可以手动停止虚拟环境
deactivate 其他virtualenvwrapper管理命令
删除虚拟环境,需要先退出虚拟环境
rmvirtualenv my_django115 复制代码
lsvirtualenv
列举所有的环境。
cdvirtualenv
导航到当前激活的虚拟环境的目录中,比如说这样您就能够浏览它的 site-packages 。
cdsitepackages
和上面的类似,但是是直接进入到 site-packages 目录中。
lssitepackages
显示 site-packages 目录中的内容。

nginx + uwsgi + django + supervisor 上线发布django

要记得关防火墙、selinux。一定。

python虚拟环境

1.准备好python3环境,以及虚拟环境virtualenvwrapper
2.创建新的虚拟环境
mkvirtualenv django15
3.安装django1.11.15
pip3 install django==1.11.15
4.创建django项目,测试访问
python3 manage.py runserver 0.0.0.0:8000

安装uwsgi

进入虚拟环境venv,安装uwsgi
1.pip3 install -i https://pypi.douban.com/simple uwsgi pip3 list 查看 uwsgi --version 检查uwsgi版本
uwsgi --python-version #检查uwsgi python版本

通过uwsgi运行django

进入项目第一层目录,可以看到manage.py

启动命令:
uwsgi --http :8088 --module mysite.wsgi --py-autoreload=1
# mysite 是跟项目同名的文件夹,下面有wsgi.py这个文件
# 问题: 样式丢了

配置nginx,使得请求正确过来

nginx端两条配置:

server {
listen 80;
server_name www.s12django.com; #charset koi8-r; #access_log logs/host.access.log main; location / {
include /opt/nginx1-12/conf/uwsgi_params;
uwsgi_pass 0.0.0.0:8000;
# root html;
# index index.html index.htm;
}

启动命令:

uwsgi --socket :8000 --module django15.wsgi --py-autoreload=1

配置nginx,解决静态文件

nginx配置添加字段:

location /static {
alias /opt/static/django;
}

创建目录:

mkdir -p  /opt/static/django/

在django的settings里面配置:

STATIC_URL = '/static/'
STATIC_ROOT='/opt/static/django'

通过python3 manage.py collectstatic 收集所有你使用的静态文件保存到STATIC_ROOT!

python3 manage.py collectstatic 

STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用nginx等部署的时候更方便

重启nginx,重启服务,静态文件恢复正常

uwsgi配置文件启动

这个文件放哪里都可以

touch uwsgi.ini

[uwsgi]
#使用nginx连接时使用
socket=0.0.0.0:8000
#不用nginx直接当做web服务器使用
#http=0.0.0.0:9000
#项目目录绝对路径
chdir=/root/django15
#wsgi文件路径,在项目底下
wsgi-file=django15/wsgi.py
#指定解释器目录,虚拟环境目录
home=/root/Envs/my_django115
processes=4
threads=2
master=True
pidfile=uwsgi.pid

启动命令:

uwsgi --ini uwsgi.ini # 在uwsgi.ini的目录中

supervisor

#注意此时已经退出虚拟环境了!!!!!

yum install python-setuptools -y
easy_install supervisor

通过命令生成supervisor的配支文件

echo_supervisord_conf > /etc/supervisord.conf

编辑配置文件,添加字段

[program:my_django115]
command=/root/Envs/my_django115/bin/uwsgi --ini /root/django15/uwsgi.ini

启动命令:

supervisord -c /etc/supervisord.conf

交互式界面:

supervisorctl
start my_django115
上一篇:[php基础]PHP.INI配置:Session配置详细说明教程


下一篇:day19_雷神_django第二天