Ubuntu 安裝mysql & 自定義數據存儲目錄


一、安裝

apt-get install mysql-server

執行過程如下:

root@duke:~#  apt-get install mysql-server
正在讀取軟件包列表... 完成
正在分析軟件包的依賴關系樹       
正在讀取狀態信息... 完成       
將會同時安裝下列軟件:
  libaio1 libevent-core-2.0-5 libhtml-template-perl mysql-client-5.7 mysql-client-core-5.7 mysql-common mysql-server-5.7 mysql-server-core-5.7
建議安裝:
  libipc-sharedcache-perl mailx tinyca
下列【新】軟件包將被安裝:
  libaio1 libevent-core-2.0-5 libhtml-template-perl mysql-client-5.7 mysql-client-core-5.7 mysql-common mysql-server mysql-server-5.7 mysql-server-core-5.7
升級了 0 個軟件包,新安裝了 9 個軟件包,要卸載 0 個軟件包,有 360 個軟件包未被升級。
需要下載 18.4 MB 的歸檔。
解壓縮后會消耗 161 MB 的額外空間。
您希望繼續執行嗎? [Y/n]  y
獲取:1 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-common all 5.7.24-0ubuntu0.16.04.1 [15.3 kB]
獲取:2 http://cn.archive.ubuntu.com/ubuntu xenial/main amd64 libaio1 amd64 0.3.110-2 [6,356 B]
獲取:3 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-client-core-5.7 amd64 5.7.24-0ubuntu0.16.04.1 [6,030 kB]
獲取:4 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-client-5.7 amd64 5.7.24-0ubuntu0.16.04.1 [1,720 kB]
獲取:5 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-server-core-5.7 amd64 5.7.24-0ubuntu0.16.04.1 [7,757 kB]
獲取:6 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 libevent-core-2.0-5 amd64 2.0.21-stable-2ubuntu0.16.04.1 [70.6 kB]
獲取:7 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-server-5.7 amd64 5.7.24-0ubuntu0.16.04.1 [2,726 kB]
獲取:8 http://cn.archive.ubuntu.com/ubuntu xenial/main amd64 libhtml-template-perl all 2.95-2 [60.4 kB]
獲取:9 http://cn.archive.ubuntu.com/ubuntu xenial-updates/main amd64 mysql-server all 5.7.24-0ubuntu0.16.04.1 [10.8 kB]
已下載 18.4 MB,耗時 3秒 (4,812 kB/s)   
正在預設定軟件包 ...
設置mysql數據庫root用戶密碼: root
確認mysql數據庫root用戶密碼: root
正在選中未選擇的軟件包 mysql-common。
(正在讀取數據庫 ... 系統當前共安裝有 220375 個文件和目錄。)
正准備解包 .../mysql-common_5.7.24-0ubuntu0.16.04.1_all.deb  ...
正在解包 mysql-common (5.7.24-0ubuntu0.16.04.1) ...
正在選中未選擇的軟件包 libaio1:amd64。
正准備解包 .../libaio1_0.3.110-2_amd64.deb  ...
正在解包 libaio1:amd64 (0.3.110-2) ...
正在選中未選擇的軟件包 mysql-client-core-5.7。
正准備解包 .../mysql-client-core-5.7_5.7.24-0ubuntu0.16.04.1_amd64.deb  ...
正在解包 mysql-client-core-5.7 (5.7.24-0ubuntu0.16.04.1) ...
正在選中未選擇的軟件包 mysql-client-5.7。
正准備解包 .../mysql-client-5.7_5.7.24-0ubuntu0.16.04.1_amd64.deb  ...
正在解包 mysql-client-5.7 (5.7.24-0ubuntu0.16.04.1) ...
正在選中未選擇的軟件包 mysql-server-core-5.7。
正准備解包 .../mysql-server-core-5.7_5.7.24-0ubuntu0.16.04.1_amd64.deb  ...
正在解包 mysql-server-core-5.7 (5.7.24-0ubuntu0.16.04.1) ...
正在選中未選擇的軟件包 libevent-core-2.0-5:amd64。
正准備解包 .../libevent-core-2.0-5_2.0.21-stable-2ubuntu0.16.04.1_amd64.deb  ...
正在解包 libevent-core-2.0-5:amd64 (2.0.21-stable-2ubuntu0.16.04.1) ...
正在處理用於 libc-bin (2.23-0ubuntu10) 的觸發器 ...
正在處理用於 man-db (2.7.5-1) 的觸發器 ...
正在設置 mysql-common (5.7.24-0ubuntu0.16.04.1) ...
update-alternatives: 使用 /etc/mysql/my.cnf.fallback 來在自動模式中提供 /etc/mysql/my.cnf (my.cnf)
正在選中未選擇的軟件包 mysql-server-5.7。
(正在讀取數據庫 ... 系統當前共安裝有 220543 個文件和目錄。) 正准備解包 .../mysql-server-5.7_5.7.24-0ubuntu0.16.04.1_amd64.deb ... 正在解包 mysql-server-5.7 (5.7.24-0ubuntu0.16.04.1) ... 正在選中未選擇的軟件包 libhtml-template-perl。 正准備解包 .../libhtml-template-perl_2.95-2_all.deb ... 正在解包 libhtml-template-perl (2.95-2) ... 正在選中未選擇的軟件包 mysql-server。 正准備解包 .../mysql-server_5.7.24-0ubuntu0.16.04.1_all.deb ... 正在解包 mysql-server (5.7.24-0ubuntu0.16.04.1) ... 正在處理用於 ureadahead (0.100.0-19) 的觸發器 ... ureadahead will be reprofiled on next reboot 正在處理用於 systemd (229-4ubuntu21.1) 的觸發器 ... 正在處理用於 man-db (2.7.5-1) 的觸發器 ... 正在設置 libaio1:amd64 (0.3.110-2) ... 正在設置 mysql-client-core-5.7 (5.7.24-0ubuntu0.16.04.1) ... 正在設置 mysql-client-5.7 (5.7.24-0ubuntu0.16.04.1) ... 正在設置 mysql-server-core-5.7 (5.7.24-0ubuntu0.16.04.1) ... 正在設置 libevent-core-2.0-5:amd64 (2.0.21-stable-2ubuntu0.16.04.1) ... 正在設置 mysql-server-5.7 (5.7.24-0ubuntu0.16.04.1) ... update-alternatives: 使用 /etc/mysql/mysql.cnf 來在自動模式中提供 /etc/mysql/my.cnf (my.cnf) Renaming removed key_buffer and myisam-recover options (if present) 正在設置 libhtml-template-perl (2.95-2) ... 正在設置 mysql-server (5.7.24-0ubuntu0.16.04.1) ... 正在處理用於 libc-bin (2.23-0ubuntu10) 的觸發器 ... 正在處理用於 systemd (229-4ubuntu21.1) 的觸發器 ... 正在處理用於 ureadahead (0.100.0-19) 的觸發器 ...

二、配置自定義數據存儲目錄

2.1、關閉數據庫

mysqladmin -u root -p shutdown
service mysql stop

2.2、遷移默認數據

默認數據是在安裝mysql時就部署完成的,必須遷移
1、創建新數據存儲目錄

mkdir -p /data/

2、遷移數據存儲目錄

mv /var/lib/mysql /data

3、設置權限

chown -R /data/mysql

2.3、修改配置

2.3.1、修改mysql配置

mysql5.7版本默認配置文件是 /etc/mysql/mysql.conf.d/mysqld.cnf

vi /etc/mysql/mysql.conf.d/mysqld.cnf

1、修改datadir配置項
將默認數據存儲目錄

datadir = /var/lib/mysql

修改為自定義數據存儲目錄

#datadir = /var/lib/mysql
datadir = /data/mysql

2、修改bind-address配置項
將本地mysql訪問

bind-address = 127.0.0.1

修改為遠端mysql訪問,地址為本機ip地址

#bind-address = 127.0.0.1
bind-address = 192.168.0.2

2.3.1、修改apparmor配置

AppArmor 是內核的一個安全增強模塊,對程序存取資源進行限制,如果不修改,啟動mysql,在journalctl -xe中會報以下錯誤

kernel: audit: type=1400 audit(1542353824.294:278): apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/19325/status" pid=19325 comm="mysqld" requested_mask="r" den

配置方法如下:

vi /etc/apparmor.d/usr.sbin.mysqld

# Allow data dir access
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,

修改為

# Allow data dir access
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,
/data2/mysql/ r,
/data2/mysql/** rwk,

2.4、啟動mysql

必須執行下面3個步驟,否則修改不會生效,單獨啟動mysql依舊會報錯。

service apparmor reload
service apparmor restart
service mysql restart


免責聲明!

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



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