偶尔需要搭建mysql环境,每次百度也够费劲的,而且还不一定会成功,所以急需一本自己的安装手册,在有需要的时候能随时翻阅,提高效率。
当前维护和支持的 MySQL 版本(如果想要下载的版本找不到,就使用下面不在维护的链接中)
不再维护和支持的旧版本的
当前我安装的是维护版本 8.0.40
shellwget https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.40-linux-glibc2.28-x86_64.tar.xz
下载完以后进行解压
shelltar -xf mysql-8.0.40-linux-glibc2.28-x86_64.tar.xz
将解压的文件夹重名为mysql且移动到对应安装目录下,默认是 /usr/local
shellmv mysql-8.0.40-linux-glibc2.28-x86_64 /opt/mysql
编辑配置文件 /etc/my.cnf
shellvim /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'
添加用户,分配权限
shellgroupadd mysql useradd -g mysql mysql chown -R mysql.mysql /opt/mysql chmod 777 /opt/mysql/data -R
初始化数据库
shellcd /opt/mysql bin/mysqld --user=mysql --basedir=/opt/mysql --datadir=/opt/mysql/data --initialize
编辑 mysql.server,找到以下属性,将其修改为对应mysql安装路径
shellbasedir=/opt/mysql datadir=/opt/mysql/data
将脚本添加为服务启动项,可通过 service mysql start/status/stop 启动服务
shellcd /opt/mysql cp ./support-files/mysql.server /etc/init.d/mysql chmod +x /etc/init.d/mysql chkconfig --add mysql
启动服务
shellservice mysql start
重置密码
shell# 设置软连接
ln -s /opt/mysql/bin/mysql /usr/bin
# 登录
mysql -uroot -p
设置密码
shellALTER 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;
查询授权
shelluse mysql; select host,user,plugin,authentication_string from user;
本文作者:柳始恭
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!