## 常见问题 ### 软件依赖 * [git](https://git-scm.co) 项目代码管理工具 * [go](https://golang.org/) 源码编译依赖 * [govendor](https://github.com/kardianos/govendor) 管理第三方包 * [docker](https://www.docker.com) 主要用于构建测试环境 * [mysql](https://www.mysql.com/) 测试时用来连接测试环境 * [retool](https://github.com/twitchtv/retool): 管理测试开发工具,首次安装耗时会比较长,如:`gometalinter.v2`, `revive`, `golangci-lint` ### 提示语法错误 * 请检查SQL语句中是否出现了不配对的引号,如 `, ", ' ### 输出结果返回慢 * 如果配置了online-dsn或test-dsn SOAR会请求这些数据库以支持更多的功能,这时评审一条SQL就会耗时变长。 * 如果又开启了`-sampling=true`的话会将线上的数据导入到测试环境,数据采样也会消耗一些时间。 ## 如何搭建测试环境 ```bash # 创建测试数据库 wget http://downloads.mysql.com/doc/sakila-db.tar.gz tar zxf sakila-db.tar.gz && cd sakila-db mysql -u root -p -f < sakila-schema.sql mysql -u root -p -f < sakila-data.sql # 创建测试用户 CREATE USER root@'hostname' IDENTIFIED BY "1t'sB1g3rt"; GRANT ALL ON *.* TO root@'hostname'; ``` ## 更新vitess依赖 使用`govendor fetch`或`git clone` [vitess](https://github.com/vitessio/vitess) 在某些地区更新vitess可能会比较慢,导致项目编译不过,所以将vitess整个代码库加到了代码仓库。 如属更新vitess仓库可以使用如下命令。 ```bash $ make vitess ``` ## 生成报告并发邮件 ```bash #!/bin/bash soar -query "select * from film" > ./index.html ( echo To: youmail@example.com echo From: robot@example.com echo "Content-Type: text/html; " echo Subject: SQL Analyze Report echo cat ./index.html ) | sendmail -t ``` ## 如何新增一条启发式建议 ```bash advisor/rules.go HeuristicRules 加一个条新的规则 advisor/heuristic.go 实现一个规则函数 advisor/heuristic_test.go 添加相应规则函数的测试用例 make heuristic make daily ```