百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MySQL 8.0 部署文档

nanshan 2025-01-01 21:57 26 浏览 0 评论


一、文档介绍

此文档旨在规范服务器上 MySQL 8.0 部署步骤,标准化操作步骤,为后续标准运维提供支撑。

二、部署环境

  • 操作系统:Linux(CentOS 7.6)
  • MySQL版本:8.0.40

注意:

(1)由于官方不再推出针对 CentOS 非 RPM 包,所以本文档中使用的是官方根据 glibc 版本编译的安装包。

(2)本文档中 CentOS 7.6 glibc 版本默认为 2.7,如果是国产操作系统,或者有重新适配过 glibc 的操作系统,需根据 glibc 版本选择对应的安装包。

三、下载

官网下载地址:https://dev.mysql.com/downloads/mysql/

cd /usr/local/src
wget https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.40-linux-glibc2.17-x86_64.tar.xz

四、创建用户

cat /etc/passwd | grep mysql
[ $? -ne 0 ] && useradd -s /sbin/nologin -M mysql

五、安装

cd /usr/local/src
tar xf mysql-8.0.40-linux-glibc2.17-x86_64.tar.xz
mv mysql-8.0.40-linux-glibc2.17-x86_64 /usr/local/mysql-8.0.40
cd /usr/local/
ln -s mysql-8.0.40 mysql80
chown -R mysql.mysql mysql-8.0.40

六、配置环境变量

cat <<"EOF" | tee -a /etc/profile
# MySQL
export MYSQL_HOME=/usr/local/mysql80
export PATH=$MYSQL_HOME/bin:$PATH
EOF

source /etc/profile

七、创建目录

默认端口为 3306,请根据实际情况进行替换。

mkdir -p /data/mysql_data/3306/{conf,data,tmp}
mkdir -p /data/logs/mysql/3306

八、配置my.cnf

cd /data/mysql_data/3306/conf
cat <<EOF | tee my.cnf
[client]
socket = /data/logs/mysql/3306/mysql.sock
port = 3306

[mysqld]
user = mysql
port = 3306
server-id = 1

pid-file = /data/logs/mysql/3306/mysql.pid
socket = /data/logs/mysql/3306/mysql.sock
datadir = /data/mysql_data/3306/data
tmpdir = /data/mysql_data/3306/tmp
log-error = /data/logs/mysql/3306/error.log
secure-file-priv = /data/mysql_data/3306/tmp
general_log_file = /data/logs/mysql/3306/general.log

skip-mysqlx = 1
character-set-server = utf8mb4
collation_server = utf8mb4_general_ci
character-set-client-handshake = FALSE
default-time_zone = '+8:00'
sql_mode = ''
lower_case_table_names = 1
skip_name_resolve = 1
# authentication_policy = mysql_native_password
default-storage-engine = INNODB
explicit_defaults_for_timestamp = 1

# read_only = 1
# skip_slave_start = 1
innodb_redo_log_capacity=1073741824
innodb_log_buffer_size = 32M
innodb_max_dirty_pages_pct = 50
innodb_online_alter_log_max_size = 1G
innodb_open_files = 65535
innodb_print_all_deadlocks = 1
innodb_read_io_threads = 48
innodb_spin_wait_delay = 30
innodb_sync_spin_loops = 100
innodb_thread_concurrency = 120
innodb_thread_sleep_delay = 0
innodb_write_io_threads = 48
innodb_autoinc_lock_mode = 2
innodb_flush_method = O_DIRECT
innodb_flush_sync = 0
innodb_io_capacity = 10000
innodb_io_capacity_max = 20000
innodb_buffer_pool_size = 4G

connect_timeout = 10
wait_timeout = 3600
interactive_timeout = 600
lock_wait_timeout = 86400
innodb_lock_wait_timeout = 30
net_read_timeout = 60
net_write_timeout = 60
replica_net_timeout = 60

back_log = 1024
open_files_limit = 65535
max_allowed_packet = 1G
replica_max_allowed_packet = 1G
replica_pending_jobs_size_max = 256M
max_prepared_stmt_count = 1048576
min_examined_row_limit = 100

join_buffer_size = 2M
key_buffer_size = 16M
read_buffer_size = 256K
read_rnd_buffer_size = 2M
sort_buffer_size = 4M
thread_cache_size = 800
max_connections = 3000
max_connect_errors = 99999999
max_heap_table_size = 32M
tmp_table_size = 32M

slow_query_log = 1
long_query_time = 1
slow_query_log_file = /data/logs/mysql/3306/slow.log

log-bin = /data/logs/mysql/3306/mysql-bin
max_binlog_size = 256M
binlog_cache_size = 4M
binlog_rows_query_log_events = 1
binlog_expire_logs_seconds = 259200
log_replica_updates = 1
log_bin_trust_function_creators = 1
log_statements_unsafe_for_binlog = 0
log_throttle_queries_not_using_indexes = 60
max_binlog_cache_size = 2G

innodb_flush_log_at_trx_commit = 1
sync_binlog = 1

relay_log = /data/logs/mysql/3306/mysql-relay
max_relay_log_size = 256M
relay_log_purge = 1
relay_log_recovery = 1

binlog-ignore-db = information_schema
binlog-ignore-db = performance_schema

replicate-ignore-db = information_schema
replicate-wild-ignore-table = information_schema.%
replicate-ignore-db = performance_schema
replicate-wild-ignore-table = performance_schema.%

gtid_mode = ON
enforce_gtid_consistency = 1
binlog_gtid_simple_recovery = 1

transaction_isolation = READ-COMMITTED

# expire_logs_days = 7

[mysql]
socket = /data/logs/mysql/3306/mysql.sock
default-character-set = utf8mb4

EOF

如果实际环境中使用的是不是3306端口,请执行以下命令进行替换:

sed -i 's/3306/实际端口/g' my.cnf

九、修改目录权限

chown -R mysql.mysql /data/mysql_data
chown -R mysql.mysql /data/logs/mysql

十、初始化数据库

/usr/local/mysql80/bin/mysqld --defaults-file=/data/mysql_data/3306/conf/my.cnf  --initialize-insecure  --user=mysql

十一、创建服务

cat <<EOF | tee /usr/lib/systemd/system/mysqld.service
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network-online.target
Wants=network-online.target
After=syslog.target

[Install]
WantedBy=multi-user.target

[Service]
User=mysql
Group=mysql
Type=simple
TimeoutSec=0
PermissionsStartOnly=true
ExecStart=/usr/local/mysql80/bin/mysqld_safe --defaults-file=/data/mysql_data/3306/conf/my.cnf
EnvironmentFile=-/etc/sysconfig/mysql
LimitNOFILE = 65535
Restart=on-failure
RestartPreventExitStatus=1
Environment=MYSQLD_PARENT_PID=1
PrivateTmp=false
EOF

十二、启动服务

systemctl daemon-reload
systemctl start mysqld
systemctl status mysqld
# 开机启动
systemctl enable mysqld

十三、修改 mysql 命令

由于本文档使用非默认 mysql socket(/tmp/mysql.sock),每次执行 mysql 命令时都需要带上 -S 或 --socket 参数。为简化命令操作,需要配置别名。

echo '
alias mysql="/usr/local/mysql80/bin/mysql -S /data/logs/mysql/3306/mysql.sock"
' >> /etc/bashrc

source /etc/bashrc

十四、修改密码

mysql -uroot

第一次登录不需要密码,登录成功后请修改 root 密码。

MySQL 8.0 的密码插件有变化:

  • 默认的是caching_sha2_password
alter user root@'localhost' identified by '新密码';
flush privileges;
  • 支持旧版本的 mysql_native_password
alter user root@'localhost' identified with mysql_native_password by '新密码';
flush privileges;

密码修改完成后退出重新登录,需要使用新密码登录

mysql -uroot -p

注意:不建议在 -p 参数后直接填写密码,会被历史记录保存,存在安全隐患。

相关推荐

雷军1994年写的老代码曝光,被称像诗一样优雅

大数据文摘授权转载自程序员的那些事雷军的代码像诗一样优雅↓↓↓有些网友在评论中质疑,说雷军代码不会是“屎”一样优雅吧。说这话的网友,也许是开玩笑的,也许是真没看过雷军写过的代码。在2011年的时候,我...

原创经验分享:低级bug耗费12小时Fix

调试某程序非常简单的程序,简单到认为不可能存在缺陷,但该BUG处理时间超过12小时:程序属于后台进程,监控系统每隔15秒检查外设IO状态,IO异常后发出报警或复位外设,外设都在linux下有/sys/...

SpringBoot实现的简单停车位管理系统附带导入和演示教程视频

这一次为大家带来的是简单的停车位管理系统,基于SpringBoot+Thymeleaf+Mybatis框架,这个系统相对来说比较简单,很容易学习并快速上手,因为逻辑很清晰,没有太复杂的代码逻辑,所以学...

一个开箱即用的代码生成器(代码自动生成工具开源)

今天给大家推荐一个好用的代码生成器,名为renren-generator,该项目附带前端页面,可以很方便的选择我们所需要生成代码的表。首先我们通过git工具克隆下来代码(地址见文末),导入idea。...

【免费开源】JeecgBoot单点登录源码全部开源了

JeecgBoot单点登录源码全部开源了,有需要的朋友可以来薅羊毛了。一、JeecgBoot介绍JeecgBoot是一款企业级的低代码平台!前后端分离架构SpringBoot2.x,SpringCl...

SpringBoot+JWT+Shiro+Mybatis实现Restful快速开发后端脚手架

作者:lywJee来源:cnblogs.com/lywJ/p/11252064.html一、背景前后端分离已经成为互联网项目开发标准,它会为以后的大型分布式架构打下基础。SpringBoot使编码配置...

为什么越来越多的人选择使用idea软件

IDEA软件是什么?IDEA软件是干什么的?为什么越来越多的人选择使用IDEA软件?IDEA软件,全称IntelliJIDEA,它是由JetBrains公司开发开发的一款功能强大的集成开发环境(ID...

开题报告大学生互助系统(附源码)java毕设

本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容选题背景随着互联网技术的飞速发展,大学生群体对信息共享与互助的需求日益增长。关于大...

SpringBoot项目快速开发框架JeecgBoot——项目简介及系统架构!

项目简介及系统架构JeecgBoot是一款基于SpringBoot的开发平台,它采用前后端分离架构,集成的框架有SpringBoot2.x、SpringCloud、AntDesignof...

新手配电脑13代CPU怎么选择(新手配电脑13代cpu怎么选择好)

Intel第13代酷睿i3、i5、i7、i9系列处理器的核心参数、性能差异及适用群体的详细说明(以桌面端为例):一、13代酷睿全系参数对比(桌面端主流型号)参数i3-13100i5-13600Ki7-...

加速 SpringBoot 应用开发,官方热部署神器真带劲

平时使用SpringBoot开发应用时,修改代码后需要重新启动才能生效。如果你的应用足够大的话,启动可能需要好几分钟。有没有什么办法可以加速启动过程,让我们开发应用代码更高效呢?今天给大家推荐一款Sp...

基于微信小程序的移动端物流系统-计算机毕业设计源码+LW文档

摘要随着Internet的发展,人们的日常生活已经离不开网络。未来人们的生活与工作将变得越来越数字化,网络化和电子化。网上管理,它将是直接管理移动端物流系统app的最新形式。本论文是以构建移动端物流系...

springboot教务管理系统+微信小程序云开发附带源码

今天给大家分享的程序是基于springboot的管理,前端是小程序,系统非常的nice,不管是学习还是毕设都非常的靠谱。本系统主要分为pc端后台管理和微信小程序端,pc端有三个角色:管理员、学生、教师...

SpringBoot全家桶:23篇博客加23个可运行项目让你对它了如指掌

SpringBoot现在已经成为Java开发领域的一颗璀璨明珠,它本身是包容万象的,可以跟各种技术集成。本项目对目前Web开发中常用的各个技术,通过和SpringBoot的集成,并且对各种技术通...

Maven+JSP+Servlet+C3P0+Mysql实现的音乐库管理系统

本系统基于Maven+JSP+Servlet+C3P0+Mysql实现的音乐库管理系统。简单实现了充值、购买歌曲、poi数据导入导出、歌曲上传下载、歌曲播放、用户注册登录注销等功能。难度等级:简单技术...

取消回复欢迎 发表评论: