mirror of https://github.com/midoks/mdserver-web
parent
b2d78d53d1
commit
9d1e934f9a
@ -0,0 +1,97 @@ |
|||||||
|
[client] |
||||||
|
user = root |
||||||
|
#password = your_password |
||||||
|
port = 3376 |
||||||
|
socket = {$SERVER_APP_PATH}/mysql.sock |
||||||
|
default-character-set = UTF8MB4 |
||||||
|
|
||||||
|
[mysqld] |
||||||
|
pid-file = {$SERVER_APP_PATH}/data/mysql.pid |
||||||
|
user = mysql |
||||||
|
port = 3376 |
||||||
|
mysqlx_port = 33760 |
||||||
|
socket = {$SERVER_APP_PATH}/mysql.sock |
||||||
|
datadir = {$SERVER_APP_PATH}/data |
||||||
|
log-error = {$SERVER_APP_PATH}/data/error.log |
||||||
|
default_storage_engine = MyISAM |
||||||
|
|
||||||
|
key_buffer_size = 8M |
||||||
|
table_open_cache = 32 |
||||||
|
sort_buffer_size = 256K |
||||||
|
net_buffer_length = 4K |
||||||
|
read_buffer_size = 128K |
||||||
|
read_rnd_buffer_size = 256K |
||||||
|
myisam_sort_buffer_size = 4M |
||||||
|
thread_cache_size = 4 |
||||||
|
lower_case_table_names=0 |
||||||
|
tmp_table_size = 8M |
||||||
|
character-set-server = UTF8MB4 |
||||||
|
|
||||||
|
max_connections = 500 |
||||||
|
max_connect_errors = 100 |
||||||
|
open_files_limit = 2560 |
||||||
|
max_allowed_packet = 128M |
||||||
|
|
||||||
|
#skip-external-locking |
||||||
|
#skip-grant-tables |
||||||
|
#loose-skip-innodb |
||||||
|
#skip-networking |
||||||
|
#skip-name-resolve |
||||||
|
|
||||||
|
log-bin=mysql-bin |
||||||
|
binlog_format=mixed |
||||||
|
server-id = 1 |
||||||
|
slow_query_log=1 |
||||||
|
slow-query-log-file={$SERVER_APP_PATH}/data/mysql-slow.log |
||||||
|
long_query_time=3 |
||||||
|
#log_queries_not_using_indexes=on |
||||||
|
|
||||||
|
relay-log=mdserver |
||||||
|
relay-log-index=mdserver |
||||||
|
|
||||||
|
#master |
||||||
|
#binlog-do-db |
||||||
|
binlog-ignore-db = test |
||||||
|
binlog-ignore-db = mysql |
||||||
|
binlog-ignore-db = information_schema |
||||||
|
binlog-ignore-db = performance_schema |
||||||
|
|
||||||
|
#slave |
||||||
|
log-slave-updates |
||||||
|
#replicate-do-db |
||||||
|
replicate-ignore-db = information_schema |
||||||
|
replicate-ignore-db = performance_schema |
||||||
|
replicate-ignore-db = mysql |
||||||
|
replicate-ignore-db = test |
||||||
|
|
||||||
|
default_storage_engine = InnoDB |
||||||
|
innodb_data_home_dir = {$SERVER_APP_PATH}/data |
||||||
|
innodb_data_file_path = ibdata1:10M:autoextend |
||||||
|
innodb_log_group_home_dir = {$SERVER_APP_PATH}/data |
||||||
|
innodb_buffer_pool_size = 16M |
||||||
|
innodb_log_file_size = 5M |
||||||
|
innodb_log_buffer_size = 8M |
||||||
|
innodb_flush_log_at_trx_commit = 1 |
||||||
|
innodb_lock_wait_timeout = 120 |
||||||
|
innodb_max_dirty_pages_pct = 90 |
||||||
|
innodb_read_io_threads = 1 |
||||||
|
innodb_write_io_threads = 1 |
||||||
|
innodb_file_per_table=1 |
||||||
|
binlog_expire_logs_seconds=2592000 |
||||||
|
|
||||||
|
secure-file-priv={$SERVER_APP_PATH}/tmp |
||||||
|
|
||||||
|
[mysqldump] |
||||||
|
quick |
||||||
|
|
||||||
|
[mysql] |
||||||
|
no-auto-rehash |
||||||
|
|
||||||
|
[myisamchk] |
||||||
|
key_buffer_size = 20M |
||||||
|
sort_buffer_size = 20M |
||||||
|
read_buffer = 2M |
||||||
|
write_buffer = 2M |
||||||
|
|
||||||
|
[mysqlhotcopy] |
||||||
|
interactive-timeout |
@ -0,0 +1,98 @@ |
|||||||
|
[client] |
||||||
|
user = root |
||||||
|
#password = your_password |
||||||
|
port = 3386 |
||||||
|
socket = {$SERVER_APP_PATH}/mysql.sock |
||||||
|
default-character-set = UTF8MB4 |
||||||
|
|
||||||
|
[mysqld] |
||||||
|
default_authentication_plugin=mysql_native_password |
||||||
|
pid-file = {$SERVER_APP_PATH}/data/mysql.pid |
||||||
|
user = mysql |
||||||
|
port = 3386 |
||||||
|
mysqlx_port = 33860 |
||||||
|
socket = {$SERVER_APP_PATH}/mysql.sock |
||||||
|
datadir = {$SERVER_APP_PATH}/data |
||||||
|
log-error = {$SERVER_APP_PATH}/data/error.log |
||||||
|
default_storage_engine = MyISAM |
||||||
|
|
||||||
|
key_buffer_size = 8M |
||||||
|
table_open_cache = 32 |
||||||
|
sort_buffer_size = 256K |
||||||
|
net_buffer_length = 4K |
||||||
|
read_buffer_size = 128K |
||||||
|
read_rnd_buffer_size = 256K |
||||||
|
myisam_sort_buffer_size = 4M |
||||||
|
thread_cache_size = 4 |
||||||
|
lower_case_table_names=0 |
||||||
|
tmp_table_size = 8M |
||||||
|
character-set-server = UTF8MB4 |
||||||
|
|
||||||
|
max_connections = 500 |
||||||
|
max_connect_errors = 100 |
||||||
|
open_files_limit = 2560 |
||||||
|
max_allowed_packet = 128M |
||||||
|
|
||||||
|
#skip-external-locking |
||||||
|
#skip-grant-tables |
||||||
|
#loose-skip-innodb |
||||||
|
#skip-networking |
||||||
|
#skip-name-resolve |
||||||
|
|
||||||
|
log-bin=mysql-bin |
||||||
|
binlog_format=mixed |
||||||
|
server-id = 1 |
||||||
|
slow_query_log=1 |
||||||
|
slow-query-log-file={$SERVER_APP_PATH}/data/mysql-slow.log |
||||||
|
long_query_time=3 |
||||||
|
#log_queries_not_using_indexes=on |
||||||
|
|
||||||
|
relay-log=mdserver |
||||||
|
relay-log-index=mdserver |
||||||
|
|
||||||
|
#master |
||||||
|
#binlog-do-db |
||||||
|
binlog-ignore-db = test |
||||||
|
binlog-ignore-db = mysql |
||||||
|
binlog-ignore-db = information_schema |
||||||
|
binlog-ignore-db = performance_schema |
||||||
|
|
||||||
|
#slave |
||||||
|
log_replica_updates |
||||||
|
#replicate-do-db |
||||||
|
replicate-ignore-db = information_schema |
||||||
|
replicate-ignore-db = performance_schema |
||||||
|
replicate-ignore-db = mysql |
||||||
|
replicate-ignore-db = test |
||||||
|
|
||||||
|
default_storage_engine = InnoDB |
||||||
|
innodb_data_home_dir = {$SERVER_APP_PATH}/data |
||||||
|
innodb_data_file_path = ibdata1:10M:autoextend |
||||||
|
innodb_log_group_home_dir = {$SERVER_APP_PATH}/data |
||||||
|
innodb_buffer_pool_size = 16M |
||||||
|
innodb_log_file_size = 5M |
||||||
|
innodb_log_buffer_size = 8M |
||||||
|
innodb_flush_log_at_trx_commit = 1 |
||||||
|
innodb_lock_wait_timeout = 120 |
||||||
|
innodb_max_dirty_pages_pct = 90 |
||||||
|
innodb_read_io_threads = 1 |
||||||
|
innodb_write_io_threads = 1 |
||||||
|
innodb_file_per_table=1 |
||||||
|
binlog_expire_logs_seconds=2592000 |
||||||
|
|
||||||
|
secure-file-priv={$SERVER_APP_PATH}/tmp |
||||||
|
|
||||||
|
[mysqldump] |
||||||
|
quick |
||||||
|
|
||||||
|
[mysql] |
||||||
|
no-auto-rehash |
||||||
|
|
||||||
|
[myisamchk] |
||||||
|
key_buffer_size = 20M |
||||||
|
sort_buffer_size = 20M |
||||||
|
read_buffer = 2M |
||||||
|
write_buffer = 2M |
||||||
|
|
||||||
|
[mysqlhotcopy] |
||||||
|
interactive-timeout |
@ -0,0 +1,28 @@ |
|||||||
|
CREATE TABLE IF NOT EXISTS `config` ( |
||||||
|
`id` INTEGER PRIMARY KEY AUTOINCREMENT, |
||||||
|
`mysql_root` TEXT |
||||||
|
); |
||||||
|
|
||||||
|
INSERT INTO `config` (`id`, `mysql_root`) VALUES (1, 'admin'); |
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `databases` ( |
||||||
|
`id` INTEGER PRIMARY KEY AUTOINCREMENT, |
||||||
|
`pid` INTEGER, |
||||||
|
`name` TEXT, |
||||||
|
`username` TEXT, |
||||||
|
`password` TEXT, |
||||||
|
`accept` TEXT, |
||||||
|
`ps` TEXT, |
||||||
|
`addtime` TEXT |
||||||
|
); |
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `master_replication_user` ( |
||||||
|
`id` INTEGER PRIMARY KEY AUTOINCREMENT, |
||||||
|
`username` TEXT, |
||||||
|
`password` TEXT, |
||||||
|
`accept` TEXT, |
||||||
|
`ps` TEXT, |
||||||
|
`addtime` TEXT |
||||||
|
); |
||||||
|
|
||||||
|
|
After Width: | Height: | Size: 1.1 KiB |
@ -0,0 +1,58 @@ |
|||||||
|
<div class="bt-form"> |
||||||
|
<div class='plugin_version'></div> |
||||||
|
<div class="bt-w-main"> |
||||||
|
<div class="bt-w-menu"> |
||||||
|
<script type="text/javascript">console.log($('.plugin_version').attr('version'));</script> |
||||||
|
<p class="bgw" onclick="pluginService('mysql-yum', $('.plugin_version').attr('version'));">服务</p> |
||||||
|
<p onclick="pluginInitD('mysql-yum', $('.plugin_version').attr('version'));">自启动</p> |
||||||
|
<p onclick="pluginConfig('mysql-yum', $('.plugin_version').attr('version'));">配置文件</p> |
||||||
|
<p onclick="myDbPos();">存储位置</p> |
||||||
|
<p onclick="myPort();">端口</p> |
||||||
|
<p onclick="runInfo();">当前状态</p> |
||||||
|
<p onclick="myPerfOpt();">性能优化</p> |
||||||
|
<p onclick="myLogs();">日志</p> |
||||||
|
<p onclick="pluginLogs('mysql-yum',$('.plugin_version').attr('version'),'error_log');">错误日志</p> |
||||||
|
<p onclick="pluginLogs('mysql-yum',$('.plugin_version').attr('version'),'show_log');">慢日志</p> |
||||||
|
<p onclick="dbList()">管理列表</p> |
||||||
|
</div> |
||||||
|
<div class="bt-w-con pd15"> |
||||||
|
<div class="soft-man-con"></div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
</div> |
||||||
|
|
||||||
|
|
||||||
|
<style type="text/css"> |
||||||
|
.db_list{ |
||||||
|
padding: 0px 0 10px 0; |
||||||
|
font-size: 13px; |
||||||
|
line-height: 35px; |
||||||
|
height: 45px; |
||||||
|
} |
||||||
|
.db_list a{ |
||||||
|
margin-right: 15px; |
||||||
|
color: #555; |
||||||
|
font-weight: 600; |
||||||
|
} |
||||||
|
.db_list span:nth-child(1){ |
||||||
|
display: block; |
||||||
|
float: left; |
||||||
|
padding-left: 15px; |
||||||
|
background: #ececec; |
||||||
|
border-radius: 3px; |
||||||
|
} |
||||||
|
|
||||||
|
#db_tools button { |
||||||
|
margin-right: 10px; |
||||||
|
} |
||||||
|
#db_tools button:last-child{ |
||||||
|
margin-right: 0; |
||||||
|
} |
||||||
|
</style> |
||||||
|
<script type="text/javascript"> |
||||||
|
resetPluginWinWidth(800); |
||||||
|
$.getScript( "/plugins/file?name=mysql-yum&f=js/mysql-yum.js", function(){ |
||||||
|
pluginService('mysql-yum',$('.plugin_version').attr('version')); |
||||||
|
}); |
||||||
|
</script> |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,17 @@ |
|||||||
|
{ |
||||||
|
"title":"MySQL[YUM]", |
||||||
|
"tip":"soft", |
||||||
|
"name":"mysql-yum", |
||||||
|
"type":"运行环境", |
||||||
|
"ps":"[<b style='color:red;'>勿用</b>]一种关系数据库管理系统(极速安装)!", |
||||||
|
"todo_versions":["5.7","8.0"], |
||||||
|
"versions":["5.7","8.0"], |
||||||
|
"shell":"install.sh", |
||||||
|
"install_pre_inspection":true, |
||||||
|
"checks":"server/mysql-yum", |
||||||
|
"path":"server/mysql-yum", |
||||||
|
"author":"mysql", |
||||||
|
"home":"https://dev.mysql.com/downloads/mysql", |
||||||
|
"date":"2022-06-29", |
||||||
|
"pid": "6" |
||||||
|
} |
@ -0,0 +1,63 @@ |
|||||||
|
# It's not recommended to modify this file in-place, because it will be |
||||||
|
# overwritten during package upgrades. If you want to customize, the |
||||||
|
# best way is to use systemctl edit: |
||||||
|
# |
||||||
|
# $ systemctl edit mysqld.service |
||||||
|
# |
||||||
|
# this will create file |
||||||
|
# |
||||||
|
# /etc/systemd/system/mysqld.service.d/override.conf |
||||||
|
# |
||||||
|
# which be parsed after the file mysqld.service itself is parsed. |
||||||
|
# |
||||||
|
# For example, if you want to increase mysql's open-files-limit to 20000 |
||||||
|
# add following when editing with command above: |
||||||
|
# |
||||||
|
# [Service] |
||||||
|
# LimitNOFILE=20000 |
||||||
|
# |
||||||
|
# Or if you require to execute pre and post scripts in the unit file as root, set |
||||||
|
# PermissionsStartOnly=true |
||||||
|
# |
||||||
|
# For more info about custom unit files, see systemd.unit(5) or |
||||||
|
# http://fedoraproject.org/wiki/Systemd#How_do_I_customize_a_unit_file.2F_add_a_custom_unit_file.3F |
||||||
|
# |
||||||
|
# Don't forget to reload systemd daemon after you change unit configuration: |
||||||
|
# root> systemctl --system daemon-reload |
||||||
|
|
||||||
|
[Unit] |
||||||
|
Description=MySQL 8.0 database server |
||||||
|
After=syslog.target |
||||||
|
After=network.target |
||||||
|
|
||||||
|
[Service] |
||||||
|
Type=notify |
||||||
|
User=mysql |
||||||
|
Group=mysql |
||||||
|
|
||||||
|
ExecStartPre=/usr/libexec/mysql-check-socket |
||||||
|
ExecStartPre=/usr/libexec/mysql-prepare-db-dir %n |
||||||
|
# Note: we set --basedir to prevent probes that might trigger SELinux alarms, |
||||||
|
# per bug #547485 |
||||||
|
ExecStart=/usr/libexec/mysqld --defaults-file={$SERVER_PATH}/mysql-ya/etc/my.cnf --basedir=/usr --user=mysql |
||||||
|
ExecStartPost=/usr/libexec/mysql-check-upgrade |
||||||
|
ExecStopPost=/usr/libexec/mysql-wait-stop |
||||||
|
|
||||||
|
# Give a reasonable amount of time for the server to start up/shut down |
||||||
|
TimeoutSec=300 |
||||||
|
|
||||||
|
# Place temp files in a secure directory, not /tmp |
||||||
|
PrivateTmp=false |
||||||
|
|
||||||
|
Restart=on-failure |
||||||
|
|
||||||
|
RestartPreventExitStatus=1 |
||||||
|
|
||||||
|
# Sets open_files_limit |
||||||
|
LimitNOFILE = 10000 |
||||||
|
|
||||||
|
# Set enviroment variable MYSQLD_PARENT_PID. This is required for SQL restart command. |
||||||
|
Environment=MYSQLD_PARENT_PID=1 |
||||||
|
|
||||||
|
[Install] |
||||||
|
WantedBy=multi-user.target |
@ -0,0 +1,46 @@ |
|||||||
|
#!/bin/bash |
||||||
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin |
||||||
|
export PATH |
||||||
|
|
||||||
|
curPath=`pwd` |
||||||
|
rootPath=$(dirname "$curPath") |
||||||
|
rootPath=$(dirname "$rootPath") |
||||||
|
serverPath=$(dirname "$rootPath") |
||||||
|
|
||||||
|
|
||||||
|
# cd /www/server/mdserver-web/plugins/mysql-yum && bash install.sh install 8.0 |
||||||
|
# cd /www/server/mdserver-web/plugins/mysql-yum && bash install.sh uninstall 8.0 |
||||||
|
# cd /www/server/mdserver-web && python3 /www/server/mdserver-web/plugins/mysql-yum/index.py start 8.0 |
||||||
|
|
||||||
|
install_tmp=${rootPath}/tmp/mw_install.pl |
||||||
|
|
||||||
|
|
||||||
|
action=$1 |
||||||
|
type=$2 |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [ "${2}" == "" ];then |
||||||
|
echo '缺少安装脚本...' > $install_tmp |
||||||
|
exit 0 |
||||||
|
fi |
||||||
|
|
||||||
|
if [ ! -d $curPath/versions/$2 ];then |
||||||
|
echo '缺少安装脚本2...' > $install_tmp |
||||||
|
exit 0 |
||||||
|
fi |
||||||
|
|
||||||
|
if [ "${action}" == "uninstall" ];then |
||||||
|
|
||||||
|
cd ${rootPath} && python3 plugins/mysql-yum/index.py stop ${type} |
||||||
|
cd ${rootPath} && python3 plugins/mysql-yum/index.py initd_uninstall ${type} |
||||||
|
cd $curPath |
||||||
|
fi |
||||||
|
|
||||||
|
sh -x $curPath/versions/$2/install.sh $1 |
||||||
|
|
||||||
|
if [ "${action}" == "install" ];then |
||||||
|
# #初始化 |
||||||
|
cd ${rootPath} && python3 plugins/mysql-yum/index.py start ${type} |
||||||
|
cd ${rootPath} && python3 plugins/mysql-yum/index.py initd_install ${type} |
||||||
|
fi |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,119 @@ |
|||||||
|
# coding: utf-8 |
||||||
|
#----------------------------- |
||||||
|
# 网站备份工具 |
||||||
|
#----------------------------- |
||||||
|
|
||||||
|
import sys |
||||||
|
import os |
||||||
|
|
||||||
|
if sys.platform != 'darwin': |
||||||
|
os.chdir('/www/server/mdserver-web') |
||||||
|
|
||||||
|
|
||||||
|
chdir = os.getcwd() |
||||||
|
sys.path.append(chdir + '/class/core') |
||||||
|
|
||||||
|
# reload(sys) |
||||||
|
# sys.setdefaultencoding('utf-8') |
||||||
|
|
||||||
|
|
||||||
|
import mw |
||||||
|
import db |
||||||
|
import time |
||||||
|
|
||||||
|
|
||||||
|
class backupTools: |
||||||
|
|
||||||
|
def backupDatabase(self, name, count): |
||||||
|
db_path = mw.getServerDir() + '/mysql-ya' |
||||||
|
db_name = 'mysql' |
||||||
|
name = mw.M('databases').dbPos(db_path, 'mysql').where( |
||||||
|
'name=?', (name,)).getField('name') |
||||||
|
startTime = time.time() |
||||||
|
if not name: |
||||||
|
endDate = time.strftime('%Y/%m/%d %X', time.localtime()) |
||||||
|
log = "数据库[" + name + "]不存在!" |
||||||
|
print("★[" + endDate + "] " + log) |
||||||
|
print( |
||||||
|
"----------------------------------------------------------------------------") |
||||||
|
return |
||||||
|
|
||||||
|
backup_path = mw.getRootDir() + '/backup/database' |
||||||
|
if not os.path.exists(backup_path): |
||||||
|
mw.execShell("mkdir -p " + backup_path) |
||||||
|
|
||||||
|
filename = backup_path + "/db_" + name + "_" + \ |
||||||
|
time.strftime('%Y%m%d_%H%M%S', time.localtime()) + ".sql.gz" |
||||||
|
|
||||||
|
import re |
||||||
|
mysql_root = mw.M('config').dbPos(db_path, db_name).where( |
||||||
|
"id=?", (1,)).getField('mysql_root') |
||||||
|
|
||||||
|
mycnf = mw.readFile(db_path + '/etc/my.cnf') |
||||||
|
rep = "\[mysqldump\]\nuser=root" |
||||||
|
sea = "[mysqldump]\n" |
||||||
|
subStr = sea + "user=root\npassword=" + mysql_root + "\n" |
||||||
|
mycnf = mycnf.replace(sea, subStr) |
||||||
|
if len(mycnf) > 100: |
||||||
|
mw.writeFile(db_path + '/etc/my.cnf', mycnf) |
||||||
|
|
||||||
|
mw.execShell( |
||||||
|
db_path + "/bin/mysqldump --opt --default-character-set=utf8 " + name + " | gzip > " + filename) |
||||||
|
|
||||||
|
if not os.path.exists(filename): |
||||||
|
endDate = time.strftime('%Y/%m/%d %X', time.localtime()) |
||||||
|
log = "数据库[" + name + "]备份失败!" |
||||||
|
print("★[" + endDate + "] " + log) |
||||||
|
print( |
||||||
|
"----------------------------------------------------------------------------") |
||||||
|
return |
||||||
|
|
||||||
|
mycnf = mw.readFile(db_path + '/etc/my.cnf') |
||||||
|
mycnf = mycnf.replace(subStr, sea) |
||||||
|
if len(mycnf) > 100: |
||||||
|
mw.writeFile(db_path + '/etc/my.cnf', mycnf) |
||||||
|
|
||||||
|
endDate = time.strftime('%Y/%m/%d %X', time.localtime()) |
||||||
|
outTime = time.time() - startTime |
||||||
|
pid = mw.M('databases').dbPos(db_path, db_name).where( |
||||||
|
'name=?', (name,)).getField('id') |
||||||
|
|
||||||
|
mw.M('backup').add('type,name,pid,filename,addtime,size', (1, os.path.basename( |
||||||
|
filename), pid, filename, endDate, os.path.getsize(filename))) |
||||||
|
log = "数据库[" + name + "]备份成功,用时[" + str(round(outTime, 2)) + u"]秒" |
||||||
|
mw.writeLog('计划任务', log) |
||||||
|
print("★[" + endDate + "] " + log) |
||||||
|
print("|---保留最新的[" + count + "]份备份") |
||||||
|
print("|---文件名:" + filename) |
||||||
|
|
||||||
|
# 清理多余备份 |
||||||
|
backups = mw.M('backup').where( |
||||||
|
'type=? and pid=?', ('1', pid)).field('id,filename').select() |
||||||
|
|
||||||
|
num = len(backups) - int(count) |
||||||
|
if num > 0: |
||||||
|
for backup in backups: |
||||||
|
mw.execShell("rm -f " + backup['filename']) |
||||||
|
mw.M('backup').where('id=?', (backup['id'],)).delete() |
||||||
|
num -= 1 |
||||||
|
print("|---已清理过期备份文件:" + backup['filename']) |
||||||
|
if num < 1: |
||||||
|
break |
||||||
|
|
||||||
|
def backupDatabaseAll(self, save): |
||||||
|
db_path = mw.getServerDir() + '/mysql-ya' |
||||||
|
db_name = 'mysql' |
||||||
|
databases = mw.M('databases').dbPos( |
||||||
|
db_path, db_name).field('name').select() |
||||||
|
for database in databases: |
||||||
|
self.backupDatabase(database['name'], save) |
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__": |
||||||
|
backup = backupTools() |
||||||
|
type = sys.argv[1] |
||||||
|
if type == 'database': |
||||||
|
if sys.argv[2] == 'ALL': |
||||||
|
backup.backupDatabaseAll(sys.argv[3]) |
||||||
|
else: |
||||||
|
backup.backupDatabase(sys.argv[2], sys.argv[3]) |
@ -0,0 +1,119 @@ |
|||||||
|
# -*- coding: utf-8 -*- |
||||||
|
#!/bin/bash |
||||||
|
|
||||||
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin |
||||||
|
export PATH |
||||||
|
|
||||||
|
#https://dev.mysql.com/downloads/mysql/5.7.html |
||||||
|
#https://dev.mysql.com/downloads/file/?id=489855 |
||||||
|
|
||||||
|
curPath=`pwd` |
||||||
|
rootPath=$(dirname "$curPath") |
||||||
|
rootPath=$(dirname "$rootPath") |
||||||
|
serverPath=$(dirname "$rootPath") |
||||||
|
sysName=`uname` |
||||||
|
|
||||||
|
|
||||||
|
install_tmp=${rootPath}/tmp/mw_install.pl |
||||||
|
mysqlDir=${serverPath}/source/mysql |
||||||
|
|
||||||
|
|
||||||
|
_os=`uname` |
||||||
|
if [ ${_os} == "Darwin" ]; then |
||||||
|
OSNAME='macos' |
||||||
|
elif grep -Eqi "CentOS" /etc/issue || grep -Eq "CentOS" /etc/*-release; then |
||||||
|
OSNAME='centos' |
||||||
|
elif grep -Eqi "Rocky" /etc/issue || grep -Eq "Rocky" /etc/*-release; then |
||||||
|
OSNAME='rocky' |
||||||
|
elif grep -Eqi "Red Hat Enterprise Linux Server" /etc/issue || grep -Eq "Red Hat Enterprise Linux Server" /etc/*-release; then |
||||||
|
OSNAME='rhel' |
||||||
|
elif grep -Eqi "Aliyun" /etc/issue || grep -Eq "Aliyun" /etc/*-release; then |
||||||
|
OSNAME='aliyun' |
||||||
|
elif grep -Eqi "Fedora" /etc/issue || grep -Eq "Fedora" /etc/*-release; then |
||||||
|
OSNAME='fedora' |
||||||
|
elif grep -Eqi "Amazon Linux AMI" /etc/issue || grep -Eq "Amazon Linux AMI" /etc/*-release; then |
||||||
|
OSNAME='amazon' |
||||||
|
elif grep -Eqi "Debian" /etc/issue || grep -Eq "Debian" /etc/*-release; then |
||||||
|
OSNAME='debian' |
||||||
|
elif grep -Eqi "Ubuntu" /etc/issue || grep -Eq "Ubuntu" /etc/*-release; then |
||||||
|
OSNAME='ubuntu' |
||||||
|
elif grep -Eqi "Raspbian" /etc/issue || grep -Eq "Raspbian" /etc/*-release; then |
||||||
|
OSNAME='raspbian' |
||||||
|
elif grep -Eqi "Deepin" /etc/issue || grep -Eq "Deepin" /etc/*-release; then |
||||||
|
OSNAME='deepin' |
||||||
|
else |
||||||
|
OSNAME='unknow' |
||||||
|
fi |
||||||
|
|
||||||
|
VERSION_ID=`cat /etc/*-release | grep VERSION_ID | awk -F = '{print $2}' | awk -F "\"" '{print $2}'` |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
YUM_INSTALL() |
||||||
|
{ |
||||||
|
####### |
||||||
|
#http://repo.mysql.com/ |
||||||
|
|
||||||
|
if [ "${OSNAME}" == "centos" ] && [ "${VERSION_ID}" -le "7" ] ;then |
||||||
|
wget -O /tmp/mysql57-community-release-el${VERSION_ID}.rpm http://repo.mysql.com/mysql57-community-release-el${VERSION_ID}.rpm |
||||||
|
rpm -ivh /tmp/mysql57-community-release-el${VERSION_ID}.rpm |
||||||
|
yum -y install mysql-server |
||||||
|
rm -rf /tmp/mysql57-community-release-el${VERSION_ID}.rpm |
||||||
|
fi |
||||||
|
####### |
||||||
|
} |
||||||
|
|
||||||
|
YUM_UNINSTALL() |
||||||
|
{ |
||||||
|
### YUM卸载 START ######## |
||||||
|
yum remove -y mysql-server |
||||||
|
### YUM卸载 END ######## |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Install_mysql() |
||||||
|
{ |
||||||
|
|
||||||
|
echo '正在安装脚本文件...' > $install_tmp |
||||||
|
|
||||||
|
if id mysql &> /dev/null ;then |
||||||
|
echo "mysql UID is `id -u mysql`" |
||||||
|
echo "mysql Shell is `grep "^mysql:" /etc/passwd |cut -d':' -f7 `" |
||||||
|
else |
||||||
|
groupadd mysql |
||||||
|
useradd -g mysql mysql |
||||||
|
fi |
||||||
|
|
||||||
|
isYum=`which yum` |
||||||
|
if [ "$isYum" != "" ];then |
||||||
|
YUM_INSTALL |
||||||
|
fi |
||||||
|
|
||||||
|
if [ "$?" == "0" ];then |
||||||
|
mkdir -p $serverPath/mysql-yum |
||||||
|
echo '5.7' > $serverPath/mysql-yum/version.pl |
||||||
|
echo '安装完成' > $install_tmp |
||||||
|
else |
||||||
|
echo "暂时不支持该系统" > $install_tmp |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
Uninstall_mysql() |
||||||
|
{ |
||||||
|
isYum=`which yum` |
||||||
|
if [ "$isYum" != "" ];then |
||||||
|
YUM_UNINSTALL |
||||||
|
fi |
||||||
|
|
||||||
|
|
||||||
|
rm -rf $serverPath/mysql-yum |
||||||
|
echo '卸载完成' > $install_tmp |
||||||
|
} |
||||||
|
|
||||||
|
action=$1 |
||||||
|
if [ "${1}" == 'install' ];then |
||||||
|
Install_mysql |
||||||
|
else |
||||||
|
Uninstall_mysql |
||||||
|
fi |
@ -0,0 +1,121 @@ |
|||||||
|
# -*- coding: utf-8 -*- |
||||||
|
#!/bin/bash |
||||||
|
|
||||||
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin |
||||||
|
export PATH |
||||||
|
|
||||||
|
#https://dev.mysql.com/downloads/mysql/5.7.html |
||||||
|
#https://dev.mysql.com/downloads/file/?id=489855 |
||||||
|
|
||||||
|
curPath=`pwd` |
||||||
|
rootPath=$(dirname "$curPath") |
||||||
|
rootPath=$(dirname "$rootPath") |
||||||
|
serverPath=$(dirname "$rootPath") |
||||||
|
sysName=`uname` |
||||||
|
|
||||||
|
|
||||||
|
install_tmp=${rootPath}/tmp/mw_install.pl |
||||||
|
mysqlDir=${serverPath}/source/mysql |
||||||
|
|
||||||
|
|
||||||
|
_os=`uname` |
||||||
|
if [ ${_os} == "Darwin" ]; then |
||||||
|
OSNAME='macos' |
||||||
|
elif grep -Eqi "CentOS" /etc/issue || grep -Eq "CentOS" /etc/*-release; then |
||||||
|
OSNAME='centos' |
||||||
|
elif grep -Eqi "Rocky" /etc/issue || grep -Eq "Rocky" /etc/*-release; then |
||||||
|
OSNAME='rocky' |
||||||
|
elif grep -Eqi "Red Hat Enterprise Linux Server" /etc/issue || grep -Eq "Red Hat Enterprise Linux Server" /etc/*-release; then |
||||||
|
OSNAME='rhel' |
||||||
|
elif grep -Eqi "Aliyun" /etc/issue || grep -Eq "Aliyun" /etc/*-release; then |
||||||
|
OSNAME='aliyun' |
||||||
|
elif grep -Eqi "Fedora" /etc/issue || grep -Eq "Fedora" /etc/*-release; then |
||||||
|
OSNAME='fedora' |
||||||
|
elif grep -Eqi "Amazon Linux AMI" /etc/issue || grep -Eq "Amazon Linux AMI" /etc/*-release; then |
||||||
|
OSNAME='amazon' |
||||||
|
elif grep -Eqi "Debian" /etc/issue || grep -Eq "Debian" /etc/*-release; then |
||||||
|
OSNAME='debian' |
||||||
|
elif grep -Eqi "Ubuntu" /etc/issue || grep -Eq "Ubuntu" /etc/*-release; then |
||||||
|
OSNAME='ubuntu' |
||||||
|
elif grep -Eqi "Raspbian" /etc/issue || grep -Eq "Raspbian" /etc/*-release; then |
||||||
|
OSNAME='raspbian' |
||||||
|
elif grep -Eqi "Deepin" /etc/issue || grep -Eq "Deepin" /etc/*-release; then |
||||||
|
OSNAME='deepin' |
||||||
|
else |
||||||
|
OSNAME='unknow' |
||||||
|
fi |
||||||
|
|
||||||
|
VERSION_ID=`cat /etc/*-release | grep VERSION_ID | awk -F = '{print $2}' | awk -F "\"" '{print $2}'` |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
YUM_INSTALL() |
||||||
|
{ |
||||||
|
####### |
||||||
|
|
||||||
|
if [ "${OSNAME}" == "centos" ];then |
||||||
|
wget -O /tmp/mysql80-community-release.rpm http://repo.mysql.com/mysql80-community-release-el${VERSION}.rpm |
||||||
|
else |
||||||
|
wget -O /tmp/mysql80-community-release.rpm http://repo.mysql.com/mysql80-community-release-el8.rpm |
||||||
|
fi |
||||||
|
rpm -ivh /tmp/mysql80-community-release.rpm |
||||||
|
yum -y install mysql-server |
||||||
|
|
||||||
|
rm -rf /tmp/mysql80-community-release.rpm |
||||||
|
####### |
||||||
|
} |
||||||
|
|
||||||
|
YUM_UNINSTALL() |
||||||
|
{ |
||||||
|
### YUM卸载 START ######## |
||||||
|
yum -y remove mysql-server |
||||||
|
### YUM卸载 END ######## |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
Install_mysql() |
||||||
|
{ |
||||||
|
|
||||||
|
echo '正在安装脚本文件...' > $install_tmp |
||||||
|
|
||||||
|
if id mysql &> /dev/null ;then |
||||||
|
echo "mysql UID is `id -u mysql`" |
||||||
|
echo "mysql Shell is `grep "^mysql:" /etc/passwd |cut -d':' -f7 `" |
||||||
|
else |
||||||
|
groupadd mysql |
||||||
|
useradd -g mysql mysql |
||||||
|
fi |
||||||
|
|
||||||
|
isYum=`which yum` |
||||||
|
if [ "$isYum" != "" ];then |
||||||
|
YUM_INSTALL |
||||||
|
fi |
||||||
|
|
||||||
|
|
||||||
|
if [ "$?" == "0" ];then |
||||||
|
mkdir -p $serverPath/mysql-yum |
||||||
|
echo '8.0' > $serverPath/mysql-yum/version.pl |
||||||
|
echo '安装完成' > $install_tmp |
||||||
|
else |
||||||
|
echo "暂时不支持该系统" > $install_tmp |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
Uninstall_mysql() |
||||||
|
{ |
||||||
|
isYum=`which yum` |
||||||
|
if [ "$isYum" != "" ];then |
||||||
|
YUM_UNINSTALL |
||||||
|
fi |
||||||
|
|
||||||
|
|
||||||
|
rm -rf $serverPath/mysql-ya |
||||||
|
echo '卸载完成' > $install_tmp |
||||||
|
} |
||||||
|
|
||||||
|
action=$1 |
||||||
|
if [ "${1}" == 'install' ];then |
||||||
|
Install_mysql |
||||||
|
else |
||||||
|
Uninstall_mysql |
||||||
|
fi |
Loading…
Reference in new issue