在 CentOS 7 中以命令行方式安裝 MySQL 5.7.11 for Linux Generic 二進位版本

来源:http://www.cnblogs.com/cyberniuniu/archive/2016/03/13/5273961.html
-Advertisement-
Play Games

MySQL 目前的最新版本是 5.7.11,在 Linux 下提供特定發行版安裝包(如 .rpm)以及二進位通用版安裝包(.tar.gz)。一般情況下,很多項目都傾向於採用二進位通用安裝包形式來進行安裝配置,自定義非常方便。但在安裝過程中發現,其實官方提供的安裝說明文件太過簡單,而且裡面的參數還有問


MySQL 目前的最新版本是 5.7.11,在 Linux 下提供特定發行版安裝包(如 .rpm)以及二進位通用版安裝包(.tar.gz)。一般情況下,很多項目都傾向於採用二進位通用安裝包形式來進行安裝配置,自定義非常方便。但在安裝過程中發現,其實官方提供的安裝說明文件太過簡單,而且裡面的參數還有問題,依照執行後,mysql 服務啟動報錯,查找了一些資料並反覆試驗後,自己總結出一套切實可行的安裝配置流程,具體如下:

1、下載 MySQL for Linux Generic 二進位版本安裝包(.tar.gz),這裡以 5.7.11 版本為例。

2、我一般習慣於將 MySQL 安裝到 /opt 目錄下,所以我將 MySQL 安裝包文件複製到 /opt 目錄下,切換為 root 賬號後執行以下命令:

# tar -zxvf mysql-5.7.11-linux-glibc2.5-x86_64.tar.gz
# ln -s mysql-5.7.11-linux-glibc2.5-x86_64 mysql 
# cd mysql

建立一個 mysql 的軟連接,是為了以後方便配置與操作。

3、5.7.11 版本的通用二進位安裝包經解壓後得到的 MySQL 目錄,內部並未包含數據文件存放的目錄,所以需要單獨再創建一個子目錄用於存放數據文件,比如取名為 data,在第二步命令後(確保在 /opt/mysql 目錄下),繼續執行如下命令:

# groupadd mysql
# useradd -r -g mysql -s /bin/false mysql
# mkdir data
# chown -R root:root .
# bin/mysqld --initialize --user=mysql --basedir=/opt/mysql --datadir=/opt/mysql/data
# bin/mysql_ssl_rsa_setup --datadir=/opt/mysql/data

這裡特別說明一下,根據官方文檔說法,從 5.7.6 版本開始,MySQL 初始化使用 mysqld --initialize 命令,不再使用 mysql_install_db 命令了。但是官方文檔給出的 mysqld --initialize 命令並沒有給出 --basedir 以及 --datadir 參數,因為它預設使用 /etc/my.cnf 配置文件。有些 Linux 發行版在安裝過程中可能會預設生成這個 mysql 配置文件並保存在 /etc 目錄下,而預設配置文件中的 basedir、datadir 是被註釋的,沒有實際內容,這樣 mysqld 實際上還是不知道當前的 basedir、datadir 具體是哪個目錄。所以這裡就通過命令行參數指定我們的自定義目錄。包括 mysql_ssl_rsa_setup 命令也要指定 datadir 目錄,因為資料庫需要的密鑰文件也都和數據文件保存在一起,都位於 datadir 目錄內。

4、上述工作完成後,先不慌啟動資料庫服務,這時還要創建 MySQL 服務的配置文件 my.cnf。這個文件可以從 /opt/mysql/support-files 子目錄下找到一個叫 my-default.cnf 的配置樣例文件,然後複製一個出來,改名為 my.cnf 並放到 /opt/mysql 下即可。根據 MySQL 的規則,它的配置文件必須以 my.cnf 命名,讀取的順序是先嘗試讀取 /etc/my.cnf,如果不存在則再讀取 basedir 目錄下的 my.cnf,如果系統環境變數沒有 basedir,則嘗試讀取服務啟動所在當前目錄下的 my.cnf,這裡就是 /opt/mysql/my.cnf 這種情況,如果還是不存在,則讀取當前用戶家目錄下的 .mysql/my.cnf(需要看官方文檔確認一下,記不清了)。所以,我們這裡只需保證在 /opt/mysql 下有一個 my.cnf,修改其中的內容為如下:

basedir = /opt/mysql
datadir = /opt/mysql/data
log-error = /var/log/mysql-error.log

其餘的不變。根據官方文檔,log-error 用來指定服務啟動後的運行信息日誌文件路徑,運行信息包括 Notice、Error 等類型的日誌。

5、配置文件修改保存好後,就可以啟動服務了,確保當前目錄為 /opt/mysql,然後運行以下命令:

# bin/msyqld_safe --user=mysql &

這時服務就可以正常啟動了。你還可以通過命令 netstat -na -t 查看 MySQL 服務的埠 3306 是否已經處在監聽狀態,如果是,則表示服務啟動正常。當然,你也可以查看日誌文件的內容來確定,我們這裡因為在已在配置文件中指定日誌文件為 /var/log/mysql-error.log,所以查看該文件即可。

6、在本機登錄 MySQL 服務,從 5.7.10 版本開始不允許 root 空密碼登錄了。其實在執行 mysqld --initialize 後系統就會為 root 生成一個初始化密碼,併在屏幕標準輸出時顯示出來,這個要記住!用這個密碼第一次登錄後,才能再修改密碼,這裡假定系統生成的初始化密碼為 xxxxxx,命令如下:

# bin/mysql --user=root --password=xxxxxx

這樣就可以登錄 MySQL 伺服器了。

7、登錄以後,系統要求必須修改 root 賬號的密碼,MySQL 命令如下:

mysql> set password=password('1234');

這樣就可以把 root 賬號改為 1234 了。

8、在 Linux 下為了安全,預設是不允許 MySQL 伺服器本機以外的機器訪問 MySQL 資料庫服務的,因此需要重新授權 root 賬號。方便其他機器遠程訪問 MySQL 伺服器,MySQL 命令如下:

mysql> grant all privileges on *.* to root@'%' identified by '1234';
mysql> flush privileges;

這樣就可以允許從其他機器用 root 賬號遠程登錄 MySQL 伺服器了,可以用下麵的 MySQL 命令來驗證一下:

mysql> use mysql;
mysql> select host,user from user;
+-----------+-----------+
| host      | user      |
+-----------+-----------+
| %         | root      |
| localhost | mysql.sys |
| localhost | root      |
+-----------+-----------+
3 rows in set (0.00 sec)

證明系統表 user 中已經增加了一條關於 root 遠程登錄的記錄。


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

-Advertisement-
Play Games
更多相關文章
  • 服務 服務沒有界面,一直運行在後臺, 運行在獨立的一個進程裡面 服務沒有界面,一直運行在後臺,預設是運行當前的應用程式進程裡面。 建立一個類繼承Service類 在清單文件中註冊service   只會在開啟服務時初始化一次   每次開啟服務都會執行調用   停止服務時,只執行一次   onCrea
  • 一、設置UITableView裡面的頂部 cell 距離頂部的間距的三種方式: 方法 1. 直接設置: self.tableView.contentInset = UIEdgeInsetsMake(HWStatusCellMargin, 0, 0, 0); @interface HWHomeView
  • 1. ARC裡面預設情況下所有指針都是強指針。 2. 在演示 設置兩個控制器的關係為 父子控制器的關係的時候,將一個控制器B 的view加到 A控制器的view上去的時候,如果A、B不為父子控制器的關係時,旋轉屏幕 的時候 B控制器是不能監聽到屏幕的旋轉的。只有A控制器可以監聽到屏幕旋轉。 3. 屏
  • sql server2000中使用convert來取得datetime數據類型樣式(全) 日期數據格式的處理,兩個示例: CONVERT(varchar(16), 時間一, 20) 結果:2007-02-01 08:02/*時間一般為getdate()函數或數據表裡的欄位*/ CONVERT(var
  • 獲取 資料庫 和 表信息: 確定MySQL支持哪些表類型:mysql> show variables like '%have%';直接得到表類型清單:mysql> show table types;
  • 出處:http://www.cnblogs.com/lzrabbit/archive/2012/05/21/2499389.html 小小程式猿SQL Server認知的成長 1.沒畢業或工作沒多久,只知道有資料庫、SQL這麼個東東,渾然分不清SQL和Sql Server Oracle、MySql的
  • 在csdn上也看到一個帖子叫Oracle常用函數110.大概的看了一下,裡面數據計算的居多,協方差之類的.自己覺得用到的不多,今天看到的這個,不是很全,稍微增加了一下,等以後用到的時候可以查看.
  • 在保密你的伺服器和數據,防備當前複雜的攻擊,SQL Server有你需要的一切。但在你能有效使用這些安全功能前,你需要理解你面對的威脅和一些基本的安全概念。這篇文章提供了基礎,因此你可以對SQL Server里的安全功能充分利用,不用在面對特定威脅,不能保護你數據的功能上浪費時間。 身份驗證是驗證主
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...