1、RPM版安裝mysql
查看是否有其餘版本的數據庫,如有,刪除乾淨linux
非root用戶必需要有sudo權限c++
1.下載mysql相關安裝包sql
https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/mysql-community-server-8.0.18-1.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/mysql-community-libs-8.0.18-1.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/mysql-community-common-8.0.18-1.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/mysql/yum/mysql80-community-el7/mysql-community-client-8.0.18-1.el7.x86_64.rpm
2.其餘依賴(能夠先跳過該步,看後面安裝mysql時缺乏什麼依賴就安裝什麼依賴)數據庫
到該網址下去尋找gcc、gcc-c++、openssl、perl及其依賴包
https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/
3.安裝mysql(未報錯則表示安裝成功)bootstrap
4.自定義配置mysql(若是不想改變mysql的默認相關目錄,跳至第6步)centos
修改Mysql默認的配置文件內容
sudo vi /etc/my.cnf
刪除全部內容,加入如下內容:
[mysqld] user=mysql port=3306 datadir=/app/mysql/data socket=/app/mysql/mysql.sock log-error=/app/mysql/log/mysqld.log pid-file=/app/mysql/mysqld.pid [client] socket=/app/mysql/mysql.sock
5.建立配置文件中的相關目錄並修改權限app
sudo mkdir /app/mysql/data /app/mysql/log -p
sudo chown mysql:mysql /app/mysql -R
6.初始化mysqlsocket
7.啓動mysqlide
若啓動出錯:
a.請查看mysql相關目錄的所屬用戶和所屬組是不是mysql
b.請查看selinux是否關閉:執行sudo getenforce獲得的結果若不是Permissive,執行命令:sudo setenforce 0
c.查看端口是否被佔用
d.若仍是沒法啓動:請查看mysql錯誤日誌以及sudo systemctl status mysqld或者journalctl -xe
8.登陸mysql
查看Mysql的初始密碼(root@localhost:後面的就是初始密碼)
sudo cat /app/mysql/log |grep root@localhost (作過第4步使用該命令)
sudo cat /var/log/mysqld.log|grep root@localhost (未作過第4步使用該命令)
登陸mysql,複製上面的密碼
mysql -p
9.修改mysql密碼(初次登陸必須修改密碼,不然沒法使用mysql命令)
alter user 'root'@'localhost' identified by '你的密碼';
2、源碼版安裝
非root用戶必需要有sudo權限
1.下載相關源碼包
https://mirrors.tuna.tsinghua.edu.cn/gnu/gcc/gcc-9.2.0/gcc-9.2.0.tar.gz https://mirrors.tuna.tsinghua.edu.cn/gnu/gmp/gmp-6.2.0.tar.xz https://mirrors.tuna.tsinghua.edu.cn/gnu/m4/m4-latest.tar.gz https://mirrors.tuna.tsinghua.edu.cn/gnu/mpfr/mpfr-4.0.2.tar.gz https://mirrors.tuna.tsinghua.edu.cn/gnu/mpc/mpc-1.1.0.tar.gz
https://mirrors.tuna.tsinghua.edu.cn/mysql/downloads/MySQL-8.0/mysql-8.0.19.tar.gz
http://dl.bintray.com/boostorg/release/1.70.0/source/boost_1_70_0.tar.gz
https://down.24kplus.com/linux/cmake/cmake-3.16.2.tar.gz
2.安裝低版本的gcc、gcc-c++(必需要作,不然升級gcc安裝m4/gmp/mpfr/mpc時configure會報錯:configure: error: no acceptable C compiler found in $PATH)
到該網址下尋找gcc、gcc-c++及其依賴包(能連外網的能夠直接使用命令:sudo yum -y install gcc gcc-c++)
https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/
3.安裝源碼版cmake
必須安裝openssl和openssl-devel依賴,下載網址同上,不然bootstrap會報錯:找不到openssl(能連外網的能夠直接使用命令:sudo yum -y install openssl openssl-devel)
tar cmake-3.16.1.tgz
cd cmake-3.16.1
sudo ./bootstrap
sudo make
sudo make check
sudo make install
4.升級gcc、gcc-c++
a.安裝m4
tar -xzvf m4-latest.tar.gz
cd m4-1.4.17/
sudo ./configure --prefix=/usr/local(--prefix指定安裝路徑)
sudo make (編譯)
sudo make check (檢查編譯是否有錯,注意是否有Error,能夠不作)
sudo make install (安裝)
m4 --version (查看m4版本)
正確安裝後能夠看到以下結果
b.安裝gmp
sudo ln -s /usr/local/bin/m4 /usr/bin (把m4作一個軟鏈接到此路徑下,不然configure時會報錯:checking for suitable m4... configure: error: No usable m4 in $PATH or /usr/5bin (see config.log for reasons).)
tar -xvf gmp-6.2.0.tar.xz
cd gmp-6.2.0
sudo ./configure --prefix=/usr/local/gmp-6.2 (非管理員必需要sudo,不然會報錯:Permission denied)
sudo make
sudo make check
sudo make install
c.安裝mpfr
tar -xzvf mpfr-4.0.2.tar.gz cd mpfr-4.0.2 sudo ./configure --prefix=/usr/local/mpfr-4.0 --with-gmp=/usr/local/gmp-6.2 (--with-gmp爲gmp的安裝目錄) sudo make sudo make check sudo make install
d.安裝mpc
tar -xzvf mpc-1.1.0.tar.gz cd mpc-1.1 sudo ./configure --prefix=/usr/local/mpc-1.1 --with-gmp=/usr/local/gmp-6.2 --with-mpfr=/usr/local/mpfr-4.0 sudo make sduo make check sudo make install
e.加入庫文件(/usr/local/mpfr-4.0/lib/必須加入庫文件,其餘兩個能夠不作,不然安裝升級gcc編譯時會報錯:error while loading shared libraries: libmpfr.so.6: cannot open shared object file: No such file or directory)
sudo vi /etc/ld.so.conf
/usr/local/mpfr-4.0/lib/
/usr/local/gmp-6.2/lib
/usr/local/mpc-1.1/lib
sudo ldconfig (使上面的操做生效)
或者作軟鏈接
sudo ln -s /usr/local/mpfr-4.0/lib/libmpfr.so.6 /usr/bin
或者複製
sudo cp /usr/local/mpfr-4.0/lib/libmpfr.so.6 /usr/bin/
f.安裝其餘依賴(系統未安裝依賴包時,必需要裝,不然升級gcc編譯時會報錯:mpc.h:沒有那個文件或目錄)
下載gmp-devel和libmpc-devel及其依賴包(能連外網的能夠直接使用命令:sudo yum -y install gmp-devel libmpc-devel)
https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/gmp-6.0.0-15.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/gmp-devel-6.0.0-15.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/libmpc-1.0.1-3.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/libmpc-devel-1.0.1-3.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/mpfr-3.1.1-4.el7.x86_64.rpm https://mirrors.tuna.tsinghua.edu.cn/centos/7/os/x86_64/Packages/mpfr-devel-3.1.1-4.el7.x86_64.rpm
若還有依賴包需下載,請到https://mirrors.tuna.tsinghua.edu.cn自行下載
g.升級gcc
tar -xzvf gcc-9.2.0.tar.gz cd gcc-9.2.0
sudo ./configure --prefix=/usr/local/gcc-9.2 \
--enable-bootstrap\
--enable-checking=release \
--enable-languages=c,c++ \
--enable-threads=posix \
--disable-checking\
--disable-multilib\
--enable--long-long\
--with-gmp=/usr/local/gmp-6.2\
--with-mpfr=/usr/local/mpfr-4.0\
--with-mpc=/usr/local/mpc-1.1
sudo make (編譯時間較長,1個小時的樣子)
sudo make check
sudo make install
務必卸載低版本的gcc、gcc-c++
sudo rpm -e gcc-c++
sudo rpm -e gcc
sudo vi /etc/profile export PATH=$PATH:/usr/local/gcc/bin
source /etc/profile
查看gcc版本號
gcc --version
5.安裝源碼版mysql
安裝ncurses-devel依賴,不然cmake報錯:Curses library not found.Please install appropriate package(能連外網的能夠直接使用命令:sudo yum -y install ncurses-devel,不能連上外網的下載地址同第2步同樣)
tar -xzvf mysql-8.0.19.tar.gz cd mysql-8.0.19
cmake . -DCMAKE_INSTALL_PREFIX=/app/mysql\
-DDEFAULT_CHARSET=utf8\
-DDEFAULT_COLLATION=utf8_general_ci\
-DENABLED_LOCAL_INFILE=ON\
-DWITH_SSL=system\
-DMYSQL_DATADIR=/app/mysql/data\
-DSYSCONFDIR=/app/mysql/config\
-DMYSQL_TCP_PORT=3306\
-DMYSQL_UNIX_ADDR=/app/mysql/mysql.sock\
-DWITH_BOOST=/home/mcbadm/mysql8/\
-DFORCE_INSOURCE_BUILD=1
以上參數介紹以下(簡單的參數,更詳細參數請參考https://blog.51cto.com/laowafang/1294964):
-DCMAKE_INSTALL_PREFIX:安裝目錄
-DDEFAULT_CHARSET:設置字符集
-DDEFAULT_COLLATION:設置排序規則
-DENABLED_LOCAL_INFILE=ON:啓用本地數據導入支持
-DWITH_SSL=system:啓用ssl庫支持
-DMYSQL_DATADIR:數據文件目錄,可任意
-DSYSCONFDIR:配置文件目錄,可任意
-DMYSQL_TCP_PORT:mysql監聽的TCP端口
-DMYSQL_UNIX_ADDR:mysql.sock路徑,可任意
-DWITH_BOOST:boost源碼包所在目錄
-DFORCE_INSOURCE_BUILD:強制創建未存在的資源目錄
cmake若報錯,請找到緣由解決後刪除CMakeCache.txt再次cmake
sudo rm -rf /usr/lib64/libstdc++.so.6* (刪掉全部低版本c++的庫文件)
sudo ln -s /usr/local/gcc-9.2/lib64 /usr/lib64 (把新安裝的高本版c++庫文件加入到系統庫文件中)
sudo make (須要大概1小時)
sudo make install
6.編寫配置文件,創建目錄並受權
sudo mkdir /app/mysql/config
sudo cd /app/mysql
sudo vi config/my.cnf
加入如下內容:
[mysqld] user=mysql port=3306 datadir=/app/mysql/data socket=/app/mysql/mysql.sock [mysqld_safe] log-error=/app/mysql/logs/mysql-err.log pid-file=/app/mysql/mysql.pid [client] socket=/app/mysql/mysql.sock
sudo useradd mysql -s /sbin/nologin
sudo mkdir -p /app/mysql/logs
sudo touch /app/mysql/logs/mysql-err.log
sudo chown -R mysql.mysql /app/mysql
7.初始化並登錄修改密碼
初始化 sudo /app/mysql/bin/mysqld --initialize-insecure --user=mysql --datadir=/app/mysql/data --basedir=/app/mysql (無初始密碼的,若想要初始密碼,使用--initialize) 啓動 sudo /app/mysql/support-files/mysql.server start 登錄(若無初始密碼直接回車便可) sudo /app/mysql/bin/mysql -p修改密碼alter user 'root'@'localhost' identified by '密碼';