記一次Linux修改MySQL配置不生效的問題

来源:https://www.cnblogs.com/xiao2shiqi/archive/2019/08/19/11376969.html
-Advertisement-
Play Games

背景 自己手上有一個項目服務用的是AWS EC2,最近從安全性和性能方面考慮,最近打算把騰訊雲的MySQL資料庫遷移到AWS RDS上,因為AWS的出口規則和安全組等問題,我需要修改預設的3306埠和Bind Address限制特定的IP訪問,我在Stackoverflow上查詢瞭如何修改,但是網 ...


database.jpg

背景

自己手上有一個項目服務用的是AWS EC2,最近從安全性和性能方面考慮,最近打算把騰訊雲的MySQL資料庫遷移到AWS RDS上,因為AWS的出口規則和安全組等問題,我需要修改預設的3306埠和Bind Address限制特定的IP訪問,我在Stackoverflow上查詢瞭如何修改,但是網上的資料大多比較老舊,不符合目前主流的MySQL版本(使用的MySQL 5.7.27,操作系統使用Ubuntu 18.04.1 LTS)

過程

在 Stackoverflow上的高票回答很簡單,修改只需要三步就可以完成

/etc/my.cnf      // 找到配置文件
port = 3306     // 修改內容
sudo service mysql restart      // 重啟MySQL

但實時並沒有那麼簡單,以上答案可能對舊版本管用,但是新版本你在/etc/my.cnf下根本找不到任何東西,文件都不存在

然後我去查閱的官方文檔,找到的配置文件原來在目錄:/etc/mysql/my.cnf 下,但是不要覺得找到配置文件就萬事大吉,當你打開文件你會看到畫風變了,因為配置文件裡面沒有內容,而是引用了另外2個配置文件夾,/etc/mysql/my.cnf 具體內容是這樣的

!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/

可以,至少有線索了,順著路徑去找,在2個目錄下每個文件都看了下,最後看到 mysql.conf.d/mysqld.cnf 似乎是我們要找的文件(官方文檔也驗證了這一點),打開可以看到我們需要修改的文件屬性

[mysqld]
prot = 3306
bind-address = 127.0.0.1        // 只允許本機訪問

改成我需要的的配置參數後,我以為事情到這裡就結束了,當我使用 sudo service mysql restart 重啟服務的時候,我發現我的內網機器還是訪問不了,我使用 netstat -ntlp 查看 Local Address,Foregin Address,發現我修改的配置後的配置沒有生效,我陷入的深深的自我懷疑當中,仿佛線索在這裡中斷了

然後,有網友說提到說有可能是文件許可權問題,如果文件許可權過大(全局可寫),MySQL 會出現安全考慮不會讀取該配置文件,而且讀取自身的配置副本文件,我執行命令,如看如下警告

mysql --help | grep my.cnf
mysql: [Warning] World-writable config file '/etc/mysql/mysql.conf.d/mysqld.cnf' 
is ignored.
                      order of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf ~/.my.cnf

上面是指文件由於全局可寫存在風險,被MySQL忽略,並且列出MySQL讀取配置文件的順序,這裡是可以看到MySQL是存在多個my.cnf配置文件,有些是全局配置,有些是局部配置,找到線索後,處理起來就簡單很多了,我們更改文件許可權,再看看 mysql --help 就發現警告已經沒有了,具體命令如下:

sudo chmod 644 /etc/mysql/mysql.conf.d/mysqld.cnf
mysql --help | grep my.cnf
                      order of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf ~/.my.cnf

然後再執行 sudo service mysql restart,然後再看看 Local Address 和 Foreign Address 已經變成我們在my.cnf配置的內容,但是修改後的配置已經成功生效,確認是文件全局可讀的安全問題導致

總結

最後是關於 MySQL 的安全規則導致修改配置不生效,當然這條規則,大部分情況下我們是不知道的(如果沒有完整閱讀官網文檔的話),在經過這次問題,我大概有如下幾點總結,幫助大家在排查問題上少走彎路,儘快找到真實的問題:

  1. 遇到問題首先應該看官網的最新文檔
  2. 查看資料時間,網上很多資料時間太長,可能會誤導你
  3. 認真查看警告信息,熟練掌握排查工具和命令
  4. 基礎知識很重要,越是深的問題越考驗程式員的內功

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

-Advertisement-
Play Games
更多相關文章
  • 來博客園是比較激動地,主要是想通過播客記錄自己的學習歷程,掌握的知識點,遇到的疑難,認識更多的朋友,分享更多的知識和技能。 歷經很久的糾結,終於正式下定決心轉行前端。問朋友,問同學,問老師,問網友最後覺得這是比較適合自己的路。目前是在做自動化方面的工作,薪資雖還行,但沒啥技術含量和發展空間,思慮良久 ...
  • 用for迴圈或者forEach遍曆數組的話,在刪除第一個元素的時候,會導致數組改變,從而導致splice中的i不是想要的i,解決方法是用filter或者逆向迴圈 1、使用filter 2、使用逆向迴圈 let arr = [2, 3, 5, 7] for (let i = arr.length - ...
  • 問題:由於業務需要,我們需要判斷圖片能否正常的載入,如果未正常載入的話,需要顯示一張預設圖片; 方案:1,由於後臺返回的是一個圖片id數組,例如 imgList=['343313131','21333413244','3312w232211'],圖片的完整路徑應為http://公司伺服器地址/xxx ...
  • Redux是一個可預測的狀態容器,提供可預測的狀態管理。 什麼是狀態?狀態其實也就是數據,管理狀態也就是對數據的管理。那麼什麼是可預測的狀態管理呢?能夠監聽數據的變化,獲取變化的來源,在發生變化時可以觸發某些動作,即為狀態管理(個人理解)。 如上所示,就是一個最簡單的狀態管理,實現了數據基本的管理, ...
  • 在標簽中經常會用到alt標簽,這對於seo的優化是有一定的幫助。 ...
  • 本篇筆記只敘述 var 與 let 的區別 var 是可以進行變數的提升的,好比先定義一個變數,不指定類型,後面再用 var 來聲明它,於是它從無類型變成了有類型,但是這樣是不好的 當你使用 var 時,可以根據需要多次聲明相同名稱的變數,但是 let 不能。 而對面 let 來說,它更像我們學的 ...
  • jQueryt靜態方法詳解 ==> each ==> map ==> trim ==> isArray ==> isFunction ==> isWindow ==> holdReady 一,each方法 註:為了更好的展示,首先創建一個數組和一個對象 (let 與 arr 區別詳解見 JavaSc ...
  • 分散式事務的挑戰 在多個服務、資料庫和消息代理之間維持數據的一致性的傳統方式是採用分散式事務。分散式的事實標註是XA、XA採用了兩階段提交老保證事務中的所有參與方同時完成提交,或者失敗時同時回滾。應用程式的整個技術棧需要滿足XA標準。 許多新技術,包括NoSQLshujk ,liru MongoDB ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...