【MYSQL】LINUX安裝MYSQL

來源:互聯網
上載者:User

標籤:conf   starting   ***   warning   初始密碼   nbsp   mysql目錄   比較   其他   

安裝環境:系統是 Red Hat Enterprise Linux Server release 6.6

安裝軟體:mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

1、下載

    :http://dev.mysql.com/downloads/mysql/5.6.html#downloads

    下載版本:我這裡選擇的5.6.33,通用版,linux下64位

    也可以直接複製64位的,通過命令下載:wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

2、解壓

1

2

3

4

#解壓

tar -zxvf mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

#複製解壓後的mysql目錄

cp -r mysql-5.6.33-linux-glibc2.5-x86_64/* /usr/local/mysql

 

#或者 解壓後 更改為mysql目錄名稱 再複製或移動到/usr/local/

mv mysql-5.6.33-linux-glibc2.5-x86_64 mysql

cp  -r mysql /usr/local

3、添加使用者組和使用者

1

2

3

4

#添加使用者組

groupadd mysql

#添加使用者mysql 到使用者組mysql

useradd -r -g mysql mysql

 

# * useradd -r參數表示mysql使用者是系統使用者,不可用於登入系統。

 

# * useradd -g參數表示把mysql使用者添加到mysql使用者組中。

4、安裝

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

cd /usr/local/mysql/

mkdir ./data/mysql              (注意;資料庫倉庫存放位置指定需自訂,有的話可以忽略)

chown -R mysql:mysql ./      

# 執行mysql_install_db指令碼,對mysql中的data目錄進行初始化並建立一些系統資料表格。

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

#############此為5.7版本前後安裝說明資訊,這裡用5.6所以不需考慮 開始 ###

mysql5.7執行mysql_install_db指令碼,對mysql中的data目錄進行初始化並建立一些系統資料表格。

 

 bin/mysql_install_db --user=mysql

 

 報錯:

 

 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.

 

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

 

 上文還有警告資訊,說mysql_install_db 命令已經是棄用的,建議切換到mysqld --initialize命令

 

 註:

 

 mysql5.7和之前版本不同,很多資料上都是這個命令:../scripts/mysql_install_db --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資料倉儲目錄

#############此為5.7版本前後安裝說明資訊,這裡用5.6所以不需考慮結束 ###

 

# 將mysql/目錄下除了data/目錄的所有檔案,改回root使用者所有,mysql使用者只需作為mysql/data/目錄下所有檔案的所有者。

chown -R root . 

chown -R mysql data 

 

# 複製設定檔 (如果/etc/my.cnf已存在則不需操作)

cp support-files/my-default.cnf /etc/my.cnf

檢查配置(正常如下,basedir和datadir配置正確,socket不要指定在/tmp/路徑,否則需要配置tmp許可權,log-error自訂,pid-file如下)

 

# 將/support-files/mysql.server 拷貝並重新命名為/etc/init.d/mysql並設定運行許可權,這樣就可以使用service mysql命令啟動/停止服務,否則就只能使用{mysql}/bin/mysqld_safe &命令來啟動服務

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

# 設定運行許可權

chmod +x /etc/init.d/mysql

 

#檢查修改啟動指令碼

vi /etc/init.d/mysql

 

#修改項:

basedir=/usr/local/mysql/

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

 

 

#把mysql註冊為開機啟動的服務

chkconfig --add mysql

chkconfig --list mysql 

 

#加入環境變數,編輯 /etc/profile,這樣可以在任何地方用mysql命令了

export PATH=$PATH:/usr/local/mysql/bin

source /etc/profile

 

 

#啟動服務或如命令

service mysqld start

 

 

#測試連接

./mysql/bin/mysql -uroot

 

#啟動mysql

service mysqld start

#關閉mysql

service mysqld stop

#查看運行狀態

service mysqld status

5、錯誤

  5.1 sqlyog遠端連線時,報1130錯誤,是由於沒有給遠端連線的使用者權限問題(推薦2)

    解決1:更改 ‘mysql’資料庫‘user’表‘host’項,從‘localhost’改成‘%’。

use mysql;

select ‘host‘ from user where user=‘root‘;

update user set host = ‘%‘ where user =‘root‘;

flush privileges;

    解決2:直接授權

GRANT ALL PRIVILEGES ON *.* TO ‘root‘@‘%‘ IDENTIFIED BY PASSWORD ‘*81F5E21E35407D884A6CD4A731AEBFB6AF209E1B‘ WITH GRANT OPTION;

  5.2 初始化時的一些提示

    ./scripts/mysql_install_db ……
    說明: 初始化完成末尾會有一些設定檔提示或產生root使用者初始密碼,請閱讀。

5.3 用戶端遠端連線mysql錯誤2003 cant connect to mysql 10060/10061解決方案

    
    方法:1. 確保mysql服務已經啟動:service mysql status

                       2. 在裝有sqlyog的端嘗試在命令列中ping目標ip,確保能ping通

                       3. 在需要已連線的服務器端查看mysql使用者名稱和許可權,確保sqlyog輸入的使用者名稱和密碼正確

                       4. 在需要已連線的服務器端登陸mysql後查看使用者權限:show grants;

                       5. 記得關閉防火牆

                       6. 開啟/etc/my.cnf 檔案,bind-address = ******** 一句前邊加上 # ,注釋掉

7. 重啟mysql服務

 

6、其他

  6.1 配置環境變數

    vi   /etc/profile

              增加如下:

    MYSQL =/usr/local/mysql/bin

       export MYSQL

7、報錯(可參考)

mysql安裝過程遇到的錯誤:

 

啟動Mysql

 

bin/mysqld_safe--user=mysql & 

 

[[email protected]mysql]# bin/mysqld_safe &

[1] 13863

[[email protected]mysql]# bin/mysqld_safe: line 541:/Ultrapowewr/test/mysql/data/mysqld_safe.pid: 沒有那個檔案或目錄

awk: (FILENAME=-FNR=1) warning: error writing standard output (斷開的管道)

2016-07-15T07:57:05.782967Zmysqld_safe Logging to ‘/Ultrapowewr/test/mysql/data/rhel5-32.err‘.

touch: 無法觸碰“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

chmod: 無法訪問 “/Ultrapowewr/test/mysql/data/rhel5-32.err”:沒有那個檔案或目錄

touch: 無法觸碰“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

chown: 無法訪問“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

2016-07-15T07:57:05.877234Zmysqld_safe Starting mysqld daemon with databases from/Ultrapowewr/test/mysql/data

bin/mysqld_safe:line 135: /Ultrapowewr/test/mysql/data/rhel5-32.err: 沒有那個檔案或目錄

bin/mysqld_safe:line 169: /Ultrapowewr/test/mysql/data/rhel5-32.err: 沒有那個檔案或目錄

touch: 無法觸碰“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

chown: 無法訪問“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

chmod: 無法訪問“/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個檔案或目錄

2016-07-15T07:57:05.923131Zmysqld_safe mysqld from pid file /Ultrapowewr/test/mysql/data/rhel5-32.pid ended

bin/mysqld_safe:line 135: /Ultrapowewr/test/mysql/data/rhel5-32.err: 沒有那個檔案或目錄

 

 

[[email protected]mysql]# service mysql restart

MySQL server PIDfile could not be found!                 [失敗]

/etc/init.d/mysql:line 276: cd: /Ultrapowewr/test/mysql: 沒有那個檔案或目錄

StartingMySQLCouldn‘t find MySQL server (/Ultrapowewr/test[失敗]/bin/mysqld_safe)

 

這錯誤是因為,在/etc/my.cnf中配置basedir路徑出錯導致的

*************************************************************************************************************************************************

 

執行 mysql-uroot -p

 

出錯:ERROR 2002(HY000): Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘(111)

 

 

查看 lessdata/rhel5-32.err

 

發現日誌輸出:

 

2016-07-15T08:13:31.786920Z0 [Note] /Ultrapower/test/mysql/bin/mysqld: ready for connections.

Version:‘5.7.13‘  socket: ‘/temp/mysql.sock‘  port: 3306 MySQL Community Server (GPL)

 

 

查看/etc/my.cnf中,socket配置:

 

# These arecommonly set, remove the # and set as required.

basedir =/Ultrapower/test/mysql

datadir =/Ultrapower/test/mysql/data

port = 3306

# server_id = .....

socket =/tmp/mysql.sock

 

 

socket檔案目錄為/temp/mysql.sock和錯誤提示不一樣,

 

#由上可知my.cnf中定義的為/tmp目錄下,而錯誤提示為/temp/mysql.sock/目錄下

#也就是說mysqld已經聲稱了正確的sock檔案,但用戶端串連還是從初始目錄去找sock檔案

 

應該是因為,沒有temp目錄,mysql不會自動建立,找不到所致

 

*************************************************************************************************************************************************

 

錯誤:The serverquit without updating PID file [失敗]local/mysql/data/rhel5-32.pi

 

啟動mysql服務時報如上錯誤,查看mysql日誌發現

 

[plain] view plain copy

 

    2016-07-26T02:07:28.134232Z 0 [Note]InnoDB: Highest supported file format is Barracuda. 

    2016-07-26T02:07:28.172866Z 0 [Note]InnoDB: Creating shared tablespace for temporary tables 

    2016-07-26T02:07:28.172990Z 0 [Note]InnoDB: Setting file ‘./ibtmp1‘ size to 12 MB. Physically writing the filefull; Please wait ... 

    2016-07-26T02:07:28.244892Z 0 [Note]InnoDB: File ‘./ibtmp1‘ size is now 12 MB. 

    2016-07-26T02:07:28.252257Z 0 [Note]InnoDB: 96 redo rollback segment(s) found. 96 redo rollback segment(s) areactive. 

    2016-07-26T02:07:28.252344Z 0 [Note]InnoDB: 32 non-redo rollback segment(s) are active. 

    2016-07-26T02:07:28.253779Z 0 [Note]InnoDB: Waiting for purge to start 

    2016-07-26T02:07:28.305124Z 0 [Note] InnoDB:5.7.13 started; log sequence number 2523957 

    2016-07-26T02:07:28.306232Z 0 [Note]InnoDB: Loading buffer pool(s) from /usr/local/mysql/data/ib_buffer_pool 

    2016-07-26T02:07:28.307231Z 0 [Note] Plugin‘FEDERATED‘ is disabled. 

    2016-07-26T02:07:28.315654Z 0 [Warning]Failed to set up SSL because of the following SSL library error: SSL context isnot usable without certificate and private key 

    2016-07-26T02:07:28.315736Z 0 [Note] Serverhostname (bind-address): ‘*‘; port: 3306 

    2016-07-26T02:07:28.315825Z 0 [Note] IPv6is available. 

    2016-07-26T02:07:28.315860Z 0 [Note]   - ‘::‘ resolves to ‘::‘; 

    2016-07-26T02:07:28.316013Z 0 [Note] Serversocket created on IP: ‘::‘. 

    2016-07-26T02:07:28.316099Z 0 [ERROR] Couldnot create unix socket lock file /usr/local/mysql/tmp/mysql.sock.lock. 

    2016-07-26T02:07:28.316115Z 0 [ERROR]Unable to setup unix socket lock file. 

    2016-07-26T02:07:28.316128Z 0 [ERROR]Aborting 

 

 

不能建立mysql.sock.lock檔案,可能是tmp目錄許可權不足或者目錄不存在的問題

 

執行 chown -Rmysql:mysql tmp,然後啟動mysql服務,啟動成功

 

*************************************************************************************************************************************************

 

登入mysql,mysql -uroot -pi7YCy.:jv6yr

 

如出現ERROR 1045(28000): Access denied for user ‘root‘@‘localhost‘ (using password: NO),是因為不允許密碼為空白

 

如出現ERROR 1045(28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES),可能密碼錯誤,

終極辦法停止mysql服務,刪除data目錄,重新初始化表資料,受權data目錄給Mysql使用者,用重建的臨時密碼登入。

 

重設密碼解決MySQL for Linux錯誤 ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘(using password: YES)

 

一般這個錯誤是由密碼錯誤引起,解決的辦法自然就是重設密碼。

 

假設我們使用的是root賬戶。

 

1.重設密碼的第一步就是跳過MySQL的密碼認證過程,方法如下:

 

#vim /etc/my.cnf(註:windows下修改的是my.ini)

 

在文檔內搜尋mysqld定位到[mysqld]文本段:

/mysqld(在vim編輯狀態下直接輸入該命令可搜尋常值內容)

 

在[mysqld]後面任意一行添加“skip-grant-tables”用來跳過密碼驗證的過程,如所示:

 

儲存文檔並退出:

 

#:wq

2.接下來我們需要重啟MySQL:

 

/etc/init.d/mysqlrestart(有些使用者可能需要使用/etc/init.d/mysqldrestart或者 service mysql restart)

 

3.重啟之後輸入./bin/mysql即可進入mysql。

cd /usr/local/mysql

./bin/mysql

4.接下來就是用sql來修改root的密碼

mysql> usemysql;

mysql> updateuser set password=password("你的新密碼") where user="root";

mysql> flushprivileges;

mysql> quit

 

到這裡root賬戶就已經重設成新的密碼了。

 

5.編輯my.cnf,去掉剛才添加的內容,然後重啟MySQL。大功告成!

service mysqlrestart

 網上有很多關於這個問題的解決說明,很多剛接觸的朋友可能比較迷惑的是在自己的平台上找不到my.cnf或者my.ini檔案,如果你是Linux,使用如下方式可以搜尋到:whereis my

 

至於windows平台,去安裝目錄下找一下my.ini吧。

【MYSQL】LINUX安裝MYSQL

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.