centos7.2安裝mysql5.7.13

博主QQ:819594300mysql

博客地址:http://zpf666.blog.51cto.com/sql

有什麼疑問的朋友能夠聯繫博主,博主會幫大家解答,謝謝支持!docker

另外本博文內使用的所有軟件和文件,博友若有須要能夠去我百度雲分享下載,分享地址是:數據庫

連接:http://pan.baidu.com/s/1bpaOqa7 密碼:r2jscentos

1、MySQL 5.7主要特性:數組

原生支持Systemd安全

更好的性能:對於多核CPU、固態硬盤、鎖有着更好的優化服務器

更好的InnoDB存儲引擎網絡

更爲健壯的複製功能:複製帶來了數據徹底不丟失的方案,傳統金融客戶也能夠選擇使用MySQL數據庫。多線程

注:從mysql5.6.3版本開始就已經支持了多線程的主從複製

新增sys庫:之後這會是DBA訪問最頻繁的庫

更好的優化器:優化器代碼重構的意義將在這個版本及之後的版本中帶來巨大的改進,Oracle官方正在解決MySQL以前最大的難題原生JSON類型的支持(JavaScript Object Notation)

注:JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。JSON採用徹底獨立於語言的文本格式,可是也使用了相似於C語言家族的習慣(包括C、C++、C#、Java、JavaScript、Perl、Python等)。這些特性使JSON成爲理想的數據交換語言。 易於人閱讀和編寫,同時也易於機器解析和生成(通常用於提高網絡傳輸速率)。

JSON 語法是 JavaScript 對象表示語法的子集。

數據在鍵值對中

數據由逗號分隔

花括號保存對象

方括號保存數組

用JSON編寫的文件,能夠代替.yaml格式的文件。(docker  kubernetes中用的到,建立RC)。

2、安裝mysql5.7.13

1、系統環境:centos7.2x86_64

wKiom1jRHRbR1xfEAAEZgegEhH8122.jpg

:由於centos7.2默認安裝了mariadb-libs,因此先要卸載掉

先查看本系統是否安裝mariadb

wKioL1jRHRfx_l-xAAPNuBAOU8U080.jpg

2、安裝依賴包

注: 相關依賴包的做用

cmake:因爲從MySQL5.5版本開始棄用了常規的configure編譯方法,因此須要CMake編譯器,用於設置mysql的編譯參數。如:安裝目錄、數據存放目錄、字符編碼、排序規則等。

Boost:從MySQL 5.7.5開始Boost庫是必需的,mysql源碼中用到了C++的Boost庫,要求必須安裝boost1.59.0或以上版本

GCC:是Linux下的C語言編譯工具,mysql源碼編譯徹底由C和C++編寫,要求必須安裝GCC

bison:Linux下C/C++語法分析器

ncurses:字符終端處理庫

1)安裝文件準備

下載cmake-3.5.tar.gz       http://wwwNaNake.org/download/

下載ncurses-5.9.tar.gz    ftp://ftp.gnu.org/gnu/ncurses/

下載bison-3.0.4.tar.gz    http://ftp.gnu.org/gnu/bison/

下載mysql-5.7.13.tar.gz

wget http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-5.7.13.tar.gz

下載Boost_1_59_0.tar.gz

wget  http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz

2)安裝CMAKE及必要的軟件

安裝cmake

wKiom1jRHRijUFf1AAGGsHALKGY536.jpg

cmake –version ---查看cmake版本

wKioL1jRHRiQt2x8AAC1roJ1PWw682.jpg

安裝ncurses

wKioL1jRHRmhuy_SAAEVi3ZvrQA401.jpg

安裝bison

wKiom1jRHRnQCG1-AAEKc8rh6DU218.jpg

安裝bootst

wKioL1jRHRry4z31AAE8mBVBLbo858.jpg

3)建立mysql用戶和用戶組及目錄

wKiom1jRHRqSnYqFAAIezNxPaNw866.jpg

wKioL1jRHRvTGZDiAAGn7LYMwm4984.jpg

3、編譯安裝mysql並優化

解壓mysql源碼包:

wKiom1jRHRvzCynlAAJMbhwo4aI319.jpg

wKiom1jRHR2ysmE-AALRuMRiqTc541.jpg

:若要從新運行cmake配置,須要刪除CMakeCache.txt文件(即前面的配置、編譯、安裝後發現有錯誤,咱們這時候無須重頭來只須要刪除CMakeCache.txt文件)

wKioL1jRHR6CuAWmAAL7OzRA9qo805.jpg

優化Mysql的執行路徑:

wKiom1jRHR6C9z7XAAB2XLFLGyY417.jpg

wKioL1jRHR-RlWrUAAENtw1LGlU849.jpg

wKioL1jRHR_iPNNSAAClfdCrusg272.jpg

4、設置權限並初始化MySQL系統受權表

wKiom1jRHSCCV5KcAAOEazBcqQo492.jpg

說明:(5.7.6版本之後的可採用安裝模式或者可使用非安裝模式)

wKiom1jRHSGTd7IfAAMQupzlt9E097.jpg

以防萬一,再次改一下屬主和屬組

wKioL1jRHSLQuIMoAACcrXX2Y_A782.jpg

5、建立配置文件

wKiom1jRHSLSB-aFAAGUOvkD7Tc893.jpg

修改my.cnf配置文件:

wKioL1jRHSKyq-glAAByWHXpkfE474.jpg

wKiom1jRHSXTk7mjAAaKeb8yaJA730.jpg

6、配置mysql自動啓動

wKioL1jRHSaSrNbHAAG_S0XnAuc694.jpg

wKiom1jRHSfDbuvVAAJA6l_lgAw458.jpg

wKioL1jRHSzzj6dyAAG02X9ugB0266.jpg

wKioL1jRHS3S8FM2AACBPHXVIUU496.jpg

wKiom1jRHTLDHZH3AAGEBW051CE204.jpg

wKiom1jRHTaR_xLtAAFnTAlOMJY635.jpg

wKioL1jRHTygZ75vAAHjQLXp_Xw404.jpg

wKioL1jRHT-RxmZLAAD-ktRfBAA391.jpg

訪問MySQL數據庫:

wKiom1jRHUfxOtAWAAJsuigaoG4680.jpg

修改數據庫管理員用戶root的密碼(隨機密碼每每很難記憶,咱們要修改爲本身的密碼)

wKiom1jRHU2iK5rKAAG1C49n9H0632.jpg

7、實現基於ssl安全鏈接的主從複製

1)在主mysql建立SSL/RSA文件

wKioL1jRHVTyTaBjAAJPvuA-tZ4150.jpg

wKioL1jRHXahJnU2AAFvyHPNHIE805.jpg

wKiom1jRHX7wUc_QAAJYjqGcJe4835.jpg

wKioL1jRHYLCLURPAAKWRXczvXc472.jpg

wKiom1jRHYmhAl_UAAIwF24OyYs853.jpg

wKioL1jRHY2BBZ6jAAFloJNC6oI875.jpg

wKioL1jRHZnzhx7XAAN4K4-p21E670.jpg

wKioL1jRHaShaELPAAOObCrsEw4975.jpg

wKiom1jRHamztSgFAAHBJnnhqcA431.jpg

wKiom1jRHa6jNbzwAAGXEYqn2oo052.jpg

wKioL1jRHbThvgSbAAHfQK2iYoI924.jpg

wKioL1jRHbnjxaLcAAG1EJBGBNc724.jpg

wKiom1jRHb6wT6qsAAFucddm4Cw475.jpg

wKiom1jRHcLxxvATAAGC0HAP55Q989.jpg

wKioL1jRHceRN2vrAAG_GlW8WbE526.jpg

wKiom1jRHdSgN16yAAPbT1f1VVI575.jpg

wKioL1jRHdizopxfAAFAe7oHzqI229.jpg

wKioL1jRHd7AImS1AAH_YqUM8Rs292.jpg

wKiom1jRHeHSg18jAAEk6GMfo04386.jpg

wKiom1jRHeiDnAwYAAJGIwgJmM4952.jpg

wKioL1jRHezChYcXAAFxCQ8D3OE188.jpg

wKioL1jRHfGQscdGAAFh6MjKp78308.jpg

wKiom1jRHfXxUodZAAFfaX0nZ1Q488.jpg

wKioL1jRHf6A5t5eAALWEx1SY0s754.jpg

那麼在配置主從複製以前能夠在從mysql上用SSL鏈接主服務器試試:

wKiom1jRHgKDOc24AAGablxMJgU488.jpg

wKiom1jRHgOTR5gkAAGxDKm7H9M358.jpg

wKioL1jRHgOQH1r2AAFmOKeKMgo592.jpg

wKiom1jRHgTDKt9VAADt2RqGy1s150.jpg

wKioL1jRHgSDzU0uAAF1O4jQMLA941.jpg

wKioL1jRHgWTTaOgAAND997iulI759.jpg

wKiom1jRHgbQNfv7AAD3T3bSJig491.jpg

wKiom1jRHgawQGDMAAIt7rKwrS8855.jpg

wKioL1jRHgei2crYAAGt2Af0RqM152.jpg

wKioL1jRHiLDiXbwAAK749-iqYU129.jpg

下面測試主從複製:

先在master上寫入一些數據:

wKiom1jRHiOCrDZgAAML9shvt6g588.jpg

去slave上驗證一下,數據是否同步:

wKioL1jRHiTSvCZQAALhxiYpcBg625.jpg

wKiom1jRHiXDFBCdAAIaAU8MOLM695.jpg

以上同步成功。

總結:

SSL(Secure SocketsLayer 安全套接層),及其繼任者傳輸層安全(Transport Layer Security,TLS)是爲網絡通訊提供安全及數據完整性的一種安全協議。複製默認是明文進行傳輸的,經過SSL加密能夠大大提升數據的安全性。

相關文章
相關標籤/搜索