(1)MySQL進階篇在linux環境下安裝
1.概述
對於mysql二進位制安裝,優點是可以安裝到任何路徑下,靈活性好,一臺伺服器可以安裝多個mysql。缺點是已經編譯過,效能不如原始碼編譯得好,不能靈活定製編譯引數。如果使用者即不想安裝最簡單卻不夠靈活的RPM包,又不想安裝複雜費時的原始碼包,那麼已編譯好的二進位制包將是最好的選擇,下面讓我們來介紹如何在linux系統下安裝mysql服務端。
2.前期準備
2.1下載mysql二進位制安裝包
mysql官網:https://dev.mysql.com/downloads/mysql/
因為我下載的是mysql-8.0.23-linux-glibc2.12-x86_64.tar版本,如果有最新版本,則下載最新版本就好了。
2.2匯入mysql二進位制安裝包
通過Xftp工具把安裝包傳輸到linux系統package目錄去:
3.mysql部署
●解壓mysql安裝包
--切換到安裝目錄 cd /app --解壓xz壓縮檔案 tar -xvf /app/package/mysql-8.0.23-linux-glibc2.12-x86_64.tar.xz
●修改mysql資料夾名稱
--把mysql-8.0.23-linux-glibc2.12-x86_64修改為mysql資料夾名稱 mv /app/mysql-8.0.23-linux-glibc2.12-x86_64 /app/mysql
●建立data目錄
--在mysql根目錄下建立data目錄,用於存放資料 mkdir /app/mysql/data
●建立mysql使用者組和mysql使用者
--建立mysql使用者組和mysql使用者 groupadd mysql useradd -g mysql mysql
●修改mysql目錄許可權
--修改mysql目錄許可權 chown -R mysql.mysql /app/mysql/
●初始化資料庫
--先切換到mysql安裝目錄 cd /app/mysql --初始化資料庫 bin/mysqld --initialize --user=mysql --basedir=/app/mysql --datadir=/app/mysql/data
●配置mysql
--先切換到mysql.support-files目錄 cd /app/mysql/support-files --在mysql/support-files建立檔案my-default.cnf touch my-default.cnf --複製配置檔案到/etc/my.cnf cp -a ./my-default.cnf /etc/my.cnf --編輯my.cnf vim /etc/my.cnf
my.cnf輸入如下配置內容:
[client] port=3306 socket=/tmp/mysql.sock [mysqld] port=3306 user=mysql socket=/tmp/mysql.sock basedir=/app/mysql datadir=/app/mysql/data
●配置環境變數
--編輯profile檔案 vim /etc/profile --配置mysql環境變數 PATH=/data/mysql/bin:/data/mysql/lib:$PATH export PATH --使mysql環境變數生效 source /etc/profile --看環境變數是否生效 echo $PATH
●啟動mysql
cd /app/mysql/bin systemctl start mysqld or service mysql start
啟動mysql時候可能會遇到如下錯誤:
●Failed to start mysqld.service: Unit not found.
or
Starting MySQL.Logging to '/app/mysql/data/dengwu.err'.
... ERROR! The server quit without updating PID file (/app/mysql/data/dengwu.pid).
解決方法如下:
--需要安裝mariadb-server yum install -y mariadb-server --然後啟動mariadb服務 systemctl start mariadb.service --需要的可以新增mariadb服務開機啟動 systemctl enable mariadb.service
●Job for mariadb.service failed because the control process exited with error code. See "systemctl status mariadb.service" and "journalctl -xe" for details.
解決方法如下:
chown -R mysql.mysql /app/mysql/
●Starting MySQL... ERROR! The server quit without updating PID file (/app/mysql/data/dengwu.pid).
解決方法如下:
--檢視mysql程序 ps -ef|grep mysqld --殺死mysql程序 kill -9 mysql程序ID
然後重新啟動下mysql:
4.修改mysql密碼
root使用者第一次登入mysql,因為初始密碼我們並不知道,一般情況下我們都會重新設定一個新的密碼,具體操作如下:
--編輯my.cnf vim /etc/my.cnf
輸入如下命令列:
default_authentication_plugin=mysql_native_password
如果忘記了密碼再加上:
--跳過密碼驗證(等設定了密碼就去掉) skip-grant-tables
然後登入mysql:
--登入mysql mysql -u root -p
然後輸入命令檢視mysql使用者組:
--檢視mysql使用者表 select user,host,authentication_string from mysql.user;
看看root使用者沒有開啟遠端連線許可權,如果沒有則執行如下命令:
--修改root使用者可以遠端連線 update mysql.user set host='%' where user='root';
開啟遠端連線許可權後,再來修改root使用者密碼:
--如果host是localhost則@字元後面是localhost,反之則是%,以host結果為準 --修改加密規則 alter user 'root'@'%' identified by 'qwer1234' password expire never; --更新一下使用者的密碼 alter user 'root'@'%' identified with mysql_native_password by 'qwer1234'; --重新整理許可權 flush privileges; --修改root使用者密碼 alter user 'root'@'%' identified by 'qwer1234';
如果防火牆開啟了,則需要加入允許mysql埠訪問許可權,具體命令如下:
--允許訪問 firewall-cmd --permanent --zone=public --add-port=3306/tcp --重新載入 firewall-cmd --reload --檢視是否開通訪問許可權 firewall-cmd --permanent --zone=public --query-port=3306/tcp
然後重新啟動mysql:
--重新啟動mysql service mysql restart;
5.配置mysql阿里雲安全組策略
登入阿里雲->安全組規則->訪問規則->入方向->手動新增如下策略:
使用Navicat連線成功:
參考文獻:
linux下安裝mysql8.0.x