美团SQLAdvisor SQL优化建议工具的Web版,告别命令行。
- 项目中使用的美团SQL分析工具是在CentOS上编译的,所以建议部署到CentOS上。
- 该项目是使用Python的Flask框架开发的。
- 使用CentOS自带的Python版本,版本号是2.7.5。
- 再部署前建议先看一下美团的分析工具文档
- CentOS所在环境是使用Vagrant虚拟的环境。
sudo yum install git
sudo yum install wget
CentOS 7安装Mysql需要先下载Mysql的rpm文件。
wget http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
rpm -ivh mysql57-community-release-el7-9.noarch.rpm
sudo yum install mysql-community-server
配置Mysql
mysql_secure_installation
执行上面命令设置root密码。
sudo systemctl enable mysqld
设置开机启动。
重启数据库
sudo systemctl mysqld restart
进入Mysql创建sqladvisor
数据库
CREATE DATABASE IF NOT EXISTS sqladvisor default charset utf8 COLLATE utf8_general_ci;
一定要设置charset为utf8和COLLATE为utf8_general_ci,否则无法保存中文。
安装pip
sudo yum -y install epel-release
sudo yum install python-pip
git clone https://github.com/zyw/sqladvisor-web.git
下载项目。
cd sqladvisor-web
为了不报下面异常
root@pts/4 $ pip install MySQL-python
Collecting MySQL-python
Using cached MySQL-python-1.2.5.zip
Complete output from command python setup.py egg_info:
sh: mysql_config: command not found
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "/tmp/pip-build-kWowP9/MySQL-python/setup.py", line 17, in <module>
metadata, options = get_config()
File "setup_posix.py", line 43, in get_config
libs = mysql_config("libs_r")
File "setup_posix.py", line 25, in mysql_config
raise EnvironmentError("%s not found" % (mysql_config.path,))
EnvironmentError: mysql_config not found
----------------------------------------
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-kWowP9/MySQL-python/
首先安装
sudo yum install python-devel mysql-community-devel -y
sudo pip install -r requirements.txt
编辑工程中的config.py
文件
SQLALCHEMY_DATABASE_URI = os.environ.get('DEV_DATABASE_URL') or 'mysql://root:root@localhost/sqladvisor'
把第二个root
修改成你安装Mysql时设置的密码。
python manage.py db init
python manage.py db migrate
python manage.py db upgrade
如果
migrations
文件夹已存在,先删除。
经过上三条命令,sqladvisor
数据库中的表已经被创建了。
解压sqlparser.tar.gz
到/usr/local
python manage.py runserver --host 0.0.0.0
启动完成后访问http://127.0.0.1:5000/
使用上面的命令是在开发环境启动Python Web应用,如果想要供多人使用还是使用gunicorn
部署比较好。
- 安装
gunicorn
pip install gunicorn
- 启动服务
gunicorn manage:app -p manage.pid -b 0.0.0.0:8000 -D
上面的命令启动一个监听0.0.0.0:8000 IP和端口的服务,-D是启动一个守护进程