zoukankan      html  css  js  c++  java
  • 分享一个基于小米 soar 的开源 sql 分析与优化的 WEB 图形化工具

    soar-web

    基于小米 soar 的开源 sql 分析与优化的 WEB 图形化工具,支持 soar 配置的添加、修改、复制,多配置切换,配置的导出、导入与导入功能。
    example-1
    example-2
    example-3

    环境需求

    python3.x
    Flask
    pymysql

    Python 环境未安装的可参考下面操作:

    Windows:
    step 1 去 python 官网下载安装 python3 (已安装可跳过此步骤)
    setp 2 pip install Flask
    setp 3 pip install pymysql

    Mac:
    step 1 brew install python3 python3-pip (如果两个包都有安装可跳过此步骤)
    setp 2 pip install Flask
    setp 3 pip install pymysql

    Ubuntu:
    step 1 sudo apt-get install python3 python3-pip (如果两个包都有安装可跳过此步骤)
    setp 2 pip install Flask
    setp 3 pip install pymysql

    CentOS:
    step 1 yum install python36 python36-pip (如果两个包都有安装可跳过此步骤)
    setp 2 pip install Flask
    setp 3 pip install pymysql

    安装与使用

    下载源码( Windows 可略过此步骤):
    sudo -y apt-get install wget 或者 sudo yum -y install wget
    wget https://codeload.github.com/xiyangxixian/soar-web/zip/master -O soar-web-master.zip

    解压缩( Windows 可略过此步骤):
    sudo -y apt-get install unzip 或者 sudo yum -y install unzip
    unzip soar-web.zip
    cd soar-web-matster

    运行启动脚本
    Windows: run.bat
    Linux or Mac: bash run.sh
    截图

    按Ctrl + c 结束

    守护进程支持:
    启动服务:bash manage.sh start
    关闭服务:bash manage.sh stop
    重启服务:bash manage.sh restart

    注:当主机上存在多个 python 版本时, 需自行更改 run.sh, run.bat, manage.sh 中的 python 版本指定为 3.x 以上的版本运行。

    docker 支持

    地址:https://hub.docker.com/r/becivells/soar-web/
    Dockerfile 见根目录 Dockerfile 文件
    yum install docker -y
    service docker start
    docker pull becivells/soar-web
    docker run -d --name soar-web -p 5077:5077 becivells/soar-web

    也可以是用 Dockerfile 自行构建
    docker build --no-cache -t soar-web .

    访问

    在浏览器上输入 http://127.0.0.1:5077 进行访问
    截图3

    配置

    如果需要改IP地址和端口号, 可在 config.py 中进行修改
    功能相关
    关于存储: 所有的配置都是保存在浏览器 Local Storage 中的,多人之间使用是互补影响的,自己只能看到自己的配置,更换浏览器或者清除浏览器会造成配置丢失。
    配置模板: 可以添加多数据库连接实例及配置,方便在 sql 评估的相互切换使用,具体配置项详情见https://github.com/XiaoMi/soar/blob/master/doc/config.md 。

    下面是连接数据库后测试效果
    截图4
    数据库连接: 数据库连接成功后,soar 可以通过表结构提供更正确优质的 sql 评估建议, 配置的正确性决定了 soar 的服务质量。
    截图5
    cfg
    截图7

    线上线下环境问题: 线上环境作为待 sql 评估环境,soar 在进行 sql 评估时,会根据 sql 语句,从 线上环境的数据库连接实例 拷贝数据表到 测试环境的数据库连接实例,然后在测试环境下执行 sql 语句进行分析。因此测试环境的数据库连接实例需要有最高权限。如果无法没有最高权限可能造成一些问题,如果没有权限可以启动一个空的 mysql docker 容器作为测试环境。如果仅仅做测试用,可将线上线下环境指定为一样。
    日志等级: 日志等级为 0 时不打印日志,设置为 1-7 时,会将 soar 产生的日志打印至控制台,按 F12 或右击网页点击审查元素打开调试工具,点击 Console 按钮查看日志。

  • 相关阅读:
    第四次作业—— 分析比较各种软件构建环境
    如何实现点击事件触发之后刷新还保存原值
    简单理解js闭包
    javascript中 __proto__与prorotype的理解
    原生和jQuery的ajax用法
    getElementById和querySelector方法的区别
    关于javascript闭包理解
    第二篇 进销存管理系统冲刺博客
    个人项目:WC
    自我介绍+软工五问
  • 原文地址:https://www.cnblogs.com/DataArt/p/10177873.html
Copyright © 2011-2022 走看看