dapi 基于Django的轻量级测试平台七 怎样部署到生产环境
QQ群:
GitHub:https://github.com/yjlch1016/dapi
Nginx+uWSGI
前置条件:
以下所有操作均在root账号下面进行
如果不是root用户
请注意权限问题
因为是自己搭的服务器
所以无所谓安全问题
如果是公司的服务器
请不要使用root账号
一、安装uWSGI服务器:
当我们在本地运行Django时
一般是python manage.py runserver
但是在服务器上面是结合uWSGI
pip install uwsgi
安装uWSGI
uWSGI是Python的Web服务器
类似于Java的Tomcat
find / -name uwsgi
找到uwsgi的执行位置
ln -s /usr/local/python/bin/uwsgi /usr/bin/uwsgi
创建软连接
pip install uwsgitop
安装uWSGI性能监控库
类似于top命令
find / -name uwsgitop
找到uwsgitop的执行位置
ln -s /usr/local/python/bin/uwsgitop /usr/bin/uwsgitop
创建软连接
uwsgi.ini文件:
[uwsgi]
socket = 127.0.0.1:3031
# Socket套接字 chdir = /django/dapi
# 工程的绝对路径
wsgi-file = dapi/wsgi.py
# wsgi.py的相对路径 master = true
# 启用主进程
processes = 4
# 4个线程,每个进程有2个线程
threads = 2
# 2个进程
# uWSGI默认单个进程和单个线程 uid = root
gid = root
# 启动uwsgi的用户名和用户组 buffer-size = 65535
# 内部缓存区大小为64k,默认4k
max-requests = 65535
# 每个进程的最大请求数 stats = 127.0.0.1:9191
# stats子系统将uWSGI的内部统计信息导出为JSON
memory-report = true
# 开启内存使用情况报告 pidfile = %(chdir)/uwsgi.pid
# pid vacuum = true
# 当服务停止的时候,自动清理Unix Socket和pid文件 #logto = %(chdir)/uwsgi.log
daemonize = %(chdir)/uwsgi.log
# 使进程在后台运行,并将日志打到指定的日志文件
二、上传代码:
因为本次是演示
所以直接把代码上传到服务器上面了
在实际的生活中
请按照规范流程git push到仓库
不然要被打shi
mkdir /django
在根目录下面创建django目录
把dapi工程代码上传到此目录下面
如果之前运行过并且上传过文件
把/dapi/media/jmeter目录删掉
以免占磁盘空间
如果没有
则不用管
chmod -R 777 /django
赋予此目录及其所有的子目录最高读写权限
cd /django/dapi
进入dapi工程根目录
pip install https://codeload.github.com/sshwsfc/xadmin/zip/django2
安装适配Django2.0以后版本的xadmin
pip install -r requirements.txt
安装工程所需的依赖
修改dapi/settings.py配置文件
把DEBUG = True改为
DEBUG = False
把ALLOWED_HOSTS = []改为
ALLOWED_HOSTS = ["*"]
或者指定的IP列表
ALLOWED_HOSTS = ["IP1", "IP2", "IP3"]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'dapi',
'HOST': '192.168.1.111',
'PORT': '3306',
'USER': 'root',
'PASSWORD': 'Abcdef@123456',
}
}
# MySQL数据库
CELERY_BROKER_URL = 'redis://:Abcdef@123456@192.168.1.111:6379/0'
# redis://:password@hostname:port/db_number
CELERY_BROKER_TRANSPORT = 'redis'
# 使用redis作为中间件
三、迁移MySQL数据库:
新建dapi库
PyMySQL年久失修,
对Django2.0以后的版本支持不是很好
有2个小BUG
vim /usr/local/python/lib/python3.6/site-packages/django/db/backends/mysql/base.py
把第35~36行注释掉
vim /usr/local/python/lib/python3.6/site-packages/django/db/backends/mysql/operations.py
把第145~146行注释掉
请注意:
迁移之前要把/dapi/interface/migrations目录下面除了__init__.py以外的所有文件都删掉
如果之前没有运行过
则不用管
python manage.py makemigrations
激活模型
报错:
django.db.utils.ProgrammingError: (1146, "Table 'dapi.product_info' doesn't exist")
分析了一下原因:
mysql服务已经启动了
IP、端口、账号与密码都是对的呀
现在是直接连接本机的mysql
不存在root远程访问的问题
况且在安装mysql时已经打开了root账号的远程访问权限
继续往上找:
(找跟dapi工程相关的报错信息,而不是找Python源码相关的报错信息)
File "/django/dapi/dapi/urls.py", line 136, in <module>
url('^pyecharts/', include('interface.urls')),
File "/django/dapi/interface/urls.py", line 3, in <module>
from interface import pyecharts
File "/django/dapi/interface/pyecharts.py", line 45, in <module>
product_count = ProductInfo.objects.all().count()
当我们在激活模型时
程序已经开始执行了
但是在urls.py文件下未能找到所需的表
于是便会出现报错
vim /django/dapi/dapi/urls.py
把第136行注释掉
等迁移完成后再恢复
(报错是因为pyecharts的原因,之后会考虑是否把pyecharts抛弃掉)
python manage.py makemigrations
重新激活模型
这次成功了
python manage.py migrate
迁移
python manage.py createsuperuser
创建超级管理员账号
因为静态文件我已经放在工程的static目录下面了
所以不用再python manage.py collectstatic收集静态资源文件了
四、配置Nginx:
vim /usr/local/nginx/conf/nginx.conf
修改nginx配置文件
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:3031;
}
location /static {
alias /django/dapi/static/;
index index.html index.htm;
}
location /media {
alias /django/dapi/media/;
}
systemctl restart nginx
重启nginx服务
uwsgi uwsgi.ini
启动uwsgi服务
ls -a
查看dapi工程目录下面的所有文件
tail -f uwsgi.log
查看日志
五、Web页面:
tail -f uwsgi.log
查看日志
uwsgitop :9191
监控uwsgi性能
这个界面按Q退出
六、uwsgi命令:
uwsgi --ini uwsgi文件
# 启动
uwsgi --stop pid文件
# 停止
uwsgi --reload pid文件
# 重启
dapi 基于Django的轻量级测试平台七 怎样部署到生产环境的更多相关文章
- dapi 基于Django的轻量级测试平台八 Docker部署
QQ群: GitHub:https://github.com/yjlch1016/dapi 采用Docker+Supervisor+Nginx+uWSGI+Django 一.Dockerfile文件: ...
- dapi 基于Django的轻量级测试平台一 设计思想
GitHub:https://github.com/yjlch1016/dapi 一.项目命名: dapi:即Django+API测试的缩写 二.设计思想: 模拟性能测试工具JMeter的思路, 实现 ...
- dapi 基于Django的轻量级测试平台二 前端页面
QQ群: GitHub:https://github.com/yjlch1016/dapi 一.登录页login.html: 二.首页home.html: 三.产品线列表页product.html: ...
- dapi 基于Django的轻量级测试平台六 怎样使用压测功能
QQ群: GitHub:https://github.com/yjlch1016/dapi JMeter非GUI模式下: jmeter -n -t jmx脚本 -l jtl文件 -e -o 测试报告目 ...
- dapi 基于Django的轻量级测试平台五 测试报告
QQ群: GitHub:https://github.com/yjlch1016/dapi 一.柱状图 二.饼状图
- dapi 基于Django的轻量级测试平台四 任务设置
QQ群: GitHub:https://github.com/yjlch1016/dapi 一.间隔时间: 二.定时时间: 三.任务设置: 四.任务结果:
- dapi 基于Django的轻量级测试平台三 接口关联
QQ群: GitHub:https://github.com/yjlch1016/dapi 一.接口关联思路: 在接口测试中, 很多场景下, 上一个接口的出参要作为下一个接口的入参, 即上一个接口的响 ...
- dmock 基于Django的轻量级Mock平台
GitHub:https://github.com/yjlch1016/dmock # dmock 基于Django的轻量级Mock平台 dmock即Django+Mock的缩写 一.思路: mock ...
- [2018-03-06] 基于Django的轻量级CMS Mezzanine搭建笔记
一丶什么是Mezzanine? 它是基于django的内容管理平台(),组成简单,可扩展性和定制性强,特别是个小型的个人博客系统.它也提供了类似wordpress的管理页面.博客发布.图片展示等功能, ...
随机推荐
- [LeetCode] 780. Reaching Points 到达指定点
A move consists of taking a point (x, y) and transforming it to either (x, x+y) or (x+y, y). Given a ...
- [LeetCode] 119. Pascal's Triangle II 杨辉三角之二
Given a non-negative index k where k ≤ 33, return the kth index row of the Pascal's triangle. Note t ...
- shell脚本中“$?”标记的用途是什么?
在写一个shell脚本时,如果你想要检查前一命令是否执行成功,在if条件中使用“$?”可以来检查前一命令的结束状态.
- 实现100以内的素数输出(Python与C++对比)
今天从链接http://www.2cto.com/kf/201302/187699.html中看到了Python实现100以内的素数输出的算法,颇受感触.尤其是被其中的Python的列表生成器的使用方 ...
- sql 自动增加排序 并且初始值是000001
declare @co_num int, @CoNum varchar(6) select co_num=count(*)+1 from tab ...
- jar解压后重新打包
因为一些原因修改了jar中的配置文件,但用WinRAR压缩成zip文件后该后缀名为jar,发现重新压缩的文件不可用,所有这些情况下我们必须用jar重新打包. 配置Java环境,让jar命令可用: ja ...
- kafka的安装和初步使用
简介 最近开发的项目中,kafka用的比较多,为了方便梳理,从今天起准备记录一些关于kafka的文章,首先,当然是如何安装kafka了. Apache Kafka是分布式发布-订阅消息系统. Apac ...
- 大话设计模式Python实现-简单工厂模式
简单工厂模式(Simple Factory Pattern):是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类. 下面使用简单工厂模式实现一个简单的四则运算 #!/usr/ ...
- eclipse打开本地文件所在目录位置的快捷键
在开发的过程中总是会遇到需要在本地文件夹找到该本地文件的情况,比如说要发送给同事什么的. 在使用Eclipse的过程中,大多数人都是先在Eclipse目录中定位到文件,然后通过在文件的右键属性中找到文 ...
- windows环境下 mysql 忘记root密码时的解决办法
1,停止MYSQL服务,CMD打开DOS窗口,输入 net stop mysql 2,在CMD命令行窗口,进入MYSQL安装目录 比如E:\Program Files\MySQL\MySQL Serv ...