day28-项目部署
django部署
redis缓存
上线项目debug要改为False
nginx转发uwsgi及静态资源(css、js等样式加载)
问题:---通过重装centos解决!!
1.解决依赖语句,报错
2.pip3 提示无此命令
虚拟机用户名:
root
root1234
virtualenv python中的一个模块
pip3 list查看安装的pip列表
which pip3 查看pip3的路径
lsvirtualenv查看 virtualenv项目
在pycharm中使用虚拟环境:
settings,Project Interpreter---小齿轮---Add Local---Virtualenv Environment
新建虚拟环境:mkvirtualenv nginx_uwsgi
马上:pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple uwsgi
uwsgi
启动项目:
cd mysite
uwsgi --http :9999 --module mysite.wsgi
nginx:简单的cs。
touch nginx.ini
vim nginx.ini
指定配置文件启动命令
uwsgi --ini /etc/nginx.ini
supervisor:任务管理工具

supervisor 1.不再通过命令行的方式,启动项目,通过ps -ef kill 2.进行进程管理(python ,mysql,redis,nginx) 3.通过supervisr统一化管理linux进程 4.检测到你服务挂了,自动重启 安装配置supervisor 1.通过easy_install安装 #注意此时已经退出虚拟环境了!!!!! yum install python-setuptools easy_install supervisor 2.通过命令生成supervisor的配支文件 echo_supervisord_conf > /etc/supervisord.conf 3.在配置文件中,添加任务,管理django项目 vim /etc/supervisord.conf #写入信息 [program:s21_django] #管理uwsgi的命令, 使用绝对路径 command=/root/Envs/nginx_uwsgi/bin/uwsgi --ini /home/mysite/uwsgi.ini #检测项目是否挂掉,自动重启 autorestart=true 4.启动supervisord supervisord -c supervisord.conf 5.管理supervisor的命令 一、添加好配置文件后 二、更新新的配置到supervisord supervisorctl update 三、重新启动配置中的所有程序 supervisorctl reload 四、启动某个进程(program_name=你配置中写的程序名称) supervisorctl start program_name 五、查看正在守候的进程 supervisorctl 六、停止某一进程 (program_name=你配置中写的程序名称) pervisorctl stop program_name 七、重启某一进程 (program_name=你配置中写的程序名称) supervisorctl restart program_name 八、停止全部进程 supervisorctl stop all 注意:显示用stop停止掉的进程,用reload或者update都不会自动重启。 环境初始化: 关闭防火墙 systemctl stop firewalld iptables -F setenforce 0 #系统自带防火墙也给关了 项目发布博客地址: https://www.cnblogs.com/pyyu/p/9481344.html
总结:
1.准备linux环境,安装虚拟机,准备服务器环境;
安装python3,注意添加环境变量

编译安装python3 解决依赖 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 1.下载python3源码包 wget https://www.python.org/ftp/python/3.4.7/Python-3.4.7.tar.xz xz -d Python-3.4.7.tar.xz tar -xf Python-3.4.7.tar 2.进入python3源码包路径,开始编译安装 ./configure --prefix=/opt/python3/ #生成一个makefile文件 make make install 结束后,完成编译安装 3.配置python3可执行命令,快捷方式 #linux添加python3的环境变量 #第一种方式 ln -s /opt/python3/bin/python3 /usr/bin/python3 #第二种方式,写入到/etc/profile中,这一步非常重要 base prefix 基本路径 export PATH=/opt/python3/bin/:$PATH source /etc/profile 使得配置文件生效 可以用echo $PATH 查看,python3放在环境变量中! 4.测试直接输入 python3,能否进入python
2.准备项目,上传到服务器;
安装一个远程传输软件 lrzsz
yum install lrzsz -y
sz #send 传输文件
rz #接受文件 选择文件路径;或者直接拖拽文件
3.unzip 解压zip包
4.进入到项目目录,修改settings
allow_host=['*']
5.创建virtualenv 1-3

virtualenv https://www.cnblogs.com/pyyu/p/9015317.html 问题比较多,不容易管理 1.下载virtualenv pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple virtualenv 2.通过命令创建虚拟环境venv #确保环境干净隔离,与宿主及解释器隔离开 --no-site-packages virtualenv --no-site-packages --python=python3 venv 3.检查环境变量,确认已经进入venv虚拟环境中 source venv/bin/activate-------------------------------------------- echo $PATH #打印环境变量 4.测试安装两个不同版本的django环境 1.在系统解释器下---宿主机环境下(linux操作系统root开头下) pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple django==1.11.15 2.在虚拟环境venv中(linux操作系统venv开头下) pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple django==1.11.12 5.可以测试在两个解释器中,运行不同的任务 6.退出虚拟环境 deactivate命令 保证开发/测试环境一致性 1.通过命令导入项目依赖(可以在宿主机上执行) pip3 freeze > requirements.txt 2.传输此requirements.txt 文件到服务器环境,通过命令直接安装 pip3 install -r requirements.txt
virtualenvwrapper 安装

virtualenvwrapper (和virtualenv二选一) 为了解决虚拟环境难以管理的问题,并且容易使用 1.安装 pip3 install virtualenvwrapper 2.配置环境变量,使得每次登陆就启动virtualenvwrapper 写入到 ~/.bashrc 文件中, vim ~/.bashrc export WORKON_HOME=~/Envs #设置virtualenv的统一管理目录 export VIRTUALENVWRAPPER_VIRTUALENV_ARGS='--no-site-packages' #添加virtualenvwrapper的参数,生成干净隔绝的环境 export VIRTUALENVWRAPPER_PYTHON=/opt/python3/bin/python3 #指定宿主机python3解释器绝对路径 source /opt/python3/bin/virtualenvwrapper.sh #执行virtualenvwrapper安装脚本 3.使得脚本生效,重新登录一次 logout 在重新登录的时候,加载virtualenvwrapper脚本 4.使用virtualenvwrapper常用命令 创建一个虚拟环境:(在哪儿输入无所谓,因为有统一目录WORKON_HOME,可以通过echo $WORKON_HOME查看) $ mkvirtualenv my_django115 这会在 ~/Envs 中创建 my_django115 文件夹。(创建后自动激活) 在虚拟环境上工作:激活虚拟环境my_django115 $ workon my_django115-------------------------------------------------------- 再创建一个新的虚拟环境 $ mkvirtualenv my_django2 virtualenvwrapper 提供环境名字的tab补全功能。 当有很多环境, 并且很难记住它们的名字时,这就显得很有用。 workon还可以任意停止你当前的环境,可以在多个虚拟环境中来回切换 workon my_django115 workon my_django2.0 也可以手动停止虚拟环境 deactivate 删除虚拟环境,需要先退出虚拟环境 rmvirtualenv my_django115
创建一个虚拟环境:mkvirtualenv s21crm
cdvirtualenv 查看pwd为/root/Envs/s21crm,此时环境为我们所用
6.安装django

django 准备一个django项目文件夹,配置好外网访问 修改settings.py allow_host=['*'] 修改数据库驱动---用mysql数据库需要修改以下内容! DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } pip3 install pymysql __init__.py 文件中添加数据库驱动 import pymysql pymysql.install()
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple django==1.11.11
测试运行: python3 manage.py runserver 0.0.0.0:7000
此时输入ip:7000就可以访问界面啦!用户名lijie 密码123
注:修改数据库驱动---用mysql数据库需要修改以下内容!
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
注意virtualenvwrapper配置环境变量
7.优化:
用uwsgi 支持多进程,高并发

uwsgi django默认启动 python manager.py runserver 它调用wsgiref单机web服务器模块,性能很差 在线上启动django项目,选择的是uWSGI + django,使用多进程高性能的web服务器运行,支持并发性更好 重点标记: django创建时,会产生wsgi.py文件 mysite/mysite/wsgi.py #wsgi.py产生的application应用---------(没有项目就无法启动!!提示“Internal Server Error”) application = get_wsgi_application() 可能出现的坑: 1. no application xxxxxx 这个问题就是说,你指定的wsgi.py文件不正确 新建虚拟环境:mkvirtualenv nginx_uwsgi 1.安装uwsgi pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple uwsgi 2.通过uwsgi启动一个python web文件 1.test.py def application(env, start_response): start_response('200 OK', [('Content-Type','text/html')]) return [b"Hello World"] # python3 2.通过命令启动 uwsgi --http :9000 --wsgi-file test.py 3.启动后可以浏览器 ip:9000 访问django程序 3.通过uwsgi启动一个python django项目 1.准备django项目,编写urls、views.py ,修改settings.py 2.通过命令启动 django , 要点就是,必须先进入django的第一层目录,然后通过相对路径找到wsgi.py cd mysite uwsgi --http :9999 --module mysite.wsgi
在项目中 安装uwsgi:pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple uwsgi
安装成功后,在项目路径下/opt/s21crm - all执行 uwsgi --http :8000 --module s21crm.wsgi
必须先进入django的第一层目录
在浏览器中访问发现静态文件丢失,无css样式,所以用到nginx
7.2安装nginx,

nginx 1.因为nginx处理并发的良好性、 2.nginx对静态文件处理的良好性 备注:因为uwsgi启动django项目,不会读取一个静态文件的配置参数 3.nginx负载均衡的一个作用 安装配置nginx 1.yum install nginx -y yum install epel-* -y #需要提前备好epel源 #检测nginx是否安装成功 rpm -qi nginx 2.启动nginx web服务器 /usr/sbin/nginx 启动nginx web服务 3.配置nginx.conf配置反向代理uwsgi,以及静态资源处理 如果找不到nginx.conf ,通过命令查找 find / -name nginx.conf 结果: /etc/nginx/nginx.conf location / { include /etc/nginx/uwsgi_params; uwsgi_pass 0.0.0.0:8000; } #静态资源入口 location /static { alias /opt/static/; } } 4.修改完,重启nginx /usr/bin/nginx -s reload 配置项目的静态文件资源,通过nginx加载 1.修改django的setings.py文件 s21crm/settings.py 加入以下信息 #指定静态文件存放路径 STATIC_ROOT='/opt/static' #指定静态资源,请求入口 STATIC_URL = '/static/' STATICFILES_DIRS=[ os.path.join(BASE_DIR,"static"), ] 2.通过命令收集静态文件资源 python3 manage.py collectstatic 收集所有你使用的静态文件保存到STATIC_ROOT! 3.此时static_root下有了所有项目的静态资源
检测是否安装成功 rpm -qi nginx ;
启动nginx: /usr/sbin/nginx
启动报错???nginx: [emerg] "location" directive is not allowed here in /etc/nginx/nginx.conf:58
编辑配置文件:/etc/nginx/nginx.conf
创建、编辑uwsgi.ini,注意修改工作目录、module和home
uwsgi --ini uwsgi.ini 启动配置文件,此时项目就可以访问啦!!--??提示页面找不到?
settings中静态文件的修改
创建static目录 mkdir static
所有静态文件放入opt/static下执行:python3 manage.py collectstatic 选择-- yes
可通过ls /opt/static/rbac/查看是否拷贝成功,存在静态文件,,再次访问界面存在样式!
nginx+uwsgi完成项目发布!