【MySQL】MySQL8安裝

来源:https://www.cnblogs.com/kuxingsengwm/archive/2023/01/16/17053038.html
-Advertisement-
Play Games

1. MySQL8安裝 安裝環境 操作系統:CentOS7 MySQL版本:8.0.28 安裝方式:二進位Generic 軟體路徑:/app/database 數據路徑:/data/3306 日誌路徑:/binlog/3306 MySQL Community Server 社區版官網下載鏈接 MyS ...


1. MySQL8安裝

安裝環境

  • 操作系統:CentOS7
  • MySQL版本:8.0.28
  • 安裝方式:二進位Generic
  • 軟體路徑:/app/database
  • 數據路徑:/data/3306
  • 日誌路徑:/binlog/3306

MySQL Community Server 社區版官網下載鏈接

MySQL :: Download MySQL Community Server (Archived Versions)

2. MySQL三種安裝方式

  • 源碼安裝:編譯安裝,可定製化高,安裝難度大時間長,不適合小白,不推薦
  • rpm包安裝:安裝簡單方便,但僅限rpm系列Linux系統,可定製化不高,生產不推薦
  • 二進位安裝:解壓即用,不限平臺,官方已編譯,可定製,推薦

3. 二進位版本安裝

3.1 二進位安裝包說明

Untitled

二進位版本會有三個安裝包下載

  • Compressed TAR Archive:主要安裝包,如果沒有特殊要求只下載這個包
  • Compressed TAR Archive, Test Suite:測試包,一般用不著
  • TAR:包含以上兩個包

3.2 MySQL二進位版本軟體目錄說明

解壓後目錄如下

drwxr-xr-x.  2 7161 31415   4096 Dec 18  2021 bin # mysql所有可執行程式命令,登陸、備份等等
drwxr-xr-x.  2 7161 31415     55 Dec 18  2021 docs # mysql文檔
drwxr-xr-x.  3 7161 31415   4096 Dec 18  2021 include # 依賴庫
drwxr-xr-x.  6 7161 31415    201 Dec 18  2021 lib # 函數庫
-rw-r--r--.  1 7161 31415 276595 Dec 18  2021 LICENSE
drwxr-xr-x.  4 7161 31415     30 Dec 18  2021 man # 幫助文件 
-rw-r--r--.  1 7161 31415    666 Dec 18  2021 README
drwxr-xr-x. 28 7161 31415   4096 Dec 18  2021 share
drwxr-xr-x.  2 7161 31415     77 Dec 18  2021 support-files # 腳本存放目錄

3.3 安裝前環境準備

3.3.1 檢查是否已安裝MySQL

# 查看rpm是否有安裝
rpm -qa | grep -i mysql  # -i 忽略大小寫
# 或者
yum list installed | grep mysql

# 查看mysql服務是否在運行
systemctl status mysqld.service

# 卸載mysql
yum remove mysql-xxx mysql-xxx mysql-xxx mysqk-xxxx

# 刪除mysql相關文件 慎用!!
find / -name mysql | xargs rm -rf 
mv /etc/my.cnd /etc/my.cnd_backup

在安裝之前最好檢查一下,如果有務必刪除乾凈,包括日誌文件和數據文件。

3.3.2 創建MySQL用戶和組

useradd -s /sbin/nologin mysql
id mysql

3.3.3 創建主要目錄

  • 軟體目錄:存放MySQL軟體
  • 數據目錄:存放MySQL數據,推薦使用埠號作為目錄名稱
  • 日誌目錄:存放binlog日誌,推薦使用埠號作為目錄名稱

註意:生產環境下軟體目錄、數據目錄、日誌目錄不要單獨存放在一個磁碟下!

mkdir -p /app/database  # 軟體目錄
mkdir -p /data/3306  # 數據目錄
mkdir -p /binlog/3306  # 日誌目錄

設置目錄許可權給mysql用戶

chown -R mysql:mysql /app /data /binlog

3.3.4 下載並解壓

註意:千萬不要下載到32位的包,一走眼就很容易搞混!一定是glibc2.12-x86_64

wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz
tar -xf mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz

3.4 安裝

3.4.1 設置環境變數

# 做軟連接,文件名太長不方便後續設置。不推薦修改文件名,修改了不能很快的知道mysql版本
ln -s mysql-8.0.28-linux-glibc2.12-x86_64/ mysql 

# 編輯當前用戶環境變數文件
vim ~/.bash_profile 
# 新增修改如下內容
MYSQL_HONE=/app/database/mysql
PATH=$PATH:$HOME/bin:$MYSQL_HONE/bin

export PATH
# 讓環境變數生效
source ~/.bash_profile

# 驗證
# mysql -V
mysql  Ver 8.0.28 for Linux on x86_64 (MySQL Community Server - GPL)

3.4.2 初始化系統表

系統表是mysql運行必備的表,不可缺失!本次初始化選擇手動設置密碼方式

mysqld --initialize-insecure --user=mysql --basedir=/app/database/mysql --datadir=/data/3306

# 參數說明
--initialize-insecure: reate the default database and exit. Create a super userwith empty password.
--initialize:Create the default database and exit. Create a super userwith a random expired password and store it into the log.
# 以上這兩參數任選其一,區分就是一個自動生成密碼,一個沒有密碼需要手動設置
--user=name: Run mysqld daemon as user.
--basedir=name: Path to installation directory. All paths are usuallyresolved relative to this
--datadir=name: Path to the database root directory

註意:初始化數據目錄一定是空目錄!否則初始化失敗

3.4.3 設置MySQL配置文件

配置文件路徑:/etc/my.cnf

以下配置文件僅供參考!根據實際機器配置來修改具體設置。

[mysqld]
user=mysql
basedir=/app/database/mysql
datadir=/data/3306
server_id=6
socket=/tmp/mysql.sock
bind-address = 0.0.0.0

# connect 
max_connections = 1000
max_connect_errors = 200

# charset
character_set_server = utf8mb4

# InnoDB Settings
innodb_buffer_pool_size = 2G
innodb_read_io_threads = 15
innodb_write_io_threads = 15
# innodb_flush_log_at_trx_commit = 0
innodb_buffer_pool_instances = 8
innodb_log_file_size = 1G
innodb_log_buffer_size = 64M
# innodb_flush_method = O_DIRECT
innodb_page_cleaners = 16

# session memory settings
read_buffer_size = 32M
read_rnd_buffer_size = 32M
sort_buffer_size = 64M
tmp_table_size = 64M
join_buffer_size = 128M
thread_cache_size = 64

# slow log
slow_query_log = 1
slow_query_log_file = slow.log
long_query_time = 10
min_examined_row_limit = 100
log-queries-not-using-indexes
log_throttle_queries_not_using_indexes = 10
log_timestamps = system

# log settings
log_error = error.log

# client settings
[mysql]
prompt = (\\u@\\h) [\\d]>\\_
socket=/tmp/mysql.sock
no-auto-rehash

3.4.3 準備MySQL啟動腳本

啟動腳本存放在support-files目錄下的mysql.server,將啟動腳本拷貝到/etc/init.d方便運行管理

CentOS7有兩種啟動方式,一個是init.d,一個是systemctl,這裡只用第一種,第二種方式具體參考百度或者官網。

cp mysql.server /etc/init.d/mysqld

3.4.5 啟動MySQL

如果沒有意外的話,可以啟動成功。有一種情況會啟動失敗,啟動腳本中設置的啟動路徑不在環境變數里,此時需要設置軟連接到腳本中對應的路徑。

/etc/init.d/mysqld start

3.4.6 驗證

# /etc/init.d/mysqld status
SUCCESS! MySQL running (11794)

# mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1397
Server version: 8.0.28 MySQL Community Server - GPL

Copyright (c) 2000, 2022, Oracle and/or its affiliates.

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.

(root@localhost) [(none)]>

3.5 安裝完成後的尾收工作

3.5.1 設置管理員密碼

mysqladmin -uroot password "WeiMin@123"

3.5.2 CentOS7設置開機自啟動

設置開機自啟動的方式有很多,這裡用最簡單的一種。

註意:

  • 開機自啟動的前提是啟動腳本必須存放在/etc/init.d目錄下!!
  • 生產環境最好重啟驗證!!
# 設置開機自啟動
chkconfig --add mysqld

# 查看mysqld是否在列表中
chkconfig --list
mysqld          0:off   1:off   2:on    3:on    4:on    5:on    6:off
netconsole      0:off   1:off   2:off   3:off   4:off   5:off   6:off
network         0:off   1:off   2:on    3:on    4:on    5:on    6:off

3.5.3 CentOS7關閉防火牆、關閉開機自啟動防火牆

iptables -F
systemctl disable firewalld.service

3.5.4 關閉selinux、修改selinux配置文件永久關閉

setenforce 0

# vim /etc/selinux/config
SELINUX=disabled

3.6 忘記root密碼處理辦法

  • —skip-grant-tables:跳過授權表,關閉用戶認證
  • —skip-networking:跳過遠程登錄,只能本地登陸
# 1. 關閉資料庫
/etc/init.d/mysqld stop

# 2. 啟動資料庫到維護模式,並放到後臺
mysqld_safe --skip-networking --skip-grant-tables &

# 3. 登陸mysql並修改密碼
flush privileges;
alter user root@'localhost' identified by 'Admin@123';

# 4. 關閉資料庫,啟動驗證
/etc/init.d/mysqld stop
mysql -uroot -pAdmin@123

3.7 啟動資料庫方式

啟動有兩種方式,不建議使用命令執行!!

  • 執行官方提供的啟動腳本
  • 設置systemctl腳本

本質上啟動腳本執行的是mysqld_safe --datadir=/data/3306 --pid-file=/data/3306/mysql.pid 這條命令,所以手動執行這條命令也可以啟動mysql

# ps -ef | grep mysqld
root       6067      1  0 03:18 pts/0    00:00:00 /bin/sh /app/database/mysql/bin/mysqld_safe --datadir=/data/3306 --pid-file=/data/3306/mysql.pid
mysql      6519   6067  1 03:18 pts/0    00:00:01 /app/database/mysql/bin/mysqld --basedir=/app/database/mysql --datadir=/data/3306 --plugin-dir=/app/database/mysql/lib/plugin --user=mysql --log-error=error.log --pid-file=/data/3306/mysql.pid --socket=/tmp/mysql.sock

Untitled

3.8 關閉資料庫方式

有三種方式正常關閉資料庫,不建議使用kill來強行關閉資料庫(被強姦的感覺)

  • 登陸數據,執行shutdown命令關閉
  • 啟動腳本關閉,/etc/init.d/mysqld stop
  • systemctl關閉,前提是設置了腳本,命令和就是服務的關閉命令,沒有特別的地方。

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

-Advertisement-
Play Games
更多相關文章
  • keytool 是 Java 自帶的一個安全相關的工具,用於管理密鑰和證書;本文主要介紹其基本使用;文中所使用到的軟體版本:Java 1.8.0_321。 1、簡介 keytool 命令是一個密鑰和證書管理的工具。它允許用戶使用數字簽名管理自己的公鑰/私鑰對和相關證書,用於自我身份驗證(向其他用戶和 ...
  • 1 簡介 如果要選擇GCP為雲平臺,則經常需要創建GCE(Google Compute Engine),有以下幾種方式: (1) 在瀏覽器創建 (2) 命令 gcloud (3) Terraform 在開始之前,可以查看:《初始化一個GCP項目並用gcloud訪問操作》。 2 GCP Console ...
  • 前言 眾所周知記憶體緩存(MemoryCache)數據是從記憶體中獲取,性能表現上是最優的,但是記憶體緩存有一個缺點就是不支持分散式,數據在各個部署節點上各存一份,每份緩存的過期時間不一致,會導致幻讀等各種問題,所以我們實現分散式緩存通常會用上Redis 但如果在高併發的情況下讀取Redis的緩存,會進行 ...
  • 前言 上一篇文章我們講了怎麼使用 NET.AutoApi 這個組件來動態生成webapi介面,讓我們不需要創建控制器去轉發業務層代碼。這篇文章主要是講解NET.AutoApi 底層是怎麼實現動態生成webapi介面 我們回顧下- NET.AutoApi 最終的效果 NET.AutoApi內部原理 其 ...
  • ● 什麼是廠商和軟體商: 廠商:一般是指Centos、紅帽、ubantu、suse等等,各linux發行版操作系統的發行廠家,廠家會維護系統的軟體,做相應的測試、補丁發佈、安全更新等 軟體商:一般指各軟體發行商,例如openssh、docker、nginx、tomcat等等,他們是將自己的軟體產品進 ...
  • Elasticsearch(簡稱:ES)功能強大,其背後有很多預設值,或者預設操作。這些操作優劣並存,優勢在於我們可以迅速上手使用 ES,劣勢在於,其實這些預設值的背後涉及到很多底層原理,怎麼做更合適,只有數據使用者知道。用 ES 的話來說,你比 ES 更懂你的數據,但一些配置信息、限制信息,還是需... ...
  • SummingMergeTree引擎繼承自MergeTree。區別在於,當合併SummingMergeTree表的數據片段時,ClickHouse會把所有具有相同主鍵的行合併為一行,該行包含了被合併的行中具有數值數據類型的列的彙總值。如果主鍵的組合方式使得單個鍵值對應於大量的行,則可以顯著的減少存儲 ...
  • 用正則表達式進行搜索 正則表達式介紹 正則表達式是用來匹配文本的特殊的串(字元集合)。 使用MySQL正則表達式 MySQL用WHERE子句對正則表達式提供了初步的支持,允許你指定正則表達式,過濾SELECT檢索出的數據。MySQL僅支持多數正則表達式實現的一個很小的子集。 基本字元匹配 SELEC ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...