Centos 6下使用cmake編譯安裝MariaDB

来源:https://www.cnblogs.com/liuxiantong/archive/2019/10/02/11583307.html
-Advertisement-
Play Games

寫在前面 最近在學習Maria DB,為了方便查閱,又為了將所學的知識重新的梳理,特作此隨筆一篇,希望過後閱讀時能有所感,也希望對大家能夠有所幫助。 安裝前的準備 大家都知道,在Linux上安裝軟體一共有三種方式:1、rpm包安裝 。2、二進位程式包安裝。3、源碼編譯安裝。對於前2種方式安裝起來會便 ...


寫在前面

最近在學習Maria DB,為了方便查閱,又為了將所學的知識重新的梳理,特作此隨筆一篇,希望過後閱讀時能有所感,也希望對大家能夠有所幫助。

安裝前的準備

大家都知道,在Linux上安裝軟體一共有三種方式:1、rpm包安裝 。2、二進位程式包安裝。3、源碼編譯安裝。對於前2種方式安裝起來會便捷不少,但是定製化程度低,當我們需要進行軟體diy時,那麼編譯安裝就再合適不過了。

對於CentOS 6 來說,使用yum安裝,yum源裡面預設提供的是低版本MySQL,因此當我們想要安裝Maria DB時,則需要使用編譯安裝。到CentOS 7後,可以使用yum源直接按照MariaDB。

1、依賴的庫和包

 在編譯之前,我們需要安裝一些以來的庫和包

yum -y groupinstall "Development tools" "Server Platform Development" #這兩個庫中包含很多常用的軟體,例如openssl-devel、bison等
yum -y install cmake lrzsz #此處的lrzsz是一個用於物理機和虛擬機之間傳輸文件的軟體,後面要將軟體包從物理機中拷貝到虛擬機中。

 2、其他相關的設置

grouped -r -g 306 mysql    #添加一個系統組
useraddd -r -u 306 -g 306 mysql  #添加一個系統用戶並且加入對應的系統組中

mkdir -p /data/mysql    #為MariaDB設置對應目錄
chown -R mysql.mysql /data/mysql  #改變對應的屬組屬主,以便寫入數據

安裝mariaDB

1、解壓到制定文件夾

rz     #由於此處MariaDB是放到物理機桌面的,因此使用此命令進行傳輸
tar -xf mariadb-10.0.13.tar.gz 
cd mariadb-10.0.13.tar.gz

2、安裝

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \   #安裝目錄為/usr/local/mysql,其中mysql目錄可以不事先建立。
-DMYSQL_DATADIR=/data/mysql \          #數據存儲的目錄,需要事先建立,並且設置好屬主屬組,方便對應的屬主屬組讀寫數據
-DWITH_XTRADB_STORAGE_ENGINE=1 \        #預設已存在CSV和MyISAM存儲引擎,因此加入FEDERATEDX、ARCHIVE、MYISAM、INNOBASE、BLACKHOLE存儲引擎。其中innoDB最常用。
-DWITH_FEDERATEDX_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DWITH_SSL=system \                #加入ssl、zlib庫 
-DWITH_ZLIB=system \
-DDEFAULT_CHARSET=utf8 \             #設置字元集
-DDEFAULT_COLLATION=utf8_general_ci      #設置排序方式

註:當此步驟出現

-- Configuring done
-- Generating done

” 時,即可進行下一步安裝。

此步驟會生成一個"CMakeCache.txt"文件,當出現問題時,需要將其刪除後重新編譯。

make

make install

安裝完成後

1、MariaDB加入環境變數  

vim /etc/profile.d/mysql.sh
  export PATH=$PATH:/usr/local/mysql/bin  #加入此內容
. /etc/profile.d/mysql.sh    #重新載入,使其生效,必須使.sh結尾,否則僅僅當前會話生效。

2、設置配置文件並初始化

chown -R mysql.mysql /usr/local/mysql #設置屬主和數組,方便寫入配置文件
cd /usr/local/mysql cp support-files/my-large.cnf /etc/my.cnf #添加配置文件,並且在[mysqld]中加入下麵三行配置信息   "datadir=/data/mysql/   innodb_file_per_table=on   skip_name_resolve=on" scripts/mysql_install_db --user=mysql --datadir=/data/mysql #註意:此初始化腳本必須在/usrl/local/mysql這個目錄中執行,否則會報錯。
  初始化後,數據目錄會有一些原始數據

    ls /data/mysql/
    aria_log.00000001 ib_logfile0 mysql-bin.000001 mysql-bin.state
    aria_log_control ib_logfile1 mysql-bin.000002 performance_schema
    ibdata1 mysql mysql-bin.index test

3、加入系統啟動項

 cp support-files/mysql.server /etc/init.d/mysqld    
 chmod +x /etc/init.d/mysqld   #給腳本增加執行許可權
 chkconfig mysqld on #加入開機啟動項

4、MariaDB用戶安全初始化

 /usr/local/mysql/bin/mysql_secure_installation 
#此步驟會設置root密碼、禁止root遠程登錄、移除一名用戶,刪除測試資料庫,並且重新載入授權表。根據自己喜好選擇即可。
PS:當MariaDB啟動時,才開始進行此操作。

5、登錄操作

[root@mycentos ~]# mysql -uroot -p     #登錄命令,以root用戶登錄,密碼為上一步操作所設置的。
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 15
Server version: 10.0.13-MariaDB-log Source distribution  #此處為MariaDB的版本

Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  
MariaDB [(none)]>   #已經進入資料庫,完成編譯安裝!!!

 

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、需求 基地新到300台伺服器,需要自實施安裝CentOS7.6版本操作系統,選擇使用PXE進行批量安裝。 二、準備工作 使用二層交換機連接未安裝操作系統伺服器,避免影響現網正常伺服器。 上傳操作系統鏡像到伺服器並安裝PXE環境必備服務。 掛載鏡像文件作為本地軟體倉庫。 環境準備 systemct ...
  • Ubuntu armhf 版本國內源: ...
  • 邏輯捲管理器是Linux系統用於對硬碟分區進行管理的一種機制,理論性較強,其創建初衷是為瞭解決硬碟設備在創建分區後不易修改分區大小的缺陷. ...
  • STM32串口通信(F1系列包含3個USART和2個UART) 一、單片機與PC機串列通信研究目的和意義: 單片機自誕生以來以其性能穩定,價格低廉、功能強大、在智能儀器、工業裝備以及日用電子消費產品中得到了廣泛的應用。在單片機的輸入輸出控制中,除直接接上小鍵盤和LCD顯示屏等方法外,一般都通過串口和 ...
  • bond模式: Mode=0(balance-rr) 表示負載分擔round-robin,和交換機的聚合強制不協商的方式配合Mode=1(active-backup) 表示主備模式,只有一塊網卡是active,另外一塊是備的standbyMode=2(balance-xor) 表示XOR Hash負 ...
  • 環境:Win10 - 1903 Q1:安裝使用Hyper-V後,安裝Virtual box新建VM,無法啟動 A1:卸載Hyper-V(非必須) 管理員運行ps/cmd bcdedit /set hypervisorlaunchtype off (禁止hyper-v) 重啟電腦恢復 Q2:卸載Vi ...
  • MySQL 顯示 Can't connect to MySQL server on 'localhost' (10061)怎麼解決 在cmd中配置啟動sql後,找不到密碼。然後怎麼也沒辦法弄,不知道怎麼回事,最後聽人建議,解決了問題。 在MySQL的bin目錄找到了一個文件“電腦名.er”,用記事本 ...
  • 資料庫管理 表管理 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...