1. 程式人生 > >CentOS 7 安裝 MySQL 5.7.23

CentOS 7 安裝 MySQL 5.7.23

gre cmd 環境變量 under emp -i 阿裏 not -a

阿裏雲服務器 CentOS 7 安裝 MySQL 5.7.23 。

一、準備工作

1、MySQL 官網下載 MySQL 5.7.23 :mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz

2、檢查是否已經安裝過 MySQL :
    $> rpm -qa | grep mysql
    如果已經安裝過其他版本的 MySQL,使用以下命令卸載:$> rpm -e 已經存在的MySQL全名

3、添加用戶組,用專門管理mysql,提高安全 (非必須,可以跳過 ) 
    $> groupadd mysql
    $> useradd -r -g mysql -s /bin/false mysql
4、安裝libaio1 :
    libaio1 是  MySQL 的安裝依賴  必須先安裝(前提條件)
    $> yum install  libaio-devel.x86_64

二、安裝

1、解壓 mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz 並移到 /usr/local/mysql 文件夾下:
    $> tar -xvf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz -C /usr/local
    $> mv mysql-5.7.23-linux-glibc2.12-x86_64 /usr/local/mysql
    $> chown -R mysql:mysql mysql
2、配置 MySQL 的服務,將 support-files 下的 mysql.server 復制到 /etc/init.d/ 下並取名mysql :
    $> cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
3、修改/etc/init.d/mysql的參數:
    $> vi /etc/init.d/mysql
        #修改如下內容
        basedir=/usr/local/mysql
        datadir=/usr/local/mysql/data
4、配置 MySQL 的配置文件,
    其他版本mysql的support-files目錄下有默認的配置文件,
    5.7.23 這個版本沒有,需要自己準備,下面提供一份簡單基本配置,
    在/etc/ 下新建my.cnf ,有些可能會提示已經存在,因為默認裝的數據庫配置文件也在,直接覆蓋就行:

註意:在 my.cnf 文件所在目錄,看是否有一個叫 my.cnf.d 的文件夾,
    如果沒有需要新建一個,不然後面安裝的時候會報錯。
    $> touch /etc/my.cnf
    $> vi /etc/my.cnf
        #my.cnf內容如下
        # *** DO NOT EDIT THIS FILE. It‘s a template which will be copied to the
        # *** default location during install, and will be replaced if you
        # *** upgrade to a newer version of MySQL.
        [client]
        port = 3306
        default-character-set=utf8
        [mysqld]
        # 一般配置選項
        basedir = /usr/local/mysql
        datadir = /usr/local/mysql/data
        port = 3306
        character-set-server=utf8
        default_storage_engine = InnoDB
        sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
        socket=/var/lib/mysql/mysql.sock

        # 下面一行是忽略大小寫的配置,不想忽略的話可以刪除,或者把值改成 0;
        lower_case_table_names=1

        # Disabling symbolic-links is recommended to prevent assorted security risks
        symbolic-links=0
        # Settings user and group are ignored when systemd is used.
        # If you need to run mysqld under a different user or group,
        # customize your systemd unit file for mariadb according to the

        [mysqld_safe]
        log-error=/var/log/mysql/mariadb/mariadb.log
        pid-file=/var/run/mysql/mariadb/mariadb.pid
        # include all files from the config directory
        !includedir /etc/my.cnf.d
5、創建相關目錄文件:
    $> mkdir -p /var/log/mysql/mariadb
    $> touch /var/log/mysql/mariadb/mariadb.log
    $> chown -R mysql:mysql /var/log/mysql
    $> mkdir /var/run/mysql
    $> chown -R mysql:mysql /var/run/mysql
    $> mkdir /var/lib/mysql
    $> chown -R mysql:mysql /var/lib/mysql
    $> ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
6、切換到mysql的bin目錄執行下面命令初始化數據庫:
    $> rm -rf /usr/local/mysql/data/* (沒有/usr/local/mysql/data目錄可以不執行)
    $> ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
7、執行完畢後會自動生成默認的初始密碼在執行記錄中,註意復制出來!

8、啟動mysql 服務,下方會提示啟動成功字樣
    $> service mysql start
        啟動成功會顯示:Starting MySQL  [ OK ! ] 

9、配置一下mysql的環境變量
    $> cd /etc/profile.d
    $> touch mysql.sh
    $> vi mysql.sh
        #mysql.sh添加如下內容
        MYSQL_HOME=/usr/local/mysql
        PATH=$PATH:$MYSQL_HOME/bin
        export MYSQL_HOME PATH
    $> source /etc/profile

三、登錄

1、登錄
    $> mysql -uroot -p
        # 輸入默認的初始密碼
2、修改密碼
    mysql> set password=password(‘新密碼‘);
3、開啟遠程登錄 
    3.1、設置mysql的遠程登錄:
    # grant all privileges on 庫.表 to 用戶@‘%‘ identified by ‘用戶密碼‘;
    mysql> grant all privileges on *.* to root@‘%‘ identified by ‘root密碼‘;
    mysql> flush privileges;
    3.2、設置防火墻:
    # 設置防火墻:
    $> firewall-cmd --zone=public --add-port=3306/tcp --permanent
    # 重新載入:
    $> firewall-cmd --reload
    # 查看:
    $> firewall-cmd --zone= public --query-port=3306/tcp 或 firewall-cmd --zone=public --list-ports
4、設置開機自啟(非必須,不影響使用):
    $> chkconfig --list
    $> chkconfig --add mysql
    $> chkconfig mysql on
    # 然後使用chkconfig --list命令再次查看自啟服務列表,
    # 會看到mysql的2-5都顯示開(有些顯示的是 on);
    # 說明mysql服務會隨機器啟動而自動啟動
然後就可以導入 SQL 文件建表跑服務了。

CentOS 7 安裝 MySQL 5.7.23