MySQL5.7--------基於CentOS6二進制包安裝

1. 背景mysql

   * MySQL是一個關係型數據庫管理系統,由瑞典MySQL AB 公司開發,目前屬於 Oracle 旗下產品。MySQL 是最流行的關係型數據庫管理系統之一,在 WEB 應用方面,MySQL是最好的 RDBMS (Relational Database Management System,關係數據庫管理系統) 應用軟件。linux

   * MySQL是一種關係數據庫管理系統,關係數據庫將數據保存在不一樣的表中,而不是將全部數據放在一個大倉庫內,這樣就增長了速度並提升了靈活性。web

   * MySQL所使用的 SQL 語言是用於訪問數據庫的最經常使用標準化語言。MySQL 軟件採用了雙受權政策,分爲社區版和商業版,因爲其體積小、速度快、整體擁有成本低,尤爲是開放源碼這一特色,通常中小型網站的開發都選擇 MySQL 做爲網站數據庫。sql


2. 選擇的理由數據庫

   * 支持多種平臺[AIX、FreeBSD、HP-UX、Linux、Mac OS、OpenBSD、Solaris、Windows......]ubuntu

   * 支持並提供多語言APIcentos

   * 開源,採用了 GPL協議,能夠修改源碼來開發本身的 MySQL 系統bash

   * 支持標準SQL語句tcp

   * 支持多種存儲引擎ide

   * 使用普遍 [ 全球top20網站除微軟的Live和Bing以外所有應用MySQL ]

wKioL1lOX5jQoVFpAAFaXeTnnpM723.jpg


3. MySQL安裝方式

   * 二制包安裝

   * 源碼編譯安裝

   * 平臺安裝包,如rpm包[centos,redhat]或deb[debian,ubuntu]包


4. 環境 [關閉selinux]

[root@MySQL ~]# cat /etc/redhat-release 
CentOS release 6.9 (Final)

[root@MySQL ~]# uname -r
2.6.32-642.3.1.el6.x86_64

[root@MySQL ~]# hostname
MySQL

[root@MySQL ~]# getenforce 
Disabled


5. 安裝 [ MySQL 5.7的安裝方式與MySQL 5.5/5.6不勁相同 ]

   * 下載 MySQL5.7 二進制包 [ 推薦從MySQL官方下載 ]

[root@MySQL ~]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz


   * 解壓 MySQL 5.7 二進制包

[root@MySQL ~]# tar zxvf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz


   * 移動 MySQL 5.7 二進制包

[root@MySQL ~]# mv mysql-5.7.18-linux-glibc2.5-x86_64 /usr/local/


   * 建立軟連接

[root@MySQL ~]# ln -s /usr/local/mysql-5.7.18-linux-glibc2.5-x86_64 /usr/local/mysql


   * 建立 mysql 用戶

[root@MySQL ~]# useradd -r -s /sbin/nologin mysql


   * 建立 MySQL 數據存放目錄

[root@MySQL ~]# mkdir -vp /data/mysql_data
mkdir: created directory `/data'
mkdir: created directory `/data/mysql_data'


   * 在 MySQL 二進制包目錄中建立 mysql-files 目錄 [MySQL 數據導入/導出數據專放目錄]

[root@MySQL ~]# mkdir -v /usr/local/mysql/mysql-files
mkdir: created directory `/usr/local/mysql/mysql-files'


   * 修改 MySQL 二進制包目錄的所屬用戶與所屬組

[root@MySQL ~]# chown root.mysql -R /usr/local/mysql-5.7.18-linux-glibc2.5-x86_64


   * 修改 MySQL 數據目錄與 數據導入/導出專放目錄的所屬用戶與所屬組

[root@MySQL ~]# chown mysql.mysql /usr/local/mysql/mysql-files /data/mysql_data


   * 重命名不使用系統自帶 MySQL 配置文件 /etc/my.cnf [ debian類系統在 /etc/mysql/my.cnf ]

[root@MySQL ~]# mv /etc/my.cnf{,.old}


   * 初始化 [ 初始化完成後會自帶隨機密碼在輸出日誌中 ]

     * 版本小於MySQL 5.7.6 [ < 5.7.6 ]

[root@MySQL ~]# /usr/local/mysql/bin/mysql_install_db \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/data/mysql_data

 

     * 版本大於或等於MySQL 5.7.6 [ >= 5.7.6 ]

     * 初始化 並指定基本目錄與數據存放目錄

[root@MySQL ~]# /usr/local/mysql/bin/mysqld --initialize \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/data/mysql_data 
2017-06-23T20:13:52.827475Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2017-06-23T20:13:57.684349Z 0 [Warning] InnoDB: New log files created, LSN=45790
2017-06-23T20:13:58.435803Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2017-06-23T20:13:58.525266Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 7d8f2b79-5850-11e7-9dab-000c29f0b169.
2017-06-23T20:13:58.538505Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
2017-06-23T20:13:58.543606Z 1 [Note] A temporary password is generated for root@localhost: Z91g%.6d&fay

     * 開啓 SSL 鏈接 

[root@MySQL ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql \
--user=mysql \
--basedir=/usr/local/mysql \

6. 建立啓動腳本

   * 複製啓動腳本到service 服務管理目錄下[ /etc/init.d ]

[root@MySQL ~]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld


   * 修改mysql啓動腳本 [ /et/init.d/mysqld ]

basedir=    ==> basedir=/usr/local/mysql
datadir=    ==> datadir=/data/mysql_data


   * 添加腳本執行權限

[root@MySQL ~]# chmod +x /etc/init.d/mysqld


   * 添加進service服務管理

[root@MySQL ~]# chkconfig --add mysqld


7. 服務啓動測試

   * 啓動 MySQL 服務

[root@MySQL ~]# /etc/init.d/mysqld start
Starting MySQL.Logging to '/data/mysql_data/MySQL.err'.
.. SUCCESS!


   * 查看服務是否啓動並監聽端口 [默認3306]

[root@MySQL ~]# netstat -lntp | grep 3306
tcp        0      0 :::3306             :::*                LISTEN      20896/mysqld


8. 服務啓動測試

   * 經過自帶mysql客戶端鏈接 [ 使用初始化時輸出的隨機密碼 ]

[root@MySQL ~]# /usr/local/mysql/bin/mysql -p'Z91g%.6d&fay'
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.18

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

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.

mysql>

   * 修改密碼

mysql> set password = '123456';
Query OK, 0 rows affected (0.00 sec)

   * 從新使用密碼鏈接

mysql> quit
Bye
[root@MySQL ~]# /usr/local/mysql/bin/mysql -p'123456'
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.18 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

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.

mysql>



9. 總結


以需求驅動技術,技術自己沒有優略之分,只有業務之分。

相關文章
相關標籤/搜索