Centos7 安裝Mysql-尋找共性-萬變不離其宗

安裝 Mysql 服務的文章數不勝數,本文的不同之處在于

提煉安裝 Mysql 服務的共性之處。

追尋道的規律和術的方法

閱讀本文你將了解到

  • 服務器安裝 Mysql 服務的兩種方式
  • Mysql 服務 基本的初始化操作步驟
  • Mysql5.7 在安裝過程中的更新細節

確認基礎環境

首先確認服務器 版本環境,這個至關重要

cat /etc/redhat-release

CentOS Linux release 7.6.1810 (Core)

安裝方式

通常安裝方式有兩種,Docker 安裝不在討論范圍

  • 源碼安裝
  • 使用編譯包安裝

使用源碼包安裝

下載源截圖,本文中不介紹這種安裝方式

源碼安裝

使用編譯包安裝

mysql57

構建服務器目錄

源碼路徑

/usr/local/mysql

執行用戶

mysql

chown -R mysql:mysql /usr/local/mysql

啟動腳本

cd /usr/local/mysql

第一點 mysql5.7 與其它版本的區別

5.7.x 之后的版本初始化數據庫不再使用 mysql_install_db,而是使用: bin/mysqld --initialize.

不推薦的版本

./scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql

初始化腳本

./mysqld --initialize --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql   --mysqld_safe --basedir=/usr/local/mysql

Can't find error-message file '/usr/local/mysql/share/errmsg.sys

原因 /usr/local/mysql 目錄下應該包含原始安裝文件

./mysqld --initialize --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  --user=mysql
2019-08-24T00:40:14.925998Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2019-08-24T00:40:16.935351Z 0 [Warning] InnoDB: New log files created, LSN=45790
2019-08-24T00:40:17.323153Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2019-08-24T00:40:17.435647Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: be7ba77f-c607-11e9-adc8-525400cff66a.
2019-08-24T00:40:17.441071Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
2019-08-24T00:40:17.441884Z 1 [Note] A temporary password is generated for root@localhost: 1aauQhoscU_k

構建 mysqld

了解兩個概念

  • mysql
  • mysqld

眾所周知 Mysql 數據庫是一個客戶端服務器架構的服務.

服務器端啟動 mysql 服務后,會生成 mysqld 服務。

客戶端如果想連接服務端,使用 mysql 工具,在終端命令行模式下運行,

總結下來就是下面兩句話:

mysqld - it's a server daemon. this is the database server main binary (executable)
MYSQL 服務

mysql - it's a commandline (administration) tool

命令行工具

第二點 mysql5.7 與其它版本的區別

從 5.7.18 開始不在二進制包中提供 my-default.cnf 文件

[client]
port = 3355
;socket = /data/3355/mysql.sock

[mysqld]
basedir = /usr/mysql
datadir = /usr/mysql/data
;socket = /tmp/mysql.sock
log-error = /usr/local/mysql/data/error.log
#臨時目錄 比如load data infile會用到
tmpdir  = /tmp
symbolic-links = 0
max-connections = 320
connect_timeout = 20
#數據庫默認字符集,主流字符集支持一些特殊表情符號(特殊表情符占用4個字節)
character-set-server = utf8mb4

#數據庫字符集對應一些排序等規則,注意要和character-set-server對應
collation-server = utf8mb4_general_ci

#設置client連接mysql時的字符集,防止亂碼
init_connect=‘SET NAMES utf8mb4‘

設置開機啟動

移動可執行文件 并改名

cp mysql.server  /etc/init.d/
cd /etc/init.d/
mv mysql.server mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld

啟動 mysql

service mysqld start

初始化密碼

You must reset your password using ALTER USER statement before executing this statement

ALTER USER USER() IDENTIFIED BY '123456';

第三點

這條命令是 5.7 和 5.6 區別之一

MySQL 5.7.4 版開始,用戶的密碼過期時間這個特性得以改進。

可以通過一個全局變量 default_password_lifetime 來設置密碼過期的策略。

此全局變量可以設置一個全局的自動密碼過期策略。

在 MySQL 的 my.cnf 配置文件中設置一個默認值,這會使得所有 MySQL 用戶的密碼過期時間都為 120 天。

MySQL 會從啟動時開始計算時間。

繼續執行命令

update user set authentication_string=password('123456') where user='root'
flush privileges;

開放外網連接權限

use mysql;

update user set host = '%' where user = 'root'; (使 mysql root 用戶可以連接上任意的 ip 地址)

FLUSH PRIVILEGES

疑難雜癥排查

重啟服務器造成的 mysql 服務啟動失敗

service mysqld start
Starting MySQL.. ERROR! The server quit without updating PID file (/usr/local/mysql/data/10-9-77-82.pid).

看提示是 PID 文件丟失

解決方案

  • 首先查看磁盤使用量

df -h

/dev/vda1 20G 20G 12M 100% /
devtmpfs 923M 0 923M 0% /dev
tmpfs 934M 0 934M 0% /dev/shm
tmpfs 934M 17M 917M 2% /run
tmpfs 934M 0 934M 0% /sys/fs/cgroup
tmpfs 187M 0 187M 0% /run/user/0

這次是磁盤的問題導致

修改主賬號密碼區別

  • 修改主賬號密碼

UPDATE user SET password=PASSWORD("新密碼") WHERE user='你的用戶名';
出現字段找不到的錯誤

Unknown column 'password' in 'field list'

解決方案

采用如下語句來更新,新版本 mysql 采用 authentication_string 替代了 password 字段

update mysql.user set authentication_string=password('root') where user='root' ;

flush privileges;

 quit;
  • 重新啟動 mysql
  service mysql restart

服務啟動完成

本文列舉安裝 Mysql 服務的幾個錯誤和排查思路。實際生產環境中需要從具體的日志,用戶等多個方面考慮。

分析總結

軟件開發流程中,服務器相關服務安裝維護屬于運維的職責。

作為軟件開發工程師,卻是繞不過去的一個環節。

實際的操作可以深入了解服務的運行機制。

像我之前文章 程序設計理念-CentOs7實踐Nginx-帶來安裝服務的通用法則
中介紹的那樣

輸出 Linux 上安裝服務的通用法則

  • 1 確定服務器環境
  • 2 確定待安裝服務的安裝方式和安裝版本
  • 3 確定服務運行賬戶和相應的配置
  • 4 確定服務正常啟動運行
  • 5 確定是否自啟動

以上同樣適用于 Redis PHP 等服務的安裝。

我是王明明,互聯網技術開發者,閱讀寫作實踐者。

輸出我的技術思想,探索個人品牌實踐之路,期待認識優秀的你。

圖南日晟-互聯網技術服務
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。