linux 安裝Mysql5.7.20

1.?下載資源包

https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz

2.?安裝步驟

https://dev.mysql.com/doc/refman/5.6/en/binary-installation.html

shell> groupadd mysql

shell> useradd -r -g mysql -s /bin/false mysql

shell> cd /usr/localshell> tar zxvf?/path/to/mysql-VERSION-OS.tar.gz

shell> ln -s?full-path-to-mysql-VERSION-OS?mysql

shell> cd mysql

shell> scripts/mysql_install_db --user=mysql

shell> bin/mysqld_safe --user=mysql &# Next command is optional

shell> cp support-files/mysql.server /etc/init.d/mysql.server

3.?添加mysql組和mysql用戶,用于設置mysql安裝目錄文件所有者和所屬組。

?①groupadd mysql

?②useradd -r -g mysql mysql

?* useradd -r參數表示mysql用戶是系統用戶,不可用于登錄系統。

?* useradd -g參數表示把mysql用戶添加到mysql用戶組中。

4.?解壓到指定的安裝目錄,我們這里指定為?/usr/local/

?①解壓二進制文件,?tar -zxvf /Ultrapower/test/mysql-5.7.13-linux-glibc2.5-i686.tar.gz?

?②mv?mysql-5.7.13-linux-glibc2.5-i686 mysql ? 更改mysql目錄名稱

?③cd mysql 進入mysql文件夾,也就是mysql所在的目錄,

?④更改mysql目錄所屬的組和用戶。更改權限

? ? chown -R mysql .

? ? chgrp -R mysql .

5.?初始化 MySQL 配置表?

?bin/mysql_install_db --user=mysql #對mysql中的data目錄進行初始化并創建一些系統表格。

?error:

?2016-07-15 14:50:14 [WARNING] mysql_install_db is deprecated. Please consider switching to mysqld --initialize

?2016-07-15 14:50:14 [ERROR] ? The data directory needs to be specified.

reason: ?需要指定data目錄,注意mysql服務進程mysqld運行時會訪問data目錄,所以必須由啟動mysqld進程的(就是我們之前設置的mysql用戶)執行這個腳本, ?或者用root ?執行,但是加上參數--user=mysql。

?注:

mysql5.7的mysql_install_db命令是在bin目錄下,建議用?mysqld --initialize命令

小于mysql5.7版本初始化配置表命令:

script/mysql_install_db --user=mysql --basedir=/Ultrapower/test/mysql --datadir=/Ultrapower/test/mysql/data/

參數說明: --user ?啟動mysql的用戶

--basedir ?mysql安裝目錄

? --datadir ?mysql數據倉庫目錄

?①?初始化表配置正確執行步驟:

[plain]?view plain?copy

[root@rhel5-32?mysql]#?mkdir?data??

[root@rhel5-32?mysql]#?bin/mysqld?--initialize?--user=mysql?--basedir=/Ultrapower/test/mysql?--datadir=/Ultrapower/test/mysql/data??

201615T09:39:39.773073Z?1?[Note]?A?temporary?password?is?generated?for?root@localhost:?i7YCy.:jv6yr??< **** 注意保存初始root密碼 **** >

?將mysql/目錄下除了data/目錄的所有文件,改回root用戶所有,mysql用戶只需作為mysql/data/目錄下所有文件的所有者。

[plain]?view plain?copy

[root@rhel5-32?mysql]#?chown?-R?root?.??

[root@rhel5-32?mysql]#?chown?-R?mysql?data??

復制配置文件

[plain]?view plain?copy

[root@rhel5-32?mysql]#?cp?support-files/my-default.cnf?/etc/my.cnf??

?④mysql5.7配置文件需要修改my.cnf關鍵配置,?mysql5.7之前默認配置文件中是有配置項的,不用手動修改

[plain]?view plain?copy

[mysqld]??

basedir?=?/usr/local/mysql??

datadir?=?/usr/local/mysql/data??

port?=?3306

socket?=?/usr/local/mysql/tmp/mysql.sock??

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES??

?注意:

tmp目錄不存在,請創建, 賦予mysql權限,chown -R mysql:mysql tmp?

? 如果mysql.sock指定到/tmp以外的目錄,需要在my.cnf中添加[client]并且指定socket位置,

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/.sock'

5.?創建mysql_sfe log文件夾并修噶權限

6.?將mysqld服務加入開機自啟動項。

拷貝support-files/mysql.server為/etc/init.d/mysql并設置運行權限,使用service mysql命令啟動/停止服務

把mysql.server中basedir的相關路徑,改為自定義的路徑,默認路徑是/usr/local/mysql

[plain]?view plain?copy

#cp?mysql.server?/etc/init.d/mysql??

#chmod?+x?/etc/init.d/mysql??

?把mysql注冊為開機啟動的服務

[plain]?view plain?copy

#chkconfig?--add?mysql??

?查看是否添加成功

[plain]?view plain?copy

[root@rhel5-32?mysql]#?chkconfig?--list?mysql??

mysqld??????????0:關閉??1:關閉??2:啟用??3:啟用??4:啟用??5:啟用??6:關閉??

7. mysql服務的開啟和關閉

[plain]?view plain?copy

serivce?mysql?start??或者??bin/mysqld_safe&??

service?mysql?stop???或者??bin/mysqladmin?-uroot?-p??

?注:在bin/mysqld_safe&這個啟動腳本里已默認設置--user=mysql;在腳本末尾加&表示設置此進程為后臺進程,區別就是在控制臺輸入bg,即可將當前進 ?程轉入后臺, ?當前shell ?可進行其他操作。

8.?需要把mysqll加入到環境變量中,或者為mysql建立軟鏈接

---- 建立軟鏈接:

ln -s /Ultrapower/test/mysql/bin/mysql ?/usr/local/bin

ln -s /Ultrapower/test/mysql/bin/mysqladmin ?/usr/local/bin

ln -s /Ultrapower/test/mysql/bin/mysqld_safe ?/usr/local/bin

---- 加入環境變量:

修改/etc/profile文件使其永久性生效,并對所有系統用戶生效:

PATH=$PATH:/Ultrapower/test/mysql:/Ultrapower/test/mysql/bin

export PATH

source /etc/profile

執行完可通過echo $PATH命令查看是否添加成功。

9. 登錄mysql服務

?執行:mysql -uroot -p生成的密碼

?連上后,在做任何操作前,mysql要求要改掉root的密碼后才能進行操作

?ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.

?需要執行:

alter user 'root'@'localhost' identified by 'xxxxxxx';

flush privileges;

需要變更權限的目錄

1. /usr/local/mysql/data

2. /usr/local/mysql/tmp

3. /usr/local/mysql/log

4. /home/mysql/*

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

推薦閱讀更多精彩內容