sanic_vue
1.0.0
프런트엔드 Vue, 백엔드 플라스크
Chrome에서 여는 것이 가장 좋습니다. Safari는 처음으로 일부 스타일을 로드하는 데 문제가 있습니다.
기술 스택: Vue + Vuex + ElementUI + 플라스크 + peewee + HTTPBasicAuth + 셀러리 + 패브릭(프런트엔드 및 백엔드 분리 MVVM 모드)
현재 프런트엔드는 도메인 간 문제를 처리하며 향후 백엔드 처리에 최적화될 수 있습니다.
pymonitor.py는 Python 스크립트의 실시간 변경 사항을 모니터링하고 서버 측 핫 업데이트 기능을 간단하게 시뮬레이션할 수 있습니다.
1. 登录注册(带token,过期验证) 使用的peewee(orm)
2. CRUD服务器资源列表、测试任务列表
3. 展示测试报告(locust)
4. 上传文件到远程服务器, fabric远程操作linux命令,
셀러리를 사용하여 분산 비동기 작업 처리 구현
celery worker -A curd.celery -l info -f celery.log
启动celery worker 更改celery配置需要重启celery
메시지 큐는 Rabbitmq 또는 redis(브로커 미들웨어)에 저장됩니다.
작업 상태에 대한 결과는 redis(백엔드)에 존재하며 프런트엔드는 이 상태를 기반으로 해당 작업 상태를 업데이트합니다.
프런트 엔드(Vue)를 시작합니다.
需要安装node 和yarn
cd frontend
yarn run serve
백엔드 시작(플라스크)
nohup python3 run.py >/dev/null 2>&1 &
Redis 시작(보고 인터페이스를 시작하지 않으면 데이터를 얻을 수 없음)
nohup redis-server > web6.log 2>&1 < /dev/null&
Rabbitmq 설치: (사용할 수 없습니다. 대신 redis를 사용하세요)
brew install rabbitmq
cd /usr/local/Cellar/rabbitmq/3.8.2 (安装目录)
RabiitMQ 시각적 모니터링 플러그인 설치
sudo sbin/rabbitmq-plugins enable rabbitmq_management
Rabbitmq 환경 변수 구성
vi ~/.bash_profile
export RABBIT_HOME= /usr/local/Cellar/rabbitmq/3.8.2
export PATH=$PATH:$RABBIT_HOME/sbin
source ~/.bash_profile
백그라운드에서 RabbitMQ 시작
后台启动
rabbitmq-server -detached
查看状态
rabbitmqctl status
访问可视化监控插件的界面
浏览器内输入 http://localhost:15672,
默认的用户名密码都是guest,登录后可以在Admin那一列菜单内添加自己的用户
rabbitmqctl stop 关闭
모니터 꽃
pip install flower
启动flower
celery flower --address=127.0.0.1 --port=5555
可通过浏览器查看
http://127.0.0.1:5555
감독자 사용
pip install supervisor
在根目录下添加配置:
echo_supervisord_conf> supervisord.conf
[program:celeryd]
command=celery worker -A curd.celery -l info -f celery.log --concurrency=15
;stdout_logfile=/var/log/celery/celeryd.log
;stderr_logfile=/var/log/celery/celeryd.log
autostart=true
autorestart=true
startsecs=10
启动
supervisord
重启
supervisorctl reload
Linux에 플라스크 생산 환경 배포
pip install gunicorn
vim gunicorn.sh
nohup gunicorn -w 4 -b 0.0.0.0:8888 run:app > gunicorn.log 2>&1 &
sh gunicorn.sh
-w 4是指预定义的工作进程数为4,
-b 127.0.0.1:4000指绑定地址和端口
Vue(nginx) 배포
在linux上打包得到dist
/usr/local/nginx/conf
在nginx.conf 第一行修改 user root;(解决403问题)
sudo ./nginx -s stop(reload)停止nginx(重新加载conf)
ps axu | grep nginx
nginx -t 查看具体使用那个conf -c + 路径(具体哪个conf)
Linux에서 MySQL 중국어 잘못된 코드:
locate my.cnf
ps aux|grep mysql|grep 'my.cnf'(查看是否使用了指定目录的my.cnf)
mysql --help|grep 'my.cnf'(查看mysql默认读取my.cnf的目录, 顺序排前的优先。)
[mysqld]
character-set-server=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
show full columns from machine; 查询表的字符编码
sudo service mysqld restart (重启mysql)
show variables like 'character%'; 查看数据库的编码格式
show create database test; 查看数据库字符编码
alter database test default character set utf8 collate utf8_general_ci;
更改数据库字符编码
alter table `表名` convert to character set utf8;
一次性修改表中所有字段的字符集语句
Linux에서 gunicorn을 사용하여 플라스크 배포
touch gunicorn.sh
nohup gunicorn -w 1 -b 0.0.0.0:8888 run:app > gunicorn.log 2>&1 &