【MYSQL】LINUX安裝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 &
[root@rhel5-32 mysql]# bin/mysqld_safe &
[1] 13863
[root@rhel5-32 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.782967Z mysqld_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.877234Z mysqld_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.923131Z mysqld_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: 沒有那個文件或目錄
[root@rhel5-32 mysql]# service mysql restart
MySQL server PID file could not be found! [失敗]
/etc/init.d/mysql: line 276: cd: /Ultrapowewr/test/mysql: 沒有那個文件或目錄
Starting MySQLCouldn‘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)
查看 less data/rhel5-32.err
發現日誌輸出:
2016-07-15T08:13:31.786920Z 0 [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 are commonly 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 server quit 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 file full; 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) are active.
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 is not usable without certificate and private key
2016-07-26T02:07:28.315736Z 0 [Note] Server hostname (bind-address): ‘*‘; port: 3306
2016-07-26T02:07:28.315825Z 0 [Note] IPv6 is available.
2016-07-26T02:07:28.315860Z 0 [Note] - ‘::‘ resolves to ‘::‘;
2016-07-26T02:07:28.316013Z 0 [Note] Server socket created on IP: ‘::‘.
2016-07-26T02:07:28.316099Z 0 [ERROR] Could not 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 -R mysql: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/mysql restart(有些用戶可能需要使用/etc/init.d/mysqld restart或者 service mysql restart)
3.重啟之後輸入./bin/mysql即可進入mysql。
cd /usr/local/mysql
./bin/mysql
4.接下來就是用sql來修改root的密碼
mysql> use mysql;
mysql> update user set password=password("你的新密碼") where user="root";
mysql> flush privileges;
mysql> quit
到這裏root賬戶就已經重置成新的密碼了。
5.編輯my.cnf,去掉剛才添加的內容,然後重啟MySQL。大功告成!
service mysql restart
網上有很多關於這個問題的解決說明,很多剛接觸的朋友可能比較迷惑的是在自己的平臺上找不到my.cnf或者my.ini文件,如果你是Linux,使用如下方式可以搜索到:whereis my
至於windows平臺,去安裝目錄下找一下my.ini吧。
【MYSQL】LINUX安裝MYSQL