MySQL Tools 之 mysql.server 腳本運用

来源:https://www.cnblogs.com/dbabd/archive/2019/06/30/11111757.html
-Advertisement-
Play Games

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 ...


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/下當作系統服務進行管理,當然前提是這個腳本必須具備可執行許可權。

參考

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Window Server 2008 R2 FTP服務用戶隔離 原題:安裝FTP服務,新建一個FTP站點,主目錄為C:\ftproot,通過適當技術實現用戶soft1 與soft2通過匿名方式登錄FTP站點時,只能瀏覽到“Public”子目錄中的內容,若用個人賬號登錄FTP站點,則只能訪問自己的子文 ...
  • 1. 創建同步文件 參考清華的Centos源,配置同步文件。https://mirrors.tuna.tsinghua.edu.cn/help/centos/ 2. 同步源到本地文件夾(此文件夾需要結合nginx 配置成網路可訪問的文件伺服器:nginx location 配置詳解) 3. 創建 r ...
  • 1、常見Linux的發行版有哪些?並描述不同發行版之間的聯繫與區別。 linux的發行版: Fedora,Debian,Ubuntu,Red Hat Linux,CentOS 不同發行版之間的聯繫和區別: Fedora:從Red Hat Linux發展出來的免費Linux系統Debian:以其穩定性 ...
  • 什麼是DHCP伺服器? DHCP伺服器(動態主機配置協議)指的是:由伺服器控制一段IP地址範圍,客戶機登錄伺服器時就可以自動獲得伺服器分配的IP地址和子網掩碼。首先, DHCP伺服器必須是一臺安裝有Windows 2000 Server/Advanced Server系統的電腦;其次,擔任DHCP ...
  • AD文件轉換為KiCAD的兩種方法: ...
  • MySQL——在Windows下安裝MySQL 摘要:本文主要說明瞭如何下Windows環境下安裝MySQL。 查看電腦上是否安裝了MySQL 打開cmd視窗,輸入 services.msc 命令,等待服務界面打開: 如果能在服務中找到MySQL服務,則說明系統已經安裝了MySQL: 下載並安裝 下 ...
  • 本文主要記錄了在使用MySQL的過程中遇到的問題以及解決方案。 ...
  • --笛卡爾集select empno,ename, 員工表.deptno, 部門表.deptno, dname from 部門表, 員工表; --添加合適的條件,可以避免笛卡爾集,從而得到正確的多表查詢記錄select empno,ename, 員工表.deptno, 部門表.deptno, dna ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...