日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql在linux下的安装(5.7版本以后)

發布時間:2023/12/13 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql在linux下的安装(5.7版本以后) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.添加mysql組和mysql用戶,用于設置mysql安裝目錄文件所有者和所屬組。

?①groupadd mysql

?②useradd -r -g mysql mysql

?2.將二進制文件解壓到指定的安裝目錄,通用的/usr/local

①解壓二進制文件,?tar -zxvf??/usr/local/mysql-5.7.13-linux-glibc2.5-i686.tar.gz?

?②mv?mysql-5.7.13-linux-glibc2.5-i686 mysql ? 更改mysql目錄名稱

?③cd mysql 進入mysql文件夾,也就是mysql所在的目錄,

?④更改mysql目錄所屬的組和用戶。更改權限

? ? chown -R mysql .

? ? chgrp -R mysql .

3.初始化 MySQL 配置表?

?執行mysql_install_db腳本,對mysql中的data目錄進行初始化并創建一些系統表格。

?bin/mysql_install_db --user=mysql

?報錯:

?2016-07-15 14:50:14 [WARNING] mysql_install_db is deprecated. Please consider switching to mysqld --initialize
?2016-07-15 14:50:14 [ERROR] ? The data directory needs to be specified.

?需要指定data目錄,注意mysql服務進程mysqld運行時會訪問data目錄,所以必須由啟動mysqld進程的用戶(就是我們之前設置的mysql用戶)執行這個腳本, ?或者用root ?執行,但是加上參數--user=mysql。

?上文還有警告信息,說mysql_install_db 命令已經是棄用的,建議切換到mysqld --initialize命令

?注:

?mysql5.7和之前版本不同,很多資料上都是這個命令:../scripts/mysql_install_db --user=mysql,而mysql5.7的mysql_install_db命令是在bin目錄下 ?的并且建議 ?用?mysqld --initialize命令

?mysql5.7之前版本初始化配置表命令:

?script/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/

?--user ?啟動mysql的用戶

?--basedir ?mysql安裝目錄

?--datadir ?mysql數據倉庫目錄

?①初始化表配置正確執行步驟:

  • [root@rhel5-32?mysql]#?mkdir?data??
  • [root@rhel5-32?mysql]#?bin/mysqld?--initialize?--user=mysql?--basedir=/usr/local/mysql?--datadir=/usr/local/mysql/data??
  •   注意最后一行,這也是和之有版本不同的地方,它給了root一個初始密碼,后面要登錄的時候要用到這個密碼。

    ?

      mysql初始化工作依賴libaio包,如果沒有安裝就會出現這個錯誤 “bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory”。   檢查是否已安裝:
      yum search libaio 或 apt-cache search libaio
      如果沒有,則安裝:
      yum install libaio 或 apt-get install libaio1
      yum適用于centos/readhat等系統,apt-get適用于ubuntu、debian系統,請按自己需要選擇。

      error while loading shared libraries: libnuma.so.1: cannot open shared object file: No such file or directory
      yum 安裝的libnuma.so.1,但安裝時默認安裝的是32的,但db2需要的是64位的
      1.如果已經安裝了libnuma.so.1,先yum remove libnuma.so.1
      2.yum -y install numactl.x86_64

    ?

    ②將mysql/目錄下除了data/目錄的所有文件,改回root用戶所有,mysql用戶只需作為mysql/data/目錄下所有文件的所有者。

  • [root@rhel5-32?mysql]#?chown?-R?root?.??
  • [root@rhel5-32?mysql]#?chown?-R?mysql?data?
  • mysql5.7以后配置文件需要刪除my.cnf關鍵配置,?mysql5.7之前默認配置文件中是有配置項的,不用手動修改

      rm -rf /etc/my.cf

    4. 將mysqld服務加入開機自啟動項。

    ?將{mysql}/ support-files/mysql.server 拷貝為/etc/init.d/mysql并設置運行權限,這樣就可以使用service mysql命令啟動/停止服務,

    ?否則就只能使用{mysql}/bin/mysqld_safe &命令來啟動服務

    ?還需要把mysql.server中basedir的相關路徑,改為自定義的路徑,默認路徑是/usr/local/mysql

  • #cp?mysql.server?/etc/init.d/mysql??
  • #chmod?+x?/etc/init.d/mysql??
  • ?把mysql注冊為開機啟動的服務

       1.chkconfig?--add?mysql?

    查看是否添加成功

  • [root@rhel5-32?mysql]#?chkconfig?--list?mysql??
  • mysqld??????????0:關閉??1:關閉??2:啟用??3:啟用??4:啟用??5:啟用??6:關閉??
  • 5.mysql服務的開啟和關閉

  • #/etc/init.d/mysql?start???或者???serivce?mysql?start??或者??bin/mysqld_safe&??
  • #/etc/init.d/mysql?stop????或者???service?mysql?stop???或者??bin/mysqladmin?-uroot?-p??
  • ?注:在bin/mysqld_safe&這個啟動腳本里已默認設置--user=mysql;在腳本末尾加&表示設置此進程為后臺進程,區別就是在控制臺輸入bg,即可將當前進 ?程轉入后臺, ?當前shell ?可進行其他操作。

    ?bin/mysqladmin -uroot -p??(注意此時的root是指mysql的root用戶)

    6.加入環境變量建立軟鏈接:運行mysql命令會出現 ? -bash: mysql:command not found ln -s /Ultrapower/test/mysql/bin/mysql ?/usr/local/bin ln -s /Ultrapower/test/mysql/bin/mysqladmin ?/usr/local/bin ln -s /Ultrapower/test/mysql/bin/mysqld_safe ?/usr/local/bin 修改/etc/profile文件使其永久性生效,并對所有系統用戶生效,在文件末尾加上如下兩行代碼
    ?PATH=$PATH:/Ultrapower/test/mysql:/Ultrapower/test/mysql/bin
    ?export PATH
    ?最后:執行 命令source /etc/profile或 執行點命令 ./profile使其修改生效,執行完可通過echo $PATH命令查看是否添加成功。 7.修改密碼:   vim /ust/local/mysql/data下的某個文件

    mysql 8.0 默認使用 caching_sha2_password 身份驗證機制 —— 從原來的 mysql_native_password 更改為 caching_sha2_password。?
    從 5.7 升級 8.0 版本的不會改變現有用戶的身份驗證方法,但新用戶會默認使用新的 caching_sha2_password 。

    客戶端不支持新的加密方式。

    方法之一,修改用戶的密碼和加密方式

    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';

    mysql8.*的新特性 caching_sha2_password 密碼加密方式

    以前版本的mysql密碼加密使用的是 mysql_native_password
    新添加的用戶密碼默認使用的 caching_sha2_password
    如果在以前mysql基礎上升級的 就得用戶使用的密碼加密使用的是 mysql_native_password
    如果使用以前的密碼加密方式,就修改文件 /etc/my.cnf [mysqld]

    default_authentication_plugin=mysql_native_password

    一. 創建用戶

    命令:

    CREATE USER 'username'@'host' IDENTIFIED BY 'password';

    說明:

    • username:你將創建的用戶名
    • host:指定該用戶在哪個主機上可以登陸,如果是本地用戶可用localhost,如果想讓該用戶可以從任意遠程主機登陸,可以使用通配符%
    • password:該用戶的登陸密碼,密碼可以為空,如果為空則該用戶可以不需要密碼登陸服務器

    例子:

    CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456'; CREATE USER 'pig'@'192.168.1.101_' IDENDIFIED BY '123456'; CREATE USER 'pig'@'%' IDENTIFIED BY '123456'; CREATE USER 'pig'@'%' IDENTIFIED BY ''; CREATE USER 'pig'@'%';

    二. 授權:

    命令:

    GRANT privileges ON databasename.tablename TO 'username'@'host'

    說明:

    • privileges:用戶的操作權限,如SELECT,INSERT,UPDATE等,如果要授予所的權限則使用ALL
    • databasename:數據庫名
    • tablename:表名,如果要授予該用戶對所有數據庫和表的相應操作權限則可用*表示,如*.*

    例子:

    GRANT SELECT, INSERT ON test.user TO 'pig'@'%'; GRANT ALL ON *.* TO 'pig'@'%'; GRANT ALL ON maindataplus.* TO 'pig'@'%';

    注意:

    用以上命令授權的用戶不能給其它用戶授權,如果想讓該用戶可以授權,用以下命令:

    GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;

    三.設置與更改用戶密碼

    命令:

    SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');

    如果是當前登陸用戶用:

    SET PASSWORD = PASSWORD("newpassword");

    例子:

    SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");

    四. 撤銷用戶權限

    命令:

    REVOKE privilege ON databasename.tablename FROM 'username'@'host';

    說明:

    privilege, databasename, tablename:同授權部分

    例子:

    REVOKE SELECT ON *.* FROM 'pig'@'%';

    注意:

    假如你在給用戶'pig'@'%'授權的時候是這樣的(或類似的):GRANT SELECT ON test.user TO 'pig'@'%',則在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤銷該用戶對test數據庫中user表的SELECT?操作。相反,如果授權使用的是GRANT SELECT ON *.* TO 'pig'@'%';則REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤銷該用戶對test數據庫中user表的Select權限。

    具體信息可以用命令SHOW GRANTS FOR 'pig'@'%';?查看。

    五.刪除用戶

    命令:

    DROP USER 'username'@'host';    

    五.查詢用戶權限

    命令:

    select host,user from mysql.user    

    轉載于:https://www.cnblogs.com/liushuchen/p/8320079.html

    總結

    以上是生活随笔為你收集整理的mysql在linux下的安装(5.7版本以后)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。