首頁 資料庫 mysql教程 怎麼透過Systemd編譯Mysql5.7.11

怎麼透過Systemd編譯Mysql5.7.11

May 29, 2023 pm 06:46 PM
mysql systemd

怎麼透過Systemd編譯Mysql5.7.11


MySQL 5.7主要功能:

原生支援Systemd 更好的效能:對於多核心CPU、固態硬碟、鎖定有著更好的優化更好的InnoDB儲存引擎更為健壯的複製功能:複製帶來了資料完全不遺失的方案,傳統金融客戶也可以選擇使用MySQL資料庫。此外,GTID在線平滑升級也變得可能更好的優化器:優化器程式碼重構的意義將在這個版本及以後的版本中帶來巨大的改進,Oracle官方正在解決MySQL之前最大的難題原生JSON類型的支援更好的地理資訊服務支援:InnoDB原生支援地理位置類型,支援GeoJSON,GeoHash特性新增sys庫:以後這會是DBA存取最頻繁的庫MySQL 5.7已經作為資料庫可選項新增至OneinStack — lnmp安裝工具中

安裝依賴包

yum -y install make gcc-c++ cmake bison-devel ncurses-devel
登入後複製

#下載mysql源碼包

源碼包有兩種版本: mysql- 5.7.11.tar.gz 不含boost函式庫,需自行下載。

mysql-boost-5.7.11.tar.gz 自帶 boost函式庫,解壓縮後的根目錄,推薦下載。 wget http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-boost-5.7.11.tar.gz

curl -O http://cdn.mysql .com/Downloads/MySQL-5.7/mysql-boost-5.7.11.tar.gz

tar -zxf mysql-boost-5.7.11.tar.gz

# mysql-5.7 .11

編譯

產生makefile「

cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_DATADIR=/usr/local/ mysql/data \ -DSYSCONFDIR=/etc \ -DWITH_MYISAM_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_MEMORY_STORAGE_ENGINE=1 \ -LEDMYSQL_TCP_PORT=3306 -DENAB3306_DEN-LEDD _CHARSETS=all \ -DDEFAULT_CHARSET=utf8 \ [字元集] -DDEFAULT_COLLATION=utf8_general_ci \ [排序規則必須有,不然初始化資料庫困難] -DDOWNLOAD_BOOST=1 \ [從MySQL 5.7.5開始Boost程式庫是必要的] -DWITH_BOOST=/root/mysql-5.7.11/5.7.11/ boost \ -DWITH_SYSTEMD=1 [支援Systemd] 加上 -DWITH_SYSTEMD=1可以使用systemd控制mysql服務,預設是不開啟systemd的。

然後make -j 2 && make install# mysql將會安裝到/usr/local/mysql路徑慢慢等……

配置MySQL

新增mysql用戶和群組

groupadd mysql
登入後複製

useradd -g mysql -s /sbin/nologin mysql

修改/usr/local/mysql權限

chown -R mysql:mysql /usr/local/mysql
登入後複製

建立mysql PID 預設目錄

在mysqld.service ,把預設的pid檔案指定到了/var/run/mysqld/ 目錄,而並沒有事先建立該目錄,因此要手動建立該目錄並把權限賦給mysql 用戶。 mkdir -p /var/run/mysqldchown mysql:mysql /var/run/mysqld

mysql 三個運行檔案預設位置

log : /var/log/mysqld.logpid : /var/run/mysqld/mysqld.pidsock : /tmp/mysql.sock
登入後複製

#拷貝my.cnf 和mysqld.service

cp support-files/my-default.cnf /etc/my.cnf
登入後複製

mysql 5.7 預設將mysqld.service

mysql -u root -p
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; [password 为远程连接密码]
mysql>FLUSH PRIVILEGES; [刷新权限]
登入後複製
登入後複製

mysql 5.7 預設將mysqld.service

##rrreeemysql 5.7 預設將mysqld.service##rrreee

mysql 5.7 預設將mysqld.service (/usr/local/mysql/)檔案安裝到了mysql 安裝目錄下的usr/lib/systemdusr/lib/systemd /system/,將mysqld.service 複製到/usr/lib/systemd/system/目錄下

[root@localhost]/usr/local/mysql#cp usr/lib/systemd/system/mysqld.service /usr /lib/systemd/system

新增環境變數

#— 編輯/etc/profile檔案最後加上以下兩行— “

vim /etc/profile

PATH=/usr/local/mysql/bin:$PATH export PATH

##source /etc/profile

初始化無密碼mysql 資料庫

bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/ databin/mysql_ssl_rsa_setup

出現下列內容,初始化成功2016-02-22T03:56:27.254356Z 1 [Warning] root@localhost is created with an empty password ! Please consider itching alease consider.

#-–initialize 會產生一個隨機密碼(儲存在~/.mysql_secret),而-–initialize-insecure 不會產生密碼,在MySQL安全設定精靈mysql_secure_installation設定密碼時,可自由選擇mysql 密碼等級。

-–datadir目標目錄下不能有資料檔。

先前版本初始化程式mysql_install_db 是在/usr/local/mysql/script 下,並會在將來被移除,轉而使用mysqld替代已被廢棄mysql5.7 放在了/usr/local/ mysql/bin 目錄下。

啟動mysql

systemctl start mysqld.service

systemctl status mysqld.service##執行MySQL安全性設定精靈mysql_secure_installation 設定密碼,mysql 服務啟動後才可執行

a)為root用戶設定密碼b)刪除匿名帳號c)取消root用戶遠端登入d)刪除test庫和對test庫的存取權e)刷新授權表使修改生效

[root@localhost mysql]# mysql_secure_installation#########Securing the MySQL server deployment.###

Connecting to MySQL using a blank password. [使用空密码连接到MySQL]

VALIDATE PASSWORD PLUGIN can be used to test passwords and improve security. It checks the strength of password and allows the users to set only those passwords which are secure enough. Would you like to setup VALIDATE PASSWORD plugin?[VALIDATE密码插件可以被用来测试密码 并提高安全性。你是否想设置VALIDATE密码插件?]

Press y|Y for Yes, any other key for No: y

There are three levels of password validation policy: [有三种级别的密码验证策略:]

LOW Length >= 8 MEDIUM Length >= 8, numeric, mixed case, and special characters STRONG Length >= 8, numeric, mixed case, special characters and dictionary file [最小长度> = 8 中等长度> = 8,数字,大小写混合和特殊字符 最长长度> = 8,数字,混合大小写,特殊字符和字典文件]

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0 [请输入0 =低,1 =中2 =强:0] Please set the password for root here. [请在这里设置root用户的密码。]

New password: [新密码:]

Re-enter new password: [重新输入新密码:]

Estimated strength of the password: 25 [密码的估计强度:25] Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y [您是否希望继续与提供的密码(按y | Y表示是,因为没有任何其他键):Y?] … Failed! Error: Your password does not satisfy the current policy requirements [ … 失败!错误:您的密码不符合当前的要求]

New password:

Re-enter new password:

Estimated strength of the password: 50 [密码的估计强度:50] Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y By default, a MySQL installation has an anonymous user, allowing anyone to log into MySQL without having to have a user account created for them. This is intended only for testing, and to make the installation go a bit smoother. You should remove them before moving into a production environment. [默认情况下,MySQL安装有一个匿名用户, 允许任何人登录到MySQL.]

Remove anonymous users? (Press y|Y for Yes, any other key for No) : y [删除匿名用户?] Success. [成功。]

Normally, root should only be allowed to connect from ‘localhost’. This ensures that someone cannot guess at the root password from the network. [通常情况下,Root 只允许其进行’localhost'(本地) 连接 。]

Disallow root login remotely? (Press y|Y for Yes, any other key for No) : n [禁止远程root登录?]

...omitting. [省略]。] By default, MySQL comes with a database named ‘test’ that anyone can access. This is also intended only for testing, and should be removed before moving into a production environment. [默认情况下,MySQL带有一个名为“测试”数据库,任何人都可以访问。这也是仅用于测试,并且应该移动到生产之前被删除环境。]

Remove test database and access to it? (Press y|Y for Yes, any other key for No) : n [删除测试数据库和访问权限?]

... omitting. [ ...省略。] Reloading the privilege tables will ensure that all changes made so far will take effect immediately. [刷新授权表以确保所有的变化取得将立即生效。]

Reload privilege tables now? (Press y|Y for Yes, any other key for No) : [现在刷新授权表?]

… skipping. All done! [全部完成!]

开放 Root 远程连接权限

mysql -u root -p
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; [password 为远程连接密码]
mysql>FLUSH PRIVILEGES; [刷新权限]
登入後複製
登入後複製

以上是怎麼透過Systemd編譯Mysql5.7.11的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mysql:簡單的概念,用於輕鬆學習 mysql:簡單的概念,用於輕鬆學習 Apr 10, 2025 am 09:29 AM

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

phpmyadmin怎麼打開 phpmyadmin怎麼打開 Apr 10, 2025 pm 10:51 PM

可以通過以下步驟打開 phpMyAdmin:1. 登錄網站控制面板;2. 找到並點擊 phpMyAdmin 圖標;3. 輸入 MySQL 憑據;4. 點擊 "登錄"。

navicat premium怎麼創建 navicat premium怎麼創建 Apr 09, 2025 am 07:09 AM

使用 Navicat Premium 創建數據庫:連接到數據庫服務器並輸入連接參數。右鍵單擊服務器並選擇“創建數據庫”。輸入新數據庫的名稱和指定字符集和排序規則。連接到新數據庫並在“對象瀏覽器”中創建表。右鍵單擊表並選擇“插入數據”來插入數據。

MySQL:世界上最受歡迎的數據庫的簡介 MySQL:世界上最受歡迎的數據庫的簡介 Apr 12, 2025 am 12:18 AM

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

為什麼要使用mysql?利益和優勢 為什麼要使用mysql?利益和優勢 Apr 12, 2025 am 12:17 AM

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

navicat怎麼新建連接mysql navicat怎麼新建連接mysql Apr 09, 2025 am 07:21 AM

可在 Navicat 中通過以下步驟新建 MySQL 連接:打開應用程序並選擇“新建連接”(Ctrl N)。選擇“MySQL”作為連接類型。輸入主機名/IP 地址、端口、用戶名和密碼。 (可選)配置高級選項。保存連接並輸入連接名稱。

redis怎麼使用單線程 redis怎麼使用單線程 Apr 10, 2025 pm 07:12 PM

Redis 使用單線程架構,以提供高性能、簡單性和一致性。它利用 I/O 多路復用、事件循環、非阻塞 I/O 和共享內存來提高並發性,但同時存在並發性受限、單點故障和不適合寫密集型工作負載的局限性。

MySQL和SQL:開發人員的基本技能 MySQL和SQL:開發人員的基本技能 Apr 10, 2025 am 09:30 AM

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

See all articles