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