您好,登錄后才能下訂單哦!
mysql兼mariadb下載自己找自己對應的版本:
https://dev.mysql.com/downloads/mysql/
因為5.5以后都用cmake編譯了,所以系統里沒有的話,就下個源碼的裝一下,怎么測試系統里有沒有裝了,在命令行中輸入#cma 在按Tab看有沒有cmake 有的話系統就裝過了,就不用在裝了。沒有話就去下個吧,下載地址:https://cmake.org/download/
還要裝boost才能裝cmake,boost下載地址:https://sourceforge.net/projects/boost/files/boost/1.62.0/boost_1_62_0.tar.gz/download
boost安裝過程:
tar xf boost_1_59_0.tar.gz
cd boost_1_59_0
./bootstrap.sh如果有提示的話就在裝下依賴庫yum install gcc 如果不出現“error: no command provided, default command 'g++' not found
”問題的話,
在發現該錯誤時,先在系統中確認是否缺失相對應的包:
rpm -qa | grep "g++"
在確認系統未安裝之后,查詢可安裝的相對應的功能的包:
yum whatprovides "*/g++"
在把給出的包裝上,
yum install gcc-c++-4.8.5-11.el7.x86_64
yum install ncurses-devel -y 安裝mysql時要的安裝環境,也許你的機器還有別的沒裝,仔細看看,直接yum 裝下就好了
接著安裝boost
./b2
結束
cmake安裝過程:
tar xf cmake-3.8.0-rc3.tar.gz
cd cmake-3.8.0-rc3
./configure
gmake && gmake install
解壓:tar xf tar xf mariadb-5.5.46.tar.gz
cd tar xf mariadb-5.5.46
cmake . -LH查看可以配置的選項,會生成CMakeCache.txt文件
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/data
-DSYSCONFDIR=/etc
-DWITHOUT_TOKUDB=1
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STPRAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWIYH_READLINE=1 -DWIYH_SSL=system
-DVITH_ZLIB=system
-DWITH_LOBWRAP=0
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
這里說明一下:-DCMAKE_INSTALL_PREFIX是指定安裝的位置,這里是/usr/local/mysql,-DMYSQL_DATADIR是指定MySQL的數據目錄,這里是/data,安裝目錄和數據目錄都可以自定義設置,-DSYSCONFDIR是指定配置文件所在的目錄,一般都是/etc ,具體的配置文件是/etc/my.cnf,-DWITHOUT_TOKUDB=1這個參數一般都要設置上,表示不安裝tokudb引擎,tokudb是MySQL中一款開源的存儲引擎,可以管理大量數據并且有一些新的特性,這些是Innodb所不具備的,這里之所以不安裝,是因為一般計算機默認是沒有Percona Server的,并且加載tokudb還要依賴jemalloc內存優化,一般開發中也是不用tokudb的,所以暫時屏蔽掉,否則在系統中找不到依賴會出現:CMake Error at storage/tokudb/PerconaFT/cmake_modules/TokuSetupCompiler.cmake:179 (message)這樣的錯誤,然后后面那些參數都是可選的,可以加也可以不加,最后的編碼建議設置一下,所以編譯指令也可以簡化成下面這樣:
注意:如果萬一執行中有了錯誤,可以執行: rm -f CMakeCache.txt 刪除編譯緩存,讓指令重新執行,否則每次讀取這個文件,命令修改正確也是報錯
cmake沒問題,可以編譯并且安裝了:
make && make install 時間有點長,耐心等待
接下來就是準備過程了:
首先我們來創建個mysql用戶和mysql用戶組,為什么要創呢?因為你啟動服務的時候需要mysql用戶來啟動,別的用戶還不行,你要問我為什么,那我可不知道,請去問 Michael Widenius
#groupadd -r mysql
#useradd -r -g mysql mysql
要給你的安裝目錄及數據目錄改屬主屬組
chown -R mysql.mysql /usr/local/mysql
chown -R mysql.mysql /data
如果不改的話,之后你的服務肯定起不來的
接下來將配置文件和啟動文件放入/etc目錄 下
#cp /usr/local/mysql/support-files/my-huge.cnf /etc/my.cnf
#cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
修改配置文件將我的數據目錄添加進去
vim /etc/my.cnf
[mysqld]
datadir = /data
添加PATH環境變量
vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
source /etc/profile.d/mysql.sh讀取下,當前shell生效
接下來就是初始化數據庫了:
初始化:
# /usr/local/mysql/mysqld --initialize --user=mysql --mysql5.7版本初始化
# /usr/local/mysql/bin/mysql_install_db --user=mysql --5.6到5.7版本
# /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/data --5.5版本
最后就是啟動數據庫了:
service mysqld start
設置開機啟動:
chkconfig mysqld on
之后就可以連接數據庫了:
mysql
mysql> SET PASSWORD FOR root@'localhost'=PASSWORD('mysql');修改密碼,不同的版本修改方式有點不同,可自己上網查下。
最后就是點小的問題解決方式:
如果沒給數據目錄權限的話就會出現以下的問題:
chown -R mysql:mysql datadir的位置
** 記得把之前的啟動項關掉,要不然會占用PID文件,你會發現你啟動不了過程
還有就是你的server-id 沒有設置
killall mysqld
1、Starting MySQL.. ERROR! The server quit without updating PID file (/var/mysql/data/localhost.localdomain.pid).
像套接字文件也是這種問題:
2、ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
3、可能是第二次在機器上安裝mysql,有殘余數據影響了服務的啟動
解決方法:去mysql的數據目錄看看,如果存在mysql-bin.index,就趕快把它刪除掉吧。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。