linux下mysql安装
二進(jìn)制安裝
1.添加mysql組和mysql用戶,用于設(shè)置mysql安裝目錄文件所有者和所屬組。
?①groupadd mysql
?②useradd -r -g mysql mysql
?* useradd -r參數(shù)表示mysql用戶是系統(tǒng)用戶,不可用于登錄系統(tǒng)。
?* useradd -g參數(shù)表示把mysql用戶添加到mysql用戶組中。
2.將二進(jìn)制文件解壓到指定的安裝目錄,我們這里指定為?/Ultrapower/test/,也可以是通用的/usr/local
?①解壓二進(jìn)制文件,?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 進(jìn)入mysql文件夾,也就是mysql所在的目錄,
?④更改mysql目錄所屬的組和用戶。更改權(quán)限
????chown -R mysql .
????chgrp -R mysql .
3.初始化 MySQL 配置表?
?執(zhí)行mysql_install_db腳本,對(duì)mysql中的data目錄進(jìn)行初始化并創(chuàng)建一些系統(tǒng)表格。
?bin/mysql_install_db --user=mysql
?報(bào)錯(cuò):
?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服務(wù)進(jìn)程mysqld運(yùn)行時(shí)會(huì)訪問data目錄,所以必須由啟動(dòng)mysqld進(jìn)程的用戶(就是我們之前設(shè)置的mysql用戶)執(zhí)行這個(gè)腳本, ?或者用root ?執(zhí)行,但是加上參數(shù)--user=mysql。
?上文還有警告信息,說mysql_install_db 命令已經(jīng)是棄用的,建議切換到mysqld --initialize命令
?注:
?mysql5.7和之前版本不同,很多資料上都是這個(gè)命令:../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 ?啟動(dòng)mysql的用戶
?--basedir ?mysql安裝目錄
?--datadir ?mysql數(shù)據(jù)倉庫目錄
?①初始化表配置正確執(zhí)行步驟:
?
[root@rhel5-32 mysql]# mkdir data
[root@rhel5-32 mysql]# bin/mysqld --initialize --user=mysql --basedir=/Ultrapower/test/mysql --datadir=/Ultrapower/test/mysql/data
2016-07-15T09:39:38.166396Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2016-07-15T09:39:38.166941Z 0 [Warning] 'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged with strict mode in a future release.
2016-07-15T09:39:38.166976Z 0 [Warning] 'NO_AUTO_CREATE_USER' sql mode was not set.
2016-07-15T09:39:39.486697Z 0 [Warning] InnoDB: New log files created, LSN=45790
2016-07-15T09:39:39.699652Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2016-07-15T09:39:39.767191Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 0d154f38-4a70-11e6-8670-005056913e3a.
2016-07-15T09:39:39.771851Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
2016-07-15T09:39:39.773073Z 1 [Note] A temporary password is generated for root@localhost: i7YCy.:jv6yr
?
?
?
?注意最后一行,這也是和之有版本不同的地方,它給了root一個(gè)初始密碼,后面要登錄的時(shí)候要用到這個(gè)密碼。
?
?②將mysql/目錄下除了data/目錄的所有文件,改回root用戶所有,mysql用戶只需作為mysql/data/目錄下所有文件的所有者。
?
[root@rhel5-32 mysql]# chown -R root .
[root@rhel5-32 mysql]# chown -R mysql data
③復(fù)制配置文件
?
?
[root@rhel5-32 mysql]# cp support-files/my-default.cnf /etc/my.cnf
?
?
?
?
?
?④mysql5.7配置文件需要修改my.cnf關(guān)鍵配置,?mysql5.7之前默認(rèn)配置文件中是有配置項(xiàng)的,不用手動(dòng)修改
?
[mysqld]
basedir = /Ultrapower/test/mysql
datadir = /Ultrapower/test/mysql/data
port = 3306
socket = /Ultrapower/test/mysql/tmp/mysql.sock
?
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
?
?注意,tmp目錄不存在,請(qǐng)創(chuàng)建之。否則會(huì)出錯(cuò) ????創(chuàng)建后要賦予mysql權(quán)限,chown -R mysql:mysql tmp?
?如果mysql.sock指定到/tmp以外的目錄,需要在my.cnf中添加[client]并且指定socket位置,
?否則登錄mysql時(shí)會(huì)報(bào)錯(cuò):ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
?應(yīng)該是,默認(rèn)會(huì)找tmp目錄下的sock文件
?
?
?
?
?
4. 將mysqld服務(wù)加入開機(jī)自啟動(dòng)項(xiàng)。
?將{mysql}/ support-files/mysql.server 拷貝為/etc/init.d/mysql并設(shè)置運(yùn)行權(quán)限,這樣就可以使用service mysql命令啟動(dòng)/停止服務(wù),
?否則就只能使用{mysql}/bin/mysqld_safe &命令來啟動(dòng)服務(wù)
?還需要把mysql.server中basedir的相關(guān)路徑,改為自定義的路徑,默認(rèn)路徑是/usr/local/mysql
?
#cp mysql.server /etc/init.d/mysql
#chmod +x /etc/init.d/mysql
?把mysql注冊(cè)為開機(jī)啟動(dòng)的服務(wù)
?
#chkconfig --add mysql
?
?
?查看是否添加成功
[root@rhel5-32 mysql]# chkconfig --list mysql
mysqld ? ? ? ? ?0:關(guān)閉 ?1:關(guān)閉 ?2:啟用 ?3:啟用 ?4:啟用 ?5:啟用 ?6:關(guān)閉
?
5.mysql服務(wù)的開啟和關(guān)閉
#/etc/init.d/mysql start ? 或者 ? service mysql start ?或者 ?bin/mysqld_safe&
#/etc/init.d/mysql stop ? ?或者 ? service mysql stop ? 或者 ?bin/mysqladmin -uroot -p
?注:在bin/mysqld_safe&這個(gè)啟動(dòng)腳本里已默認(rèn)設(shè)置--user=mysql;在腳本末尾加&表示設(shè)置此進(jìn)程為后臺(tái)進(jìn)程,區(qū)別就是在控制臺(tái)輸入bg,即可將當(dāng)前進(jìn) ?程轉(zhuǎn)入后臺(tái), ?當(dāng)前shell ?可進(jìn)行其他操作。
?bin/mysqladmin -uroot -p??(注意此時(shí)的root是指mysql的root用戶)
?
需要把mysqll加入到環(huán)境變量中,或者為mysql建立軟鏈接
否則運(yùn)行mysql命令會(huì)出現(xiàn) ??-bash: mysql:command not found
不加環(huán)境變量,就要使用bin/mysql -uroot -p 或者bin/mysqladmin -uroot -p ?命令來登錄mysql服務(wù)
?
建立軟鏈接:
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
?
6.加入環(huán)境變量
?修改/etc/profile文件使其永久性生效,并對(duì)所有系統(tǒng)用戶生效,在文件末尾加上如下兩行代碼
?PATH=$PATH:/Ultrapower/test/mysql:/Ultrapower/test/mysql/bin
?export PATH
?最后:執(zhí)行 命令source /etc/profile或 執(zhí)行點(diǎn)命令 ./profile使其修改生效,執(zhí)行完可通過echo $PATH命令查看是否添加成功。
?
7.登錄mysql服務(wù)
?執(zhí)行:mysql -uroot -p生成的密碼
?連上后,在做任何操作前,mysql要求要改掉root的密碼后才能進(jìn)行操作。
?ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
?需要執(zhí)行:alter user 'root'@'localhost' identified by 'xxxxxxx';
mysql安裝過程遇到的錯(cuò)誤:
?
啟動(dòng)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: 沒有那個(gè)文件或目錄
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”: 沒有那個(gè)文件或目錄
chmod: 無法訪問 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
touch: 無法觸碰 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
chown: 無法訪問 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
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: 沒有那個(gè)文件或目錄
bin/mysqld_safe: line 169: /Ultrapowewr/test/mysql/data/rhel5-32.err: 沒有那個(gè)文件或目錄
touch: 無法觸碰 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
chown: 無法訪問 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
chmod: 無法訪問 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 沒有那個(gè)文件或目錄
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: 沒有那個(gè)文件或目錄
?
[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: 沒有那個(gè)文件或目錄
Starting MySQLCouldn't find MySQL server (/Ultrapowewr/test[失敗]/bin/mysqld_safe)
這錯(cuò)誤是因?yàn)?#xff0c;在/etc/my.cnf中配置basedir路徑出錯(cuò)導(dǎo)致的
*************************************************************************************************************************************************
執(zhí)行 mysql -uroot -p
出錯(cuò):ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (111)
?
查看 less data/rhel5-32.err?
發(fā)現(xiàn)日志輸出:
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和錯(cuò)誤提示不一樣,
#由上可知my.cnf中定義的為/tmp目錄下,而錯(cuò)誤提示為/temp/mysql.sock/目錄下
#也就是說mysqld已經(jīng)聲稱了正確的sock文件,但客戶端連接還是從初始目錄去找sock文件
應(yīng)該是因?yàn)?#xff0c;沒有temp目錄,mysql不會(huì)自動(dòng)創(chuàng)建,找不到所致
*************************************************************************************************************************************************
錯(cuò)誤:The server quit without updating PID file [失敗]local/mysql/data/rhel5-32.pi
啟動(dòng)mysql服務(wù)時(shí)報(bào)如上錯(cuò)誤,查看mysql日志發(fā)現(xiàn)
?
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
不能創(chuàng)建mysql.sock.lock文件,可能是tmp目錄權(quán)限不足或者目錄不存在的問題
?
執(zhí)行 chown -R mysql:mysql tmp,然后啟動(dòng)mysql服務(wù),啟動(dòng)成功
*************************************************************************************************************************************************
登錄mysql,mysql -uroot -pi7YCy.:jv6yr
如出現(xiàn)ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO),是因?yàn)椴辉试S密碼為空
如出現(xiàn)ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES),可能密碼錯(cuò)誤
,終極辦法停止mysql服務(wù),刪除data目錄,重新初始化表數(shù)據(jù),受權(quán)data目錄給Mysql用戶,用重新生成的臨時(shí)密碼登錄。
---------------------?
作者:夜舞傾城?
來源:CSDN?
原文:https://blog.csdn.net/bao19901210/article/details/51917641?
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請(qǐng)附上博文鏈接!
總結(jié)
以上是生活随笔為你收集整理的linux下mysql安装的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 10分钟了解JSON Web令牌(JWT
- 下一篇: nginx动态配置及服务发现那些事