pull/577/head
Mr Chen 12 months ago
parent 41109af522
commit a74ca20d0e
  1. 6
      README.md
  2. 19
      plugins/mysql/index.py
  3. 149
      plugins/sphinx/class/sphinx_make.py
  4. 2
      plugins/sphinx/index.html
  5. 28
      plugins/sphinx/index.py
  6. 1
      plugins/sphinx/install.sh
  7. 2
      plugins/sphinx/js/sphinx.js

@ -110,9 +110,11 @@ docker run -itd --name mw-server --privileged=true -p 7200:7200 -p 80:80 -p 443:
```
### 版本更新 0.16.8
### 版本更新 0.16.8.x
- 首页对网络/磁盘IO进行更细致的展示。
- mysql同步优化,享受丝滑般感觉。
- 网站统计实时-可调节1-10s。
- Sphinx优化。
### JSDelivr安装地址

@ -3448,7 +3448,9 @@ def doFullSyncUser(version=''):
time.sleep(1)
writeDbSyncStatus({'code': 1, 'msg': '正在停止从库...', 'progress': 15})
if version == '8.0':
mdb8 = ['8.0','8.1','8.2','8.3','8.4']
if mw.inArray(mdb8,version):
db.query("stop slave user='{}' password='{}';".format(user, apass))
else:
db.query("stop slave")
@ -3537,12 +3539,12 @@ def doFullSyncUser(version=''):
# r = db.query(cmd)
# print(r)
if version == '8.0':
mdb8 = ['8.0','8.1','8.2','8.3','8.4']
if mw.inArray(mdb8,version):
db.query("start slave user='{}' password='{}';".format(user, apass))
else:
db.query("start slave")
db.query("start all slaves")
time_all_e = time.time()
cos = time_all_e - time_all_s
@ -3681,10 +3683,13 @@ def doFullSyncSSH(version=''):
print(import_data[0])
writeDbSyncStatus({'code': 5, 'msg': '导入数据失败...', 'progress': 100})
return 'fail'
# "start slave user='{}' password='{}';".format(uinfo['username'], uinfo['password'])
db.query("start slave")
mdb8 = ['8.0','8.1','8.2','8.3','8.4']
if mw.inArray(mdb8,version):
db.query("start slave user='{}' password='{}';".format(uinfo['username'], uinfo['password']))
else:
db.query("start slave")
writeDbSyncStatus({'code': 6, 'msg': '从库重启完成...', 'progress': 100})
os.system("rm -rf " + SSH_PRIVATE_KEY)

@ -0,0 +1,149 @@
# coding:utf-8
import sys
import io
import os
import time
import subprocess
import re
import json
sys.path.append(os.getcwd() + "/class/core")
import mw
def getServerDir():
return mw.getServerDir() + '/mysql'
def getPluginDir():
return mw.getPluginDir() + '/mysql'
def getConf():
path = getServerDir() + '/etc/my.cnf'
return path
def getDbPort():
file = getConf()
content = mw.readFile(file)
rep = 'port\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
def getSocketFile():
file = getConf()
content = mw.readFile(file)
rep = 'socket\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
def pSqliteDb(dbname='databases'):
file = getServerDir() + '/mysql.db'
name = 'mysql'
conn = mw.M(dbname).dbPos(getServerDir(), name)
return conn
def pMysqlDb():
# pymysql
db = mw.getMyORM()
db.setPort(getDbPort())
db.setSocket(getSocketFile())
# db.setCharset("utf8")
db.setPwd(pSqliteDb('config').where('id=?', (1,)).getField('mysql_root'))
return db
def makeSqlToSphinx():
pass
def makeSqlToSphinxDb(db, table = []):
pdb = pMysqlDb()
tables = pdb.query("show tables in "+ db)
for x in range(len(tables)):
key = 'Tables_in_'+db
table_name = tables[x][key]
pkey_name = getTablePk(db,table_name)
if pkey_name == '':
continue
# print(table_name+':'+pkey_name)
makeSqlToSphinxTable(db,table_name)
def getTablePk(db, table):
pdb = pMysqlDb()
pkey_sql = "SHOW INDEX FROM {}.{} WHERE Key_name = 'PRIMARY';".format(db,table,);
pkey_data = pdb.query(pkey_sql)
if len(pkey_data) == 1:
return pkey_data[0]['Column_name']
return ''
def makeSqlToSphinxTable(db,table):
pdb = pMysqlDb()
sql = "select COLUMN_NAME,DATA_TYPE from information_schema.COLUMNS where `TABLE_SCHEMA`='{}' and `TABLE_NAME` = '{}';"
sql = sql.format(db,table,)
cols = pdb.query(sql)
cols_len = len(cols)
conf = ''
run_pos = 0
for x in range(cols_len):
data_type = cols[x]['DATA_TYPE']
column_name = cols[x]['COLUMN_NAME']
print(column_name+":"+data_type)
# if mw.inArray(['tinyint'], data_type):
# conf += 'sql_attr_bool = '+ column_name + "\n"
if mw.inArray(['enum'], data_type):
run_pos += 1
conf += 'sql_attr_string = '+ column_name + "\n"
if mw.inArray(['decimal'], data_type):
run_pos += 1
conf += 'sql_attr_float = '+ column_name + "\n"
if mw.inArray(['bigint','smallint','tinyint','int','mediumint'], data_type):
run_pos += 1
conf += 'sql_attr_bigint = '+ column_name + "\n"
if mw.inArray(['float'], data_type):
run_pos += 1
conf += 'sql_attr_float = '+ column_name + "\n"
if mw.inArray(['varchar','char'], data_type):
run_pos += 1
conf += 'sql_attr_string = '+ column_name + "\n"
if mw.inArray(['text','mediumtext','tinytext','longtext'], data_type):
run_pos += 1
conf += 'sql_field_string = '+ column_name + "\n"
if mw.inArray(['datetime','date'], data_type):
run_pos += 1
conf += 'sql_attr_timestamp = '+ column_name + "\n"
if cols_len != run_pos:
print(db,table)
print(cols_len,run_pos)
# print(conf)
return conf

@ -7,7 +7,7 @@
<p onclick="pluginLogs('sphinx','','run_log',30);">运行日志</p>
<p onclick="pluginLogs('sphinx','','query_log', 30);">查询日志</p>
<p onclick="runStatus();">运行状态</p>
<p onclick="rebuild();">重建索引</p>
<p onclick="commonFunc();">常用功能</p>
<p onclick="readme();">说明</p>
</div>
<div class="bt-w-con pd15">

@ -15,14 +15,13 @@ app_debug = False
if mw.isAppleSystem():
app_debug = True
def getPluginName():
return 'sphinx'
def getPluginDir():
return mw.getPluginDir() + '/' + getPluginName()
sys.path.append(getPluginDir() +"/class")
def getServerDir():
return mw.getServerDir() + '/' + getPluginName()
@ -318,6 +317,29 @@ def sphinxCmd():
else:
return mw.returnJson(False, 'no index')
def makeDbToSphinx():
import sphinx_make
pdb = sphinx_make.pMysqlDb()
filter_db = ['information_schema','performance_schema','sys','mysql']
db_list = pdb.query('show databases')
print(db_list)
for x in range(len(db_list)):
dbname = db_list[x]['Database']
if mw.inArray(filter_db, dbname):
continue
sphinx_make.makeSqlToSphinxDb(dbname)
print(dbname)
# makeSqlToSphinxTable()
if __name__ == "__main__":
func = sys.argv[1]
@ -353,5 +375,7 @@ if __name__ == "__main__":
print(runStatus())
elif func == 'sphinx_cmd':
print(sphinxCmd())
elif func == 'db_to_sphinx':
print(makeDbToSphinx())
else:
print('error')

@ -12,6 +12,7 @@ install_tmp=${rootPath}/tmp/mw_install.pl
# cd /www/server/mdserver-web && source bin/activate && python3 plugins/sphinx/index.py rebuild
# /www/server/sphinx/bin/bin/indexer -c /www/server/sphinx/sphinx.conf --rotate
# cd /www/server/mdserver-web && source bin/activate && python3 plugins/sphinx/index.py db_to_sphinx
bash ${rootPath}/scripts/getos.sh

@ -30,7 +30,7 @@ function spPost(method, args, callback){
});
}
function rebuild(){
function commonFunc(){
var con = '<button class="btn btn-default btn-sm" onclick="rebuildIndex();">重建索引</button>';
$(".soft-man-con").html(con);
}

Loading…
Cancel
Save