MySQL5.7.17源碼編譯安裝與配置


一、下載MySQL源碼

官網: http://www.mysql.com
下載下來的文件為:mysql-boost-5.7.17.tar.gz

二、解壓源碼,准備環境

[root@server1 software]# tar -zxf mysql-boost-5.7.17.tar.gz [root@server1 software]# ls [root@server1 software]# cd mysql-5.7.17/ [root@server1 mysql-5.7.17]# ls [root@server1 mysql-5.7.17]# vim README [root@server1 mysql-5.7.17]# vim INSTALL

這里寫圖片描述
這里寫圖片描述

幫助文檔里給我們的是一個網址,打開看看
這里寫圖片描述
可以用cmake的方式,這里我們看到這里只列出了幾個選項,更多選項又被鏈接到了另外一個網址,打開看看
這里寫圖片描述

這么多選項,我們根據需要進行選擇,先看看從cmake –help
這里寫圖片描述

這就尷尬了,沒有安裝cmake,看看本機yum源里的cmake版本
這里寫圖片描述

cmake跨平台工具是用來預編譯mysql源碼的,用於設置mysql的編譯參數。如:安裝目錄、數據存放目錄、字符編碼、排序規則等。所以安裝yum源里帶的即可

[root@server1 mysql-5.7.17]# yum install -y cmake.x86_64
  • 1

這里寫圖片描述

cmake –help似乎沒提供什么我們需要的選項,還是參照mysql的官方文檔來吧
這里寫圖片描述
編譯環境
官方文檔說明:http://dev.mysql.com/doc/refman/5.7/en/source-installation.html
從官方文檔知:需要以下依賴庫

  • make 3.75
    • mysql源代碼是由C和C++語言編寫,在linux下使用make對源碼進行編譯和構建,要求必須安裝make 3.75或以上版本
  • gcc4.4.6
    • GCC是Linux下的C語言編譯工具,mysql源碼編譯完全由C和C++編寫,要求必須安裝GCC4.4.6或以上版本
  • Boost1.59.0
    • mysql源碼中用到了C++的Boost庫,要求必須安裝boost1.59.0或以上版本
  • bison2.1
    • Linux下C/C++語法分析器
  • ncurses
    • 字符終端處理庫
      由於我們下載的源碼包含boost,所以我們只需要安裝其他的依賴庫即可
[root@server1 mysql-5.7.17]# yum install -y make.x86_64 gcc-c++.x86_64 bison.x86_64 ncurses.x86_64
  • 1

這里寫圖片描述

依賴庫安裝好了,我們將boost移至/usr/local下,方便使用

[root@server1 mysql-5.7.17]# cp -r boost/boost_1_59_0/ /usr/local/ [root@server1 mysql-5.7.17]# ls /usr/local/boost_1_59_0/ boost

由於是源碼安裝,不同於玉米安裝,不會自動幫我們創建用戶,所以需要我們創建用戶

[root@server1 mysql-5.7.17]# groupadd mysql #添加mysql用戶組 [root@server1 mysql-5.7.17]# useradd -r -g mysql -s /bin/false mysql #添加mysql用戶
  • 1
  • 2

三、編譯安裝

配置mysql預編譯參數

參考mysql官方文檔說明:http://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html#cmake-general-options

[root@server1 mysql-5.7.17]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_BOOST=/usr/local/boost_1_59_0/ -DSYSCONFDIR=/etc -DEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all
  • DCMAKE_INSTALL_PREFIX:安裝路徑
  • DMYSQL_DATADIR:數據存放目錄
  • DWITH_BOOST:boost源碼路徑
  • DSYSCONFDIR:my.cnf配置文件目錄
  • DEFAULT_CHARSET:數據庫默認字符編碼
  • DDEFAULT_COLLATION:默認排序規則
  • DENABLED_LOCAL_INFILE:允許從本文件導入數據
  • DEXTRA_CHARSETS:安裝所有字符集
    這里寫圖片描述
    預編譯報錯,提示remove CMakeCache.txt ,redhat還需要ncurses-devel , yum 安裝之
[root@server1 mysql-5.7.17]# rm -rf CMakeCache.txt [root@server1 mysql-5.7.17]# yun install -y ncurses-devel

繼續執行cmake預編譯

編譯並安裝

[root@server1 mysql-5.7.17]# make ##可加參數-j根據CPU核數指定編譯時的線程數,可以加快編譯速度。默認為1個線程編譯,經測試四核CPU,2G的內存,單先程編譯完需要20分鍾左右。 [root@server1 mysql-5.7.17]# makeinstall

這里寫圖片描述
這里寫圖片描述
至此,編譯安裝完成,下面進行簡單的配置使用

mysql簡單配置

初始化系統數據庫

[root@server1 mysql-5.7.17]# cd /usr/local/mysql/ [root@server1 mysql]# ll -d drwxr-xr-x 10 root root 4096 Sep 23 22:45 . [root@server1 mysql]# chown -R mysql:mysql . [root@server1 mysql]# ll -d drwxr-xr-x 10 mysql mysql 4096 Sep 23 22:45 . [root@server1 mysql]# ./bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data 2017-09-24T03:01:29.063554Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2017-09-24T03:01:29.068209Z 0 [ERROR] COLLATION 'utf8mb4_general_ci' is not valid for CHARACTER SET 'latin1' 2017-09-24T03:01:29.068253Z 0 [ERROR] Aborting 

提示字符集有錯

[root@server1 mysql]# vim /etc/my.cnf ##編輯:增加兩個編碼變量 #改成如下,如果沒有該文件,可拷貝一份,命令如下 ##cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cn [client] default-character-set=gbk ##增加的編碼變量 [mysqld] character_set_server=gbk ##增加的編碼變量 datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock user=mysql 

在初始化即可
這里寫圖片描述
如果使用–initialize參數初始化系統數據庫之后,會在~/.mysql_secret文件中生成root用戶的一個臨時密碼,同時也在初始化日志中打印出來了,如下圖(fy<;iif!U95r):
這里寫圖片描述

配置mysql服務並啟動服務

[root@server1 init.d]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld [root@server1 init.d]# chkconfig --add mysqld ## 添加到系統服務 [root@server1 init.d]# chkconfig mysqld on ## 開機啟動 [root@server1 ~]# /etc/init.d/mysqld ##查看提供哪些用法 Usage: mysqld {start|stop|restart|reload|force-reload|status} [ MySQL server options ] [root@server1 ~]# /etc/init.d/mysqld start ##測試開啟服務 Starting MySQL. SUCCESS! [root@server1 ~]# /etc/init.d/mysqld stop ##測試停止服務 Shutting down MySQL. SUCCESS! [root@server1 ~]# /etc/init.d/mysqld start ##開啟服務 [root@server1 ~]# ln -s /usr/local/mysql/bin/mysql /usr/local/bin/mysql ##添加軟鏈接將mysql加入系統環境變量,或者通過配置環境變量,export PATH=/usr/local/mysql/bin:$PATH 或者vim /etc/profile

測試啟動

[root@server1 ~]# mysql -uroot -pfy<;iif!U95r ##密碼為剛才初始化時生成的 -bash: !U95r: event not found ##秘密包含特殊字符,不能這樣寫 [root@server1 ~]# mysql -uroot -p Enter password: ##輸入密碼 ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) ##報錯 [root@server1 ~]# ln -s /var/lib/mysql/mysql.sock /tmp ##軟鏈接 [root@server1 ~]# mysql -uroot -p ##再來 Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 6 Server version: 5.7.17 Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> ##登陸成功 

設置數據庫密碼

mysql> set password for root@localhost=password('mypasswd'); Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> mysql> exit Bye [root@server1 ~]# mysql -uroot -pmypasswd mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 7 Server version: 5.7.17 Source distribution Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> 

修改成功,可以進行數據庫的操作了

mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | sys | +--------------------+ 4 rows in set (0.00 sec) mysql> CREATE database mydatabase  -> ; Query OK, 1 row affected (0.00 sec) mysql> SHOW databases  -> ; +--------------------+ | Database | +--------------------+ | information_schema | | mydatabase | | mysql | | performance_schema | | sys | +--------------------+ 5 rows in set (0.00 sec) mysql> use mydatabase Database changed mysql> show tables  -> ; Empty set (0.00 sec) mysql> 

這里寫圖片描述


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM