2025-05-31
工具运维
0

目录

下载
安装

偶尔需要搭建mysql环境,每次百度也够费劲的,而且还不一定会成功,所以急需一本自己的安装手册,在有需要的时候能随时翻阅,提高效率。

下载

当前维护和支持的 MySQL 版本(如果想要下载的版本找不到,就使用下面不在维护的链接中)

https://dev.mysql.com/downloads/mysql/

不再维护和支持的旧版本的

https://downloads.mysql.com/archives/community/

当前我安装的是维护版本 8.0.40

shell
wget https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.40-linux-glibc2.28-x86_64.tar.xz

安装

下载完以后进行解压

shell
tar -xf mysql-8.0.40-linux-glibc2.28-x86_64.tar.xz

将解压的文件夹重名为mysql且移动到对应安装目录下,默认是 /usr/local

shell
mv mysql-8.0.40-linux-glibc2.28-x86_64 /opt/mysql

编辑配置文件 /etc/my.cnf

shell
vim /etc/my.cnf

my.cnf 填充内容 以下内容中,需要将socket、basedir、datadir地址修改为当前安装的mysql路径

shell
###### [client]配置模块 ###### [client] default-character-set=utf8mb4 socket=/opt/mysql/mysql.sock ###### [mysql]配置模块 ###### [mysql] # 设置MySQL客户端默认字符集 default-character-set=utf8mb4 socket=/opt/mysql/mysql.sock ###### [mysqld]配置模块 ###### [mysqld] port=3306 user=mysql # 设置sql模式 sql_mode模式引起的分组查询出现*this is incompatible with sql_mode=only_full_group_by,这里最好剔除ONLY_FULL_GROUP_BY sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION basedir=/opt/mysql datadir=/opt/mysql/data socket=/opt/mysql/mysql.sock server-id = 1 # MySQL8 的密码认证插件 如果不设置低版本navicat无法连接 default_authentication_plugin=mysql_native_password # 禁用符号链接以防止各种安全风险 symbolic-links=0 # 允许最大连接数 max_connections=1000 # 服务端使用的字符集默认为8比特编码的latin1字符集 character-set-server=utf8mb4 # 创建新表时将使用的默认存储引擎 default-storage-engine=INNODB # 0: 表名将按指定方式存储,并且比较区分大小写; # 1: 表名以小写形式存储在磁盘上,比较不区分大小写; lower_case_table_names=0 max_allowed_packet=16M # 设置时区 default-time_zone='+8:00'

添加用户,分配权限

shell
groupadd mysql useradd -g mysql mysql chown -R mysql.mysql /opt/mysql chmod 777 /opt/mysql/data -R

初始化数据库

shell
cd /opt/mysql bin/mysqld --user=mysql --basedir=/opt/mysql --datadir=/opt/mysql/data --initialize

编辑 mysql.server,找到以下属性,将其修改为对应mysql安装路径

shell
basedir=/opt/mysql datadir=/opt/mysql/data

将脚本添加为服务启动项,可通过 service mysql start/status/stop 启动服务

shell
cd /opt/mysql cp ./support-files/mysql.server /etc/init.d/mysql chmod +x /etc/init.d/mysql chkconfig --add mysql

启动服务

shell
service mysql start

重置密码

shell
# 设置软连接 ln -s /opt/mysql/bin/mysql /usr/bin # 登录 mysql -uroot -p

设置密码

shell
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

设置远程访问

shell
# 被连接的数据库的用户名、其中“%”表示允许所有机器能访问root用户 create user root@'%' identified by '新密码'; grant all privileges on *.* to root@'%' with grant option;

查询授权

shell
use mysql; select host,user,plugin,authentication_string from user;

本文作者:柳始恭

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!