本文出處:http://www.cnblogs.com/wy123/p/6815049.html
最新在學習MySQL,純新手,對Linux了解的也不多,因為是下載的最新版的MySQL(MySQL5.7.18)二進制包,CentOS7.2下測試安裝,方便以后折騰。
大概步驟如下,安裝刪除反復折騰了幾遍,按照以下步驟,應該沒啥問題了。
也沒有想象中的復雜,大部分步驟都是參考網上的,照做就是了,出錯的話,多嘗試,多查資料。
操作系統版本
創建mysql組和用戶
下載最新版的MySQL 5.7.18二進制包,上傳至服務器的usr/local目錄下
解壓MySQL二進制包
如下是解壓之后的,並且重命名文件夾之后的文件信息
更改所屬的組和用戶
解壓之后的MySQL文件包含的內容
查看support-files文件夾的內容,發現並沒有my_default.cnf默認的配置文件,如果沒有默認的配置文件,需要手動創建一個my_default.cnf配置文件
如下是一個最簡化的配置文件,上傳到supp-files文件夾中,當然其他配置選項可以根據需要自行修改,
如下有一個配置是skip-grant-tables = 1,表示可以跳過密碼登陸,登陸之后可以修改root的密碼和遠程訪問權限,然后取消跳過密碼驗證,用root+密碼可以正常登陸
[mysqld]
character-set-server=utf8
basedir = /usr/local/mysql/
datadir=/usr/local/mysql/data/
log-error=/usr/local/mysql/mysqld.log
port = 3306
socket=/tmp/mysql.sock
skip-grant-tables = 1
如下,將上述默認配置文件上傳至support-files文件夾中
注冊和初始化MySQL服務
這一點比較坑,網上的教程大多是mysql_install_db 方式安裝的,這一步也是遇到問題最最多的,折騰了好久,但是mysql_install_db 命令是不推薦的,也提示使用mysqld來安裝
在安裝mysql 5.7.18的時候也是各種報錯,經過各種嘗試之后吧,采用如下命名方式安裝,只要沒有Error,警告信息Warning先不理它
bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
復制上述的my_default.cnf和mysql.server配置文件到etc目錄,之前復制過該文件到etc目錄,它這里提示是否覆蓋,輸入Y覆蓋
啟動MySQL服務
連接至MySQL,默認沒有密碼,直接回車后連接至MySQL
修改MySQL的root密碼
修改可遠程訪問
重啟MySQL服務
此時本地可以正常使用MySQL
設置開機自動啟動
測試遠程連接
20171205:
后面因為需要,自己又照做了一遍,安裝是ok的,后面考慮使用python做一個自動化安裝
groupadd mysql
cat /etc/group | grep mysql
useradd -r -g mysql mysql
cat /etc/passwd | grep mysql
tar xvfz mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz
chown -R mysql mysql-5.7.20/
chgrp -R mysql mysql-5.7.20/
./bin/mysqld --initialize-insecure --user=mysql --basedir=/home/mysql/mysql-5.7.20 --datadir=/home/mysql/mysql-5.7.20/data/
cp /home/mysql/mysql-5.7.20/support-files/mysql.server /etc/init.d/mysqld
/etc/init.d/mysqld restart
rm -rf /etc/selinux/targeted/active/modules/100/mysql
rm -rf /var/lib/mysql
rm -rf /usr/bin/mysql
rm -rf /usr/lib64/perl5/vendor_perl/auto/DBD/mysql
rm -rf /usr/lib64/perl5/vendor_perl/DBD/mysql
rm -rf /usr/lib64/mysql
rm -rf /usr/share/mysql
設置mysql的環境變量
export PATH=$PATH:/home/mysql/mysql-5.7.20/bin
注:修改文件后要想馬上生效還要運行# source /etc/profile不然只能在下次重進此用戶時生效。