對於mysql二進制安裝,優勢是能夠安裝到任何路徑下,靈活性好,一臺服務器能夠安裝多個mysql。缺點是已經編譯過,性能不如源碼編譯得好,不能靈活定製編譯參數。若是用戶即不想安裝最簡單卻不夠靈活的RPM包,又不想安裝複雜費時的源碼包,那麼已編譯好的二進制包將是最好的選擇,下面讓咱們來介紹如何在linux系統下安裝mysql服務端。html
mysql官網:https://dev.mysql.com/downloads/mysql/
由於我下載的是mysql-8.0.23-linux-glibc2.12-x86_64.tar版本,若是有最新版本,則下載最新版本就行了。mysql
經過Xftp工具把安裝包傳輸到linux系統package目錄去:linux
●解壓mysql安裝包sql
--切換到安裝目錄 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目錄vim
--在mysql根目錄下建立data目錄,用於存放數據
mkdir /app/mysql/data
●建立mysql用戶組和mysql用戶安全
--建立mysql用戶組和mysql用戶
groupadd mysql
useradd -g mysql mysql
●修改mysql目錄權限服務器
--修改mysql目錄權限
chown -R mysql.mysql /app/mysql/
●初始化數據庫app
--先切換到mysql安裝目錄 cd /app/mysql --初始化數據庫 bin/mysqld --initialize --user=mysql --basedir=/app/mysql --datadir=/app/mysql/data
●配置mysqlsocket
--先切換到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:
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;
登陸阿里雲->安全組規則->訪問規則->入方向->手動添加以下策略:
使用Navicat鏈接成功:
參考文獻:
linux下安裝mysql8.0.x步驟