1. 程式人生 > 其它 >MySQL Tools 之 mysql.server 指令碼運用--轉發

MySQL Tools 之 mysql.server 指令碼運用--轉發

目錄


正文

MySQL distributions on Unix and Unix-like system include a script named mysql.server, which starts the MySQL server using mysqld_safe. It can be used on systems such as Linux and Solaris that use System V-style run directories to start and stop system services. It is also used by the macOS Startup Item for MySQL.

mysql.server是官方針對Unix和類Unix系統二進位制版本安裝包當中包含的指令碼,它是一個SHELL指令碼,被用來啟動、檢視和停止mysqld程序服務。mysql.server其實上呼叫的是mysqld_safe命令。

更詳細的關於mysql.server的說明可以參考官方文件:https://dev.mysql.com/doc/refman/5.7/en/mysql-server.html

本文使用的MySQL版本為5.7.21

# mysqld -V
mysqld  Ver 5.7.21 for linux-glibc2.12 on x86_64 (MySQL Community Server (GPL))
  • 如果使用RPM包的安裝方式進行安裝MySQL後,mysql.server這個指令碼會被放在/etc/init.d/下面,並且命名為mysqld或者mysql
  • 如果是二進位制包的安裝方式,則mysql.server放在二進位制安裝目錄下support-files的目錄下面。
回到頂部

主要用法

  • 1、啟動mysqld服務
# mysql.server start      
  • 2、檢視mysqld狀態
# mysql.server status
  • 3、停止mysqld服務
# mysql.server stop
  • 4、重啟mysqld服務
# mysql.server restart
  • 5、平滑重啟mysqld服務
# mysql.server reload
回到頂部

自定義

mysql.server是一個SHELL指令碼,其中有一些選項在沒有明確指定的時候是有預設值,比如basedir預設路徑為/usr/local/mysql等。通常以二進位制包進行安裝的時候,有些路徑需要自定義,否則mysql.server無法找到相應的路徑,也就無法完成mysqld程序服務的管理。

可以通過VIM等編輯器對mysql.server指令碼進行編輯與修改。

主要修改選項路徑如下:

回到頂部

1、新增basedir、datadir和config配置

大概在mysql.server指令碼的43行處。

43 # If you change base dir, you must also change datadir. These may get                                                  
44 # overwritten by settings in the MySQL configuration files.                                                            
45                                                                                                                        
46 basedir=     #二進位制包安裝的目錄                                                                                       
47 datadir=     #資料檔案所在的目錄
48 config=      #此處為新增選項,配置需要使用的引數檔案路徑 

此處可以修改為:

basedir=/usr/local/mysql5.7
datadir=/data/mysql/data
config=/data/mysql/3306/my.cnf

回到頂部

2、指定mysqld的PID檔案

 61 # The following variables are only set for letting mysql.server find things.
 62 
 63 # Set some defaults
 64 mysqld_pid_file_path=

此處可以修改為:

61 # The following variables are only set for letting mysql.server find things.
62 
63 # Set some defaults
64 mysqld_pid_file_path=/data/mysql/3306/mysql.pid
回到頂部

3、註釋解析預設引數檔案方法

mysqld啟動時,預設尋找的引數檔案路徑如下:

/etc/my.cnf ---> /etc/mysql/my.cnf ---> /usr/local/mysql/etc/my.cnf ---> ~/.my.cnf

mysql.server指令碼預設會按照這個順序去解析(通過my_print_defaults這個命令實現)這幾個引數檔案,而為了防止mysql.server去解析這幾個引數檔案當中的引數選項,這時還是通過修改mysql.server指令碼選項來實現,以便於使用自定義的引數檔案。

大概在mysql.server指令碼的240行處。

229 #
230 # Read defaults file from 'basedir'.   If there is no defaults file there
231 # check if it's in the old (depricated) place (datadir) and read it from there
232 #
233 
234 extra_args=""
235 if test -r "$basedir/my.cnf"
236 then
237   extra_args="-e $basedir/my.cnf"
238 fi
239 
240 parse_server_arguments `$print_defaults $extra_args mysqld server mysql_server mysql.server`

可以註釋240行,如下:

…………省略…………
237   extra_args="-e $basedir/my.cnf"
238 fi
239 
240 # 註釋這行
240 # parse_server_arguments `$print_defaults $extra_args mysqld server mysql_server mysql.server`

這樣當通過mysql.server來啟動mysqld時就不會去解析預設路徑下的引數檔案

回到頂部

4、修改mysqld_safe啟動時的引數檔案

預設情況下mysqld_safe啟動時是沒有選項--defaults-file指定引數的。可以新增這個選項指定所需的引數路徑。

大概在mysql.server指令碼的264行處。

264 # Give extra arguments to mysqld with the my.cnf file. This script
265 # may be overwritten at next upgrade.
266 $bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null &
267 wait_for_pid created "$!" "$mysqld_pid_file_path"; return_value=$?
268 

可以新增conf配置:

# 此處配置的引數檔案為前面新增選項的引數檔案
266 $bindir/mysqld_safe --defaults-file="$config" --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null &

至此,現在可以通過mysql.server來管理mysqld程序服務的狀態了,也可以放在/etc/init.d/下當作系統服務進行管理,當然前提是這個指令碼必須具備可執行許可權。

回到頂部

參考

☆〖本人水平有限,文中如有錯誤還請留言批評指正!〗☆