MySQL 安装(二进制版)
小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《MySQL 安装(二进制版)》,以下内容将会涉及到MySQL,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
MySQL 的安装方式一般分为三种,二进制版本、编译版本、RPM 包。比较常见的是二进制版本安装,方便简单,相对于编译安装,如果不是追求极致性能,使用起来差别不大。本次教程以二进制版本为例,系统为 centos6.8,MySQL 版本为5.7.20。
下载安装包
先去官网下载二进制安装包,进入官网下载页面 mysql下载页面,点击下载 5.7.20 二进制 64 位版本

下载完成,把安装包移到目标 Linux 下
环境准备
1 安装依赖
yum install libaio numactl -y
2 创建用户以及用户组
groupadd mysql useradd -m -r -g mysql mysql
3 配置 ulimit
我们一般使用 mysql 用户启动数据库,如果不设置文件打开数和进程数,后期会有问题
打开
/etc/security/limits.conf文件,在文件末尾写上
mysql soft nproc 65536 mysql hard nproc 65536 mysql soft nofile 65536 mysql hard nofile 65536
打开
/etc/security/limits.d/90-nproc.conf把参数调整为
* soft nproc 65536 root soft nproc unlimited * soft nofile 65536 root soft nofile unlimited
4 在 hosts 文件加上本机解析
如果不设置 hosts 本机解析,偶然会出现一些诡异的问题,所以还是加上比较好
host_ip=$(ifconfig | grep inet | grep cast | awk '{print $2}' | awk -F: '{print $NF}' | head -1) echo "$host_ip `hostname`" >> /etc/hosts
5 开启时间同步
时间同步对于数据库来说非常重要,请保证所有数据库节点时间是一致的
yum install -y ntp service ntpd start
6 关闭 iptable
数据库一般不允许通外网,如果对防火墙不是很熟悉,可以关掉; 如果网络环境不够安全,可以开启
service iptables stop chkconfig iptables off
7 关闭 selinux
selinux 可能会造成无法写入数据,如果对它不熟悉,建议关掉
查看 selinux 状态
getenforce
临时关闭
setenforce 0
永久关闭
打开
/etc/sysconfig/selinux
SELINUX=enforcing 改为 SELINUX=disabled
安装
这次安装数据目录为
/data/mysql_db/,日志目录为
/data/mysql_log/,实例名为
mysql_test,启动用户为
mysql
1 解压文件
把二进制文件解压出来,放到
/user/local/目录下
tar -xvzf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz mv mysql-5.7.20-linux-glibc2.12-x86_64 /usr/local/mysql57
如果想要全局访问到 mysql 客户端,可以把
/usr/local/mysql57/bin加入系统路径,我这里采取直接创建软连接的方式
ln -s /usr/local/mysql57/bin/mysql /usr/bin/mysql ln -s /usr/local/mysql57/bin/mysqlbinlog /usr/bin/mysqlbinlog
2 创建数据和日志目录
mkdir -p /data/mysql_db/mysql_test mkdir -p /data/mysql_log/mysql_test
3 初始化目录
/usr/local/mysql57/bin/mysqld --initialize-insecure --basedir=/usr/local/mysql57 --datadir=/data/mysql_db/mysql_test --user=mysql /usr/local/mysql57/bin/mysql_ssl_rsa_setup --basedir=/usr/local/mysql57 --datadir=/data/mysql_db/mysql_test
正常输出
[root@mysql-test ~]# /usr/local/mysql57/bin/mysqld --initialize-insecure --basedir=/usr/local/mysql57 --datadir=/data/mysql_db/mysql_test --user=mysql 2018-06-03T05:19:31.469841Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2018-06-03T05:19:32.525091Z 0 [Warning] InnoDB: New log files created, LSN=45790 2018-06-03T05:19:32.751099Z 0 [Warning] InnoDB: Creating foreign key constraint system tables. 2018-06-03T05:19:32.861647Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: b2d883be-66ed-11e8-bd72-90b11c1a653a. 2018-06-03T05:19:32.877177Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened. 2018-06-03T05:19:32.877705Z 1 [Warning] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option. [root@mysql-test ~]# /usr/local/mysql57/bin/mysql_ssl_rsa_setup --basedir=/usr/local/mysql57 --datadir=/data/mysql_db/mysql_test Generating a 2048 bit RSA private key ............................................................................+++ ....+++ writing new private key to 'ca-key.pem' ----- Generating a 2048 bit RSA private key ......................................+++ ...........................+++ writing new private key to 'server-key.pem' ----- Generating a 2048 bit RSA private key ..............................................................................+++ ..................................................+++ writing new private key to 'client-key.pem' -----
4 生成配置文件
一台机器上有可能会存在多个 MySQL 实例,我们可以把 my.cnf 文件放到对应实例的数据目录下,由于 MySQL 会受到默认配置文件的影响,所以我们要把
/etc/my.cnf移走, 然后创建新的
my.cnf文件
rm -f /etc/my.cnf vim /data/mysql_db/mysql_test/my.cnf
本次安装参考配置,具体参数结合服务器情况调整
# my.cnf [client] port = 3306 default-character-set =utf8 socket = /data/mysql_db/mysql_test/mysql.sock [mysqld] datadir = /data/mysql_db/mysql_test basedir = /usr/local/mysql57 tmpdir = /tmp socket = /data/mysql_db/mysql_test/mysql.sock pid-file = /data/mysql_db/mysql_test/mysql.pid skip-external-locking = 1 skip-name-resolve = 1 port = 3306 server_id = 1 default-storage-engine = InnoDB character-set-server = utf8 default_password_lifetime=0 #### log #### binlog_cache_size = 16M log_bin = /data/mysql_log/mysql_test/mysql-bin log_bin_index = /data/mysql_log/mysql_test/mysql-bin.index binlog_format = row expire_logs_days = 15 relay_log_recovery=ON relay_log=/data/mysql_log/mysql_test/mysql-relay-bin relay_log_index=/data/mysql_log/mysql_test/mysql-relay-bin.index log_error = /data/mysql_log/mysql_test/mysql-error.log log_queries_not_using_indexes = /data/mysql_log/mysql_test/nouseindex.log slow_query_log = 1 long_query_time = 1 slow_query_log_file = /data/mysql_log/mysql_test/mysql-slow.log #### innodb #### innodb_buffer_pool_size = 4G innodb_buffer_pool_instances = 8 innodb_log_group_home_dir = /data/mysql_log/mysql_test/ innodb_undo_directory = /data/mysql_log/mysql_test/ innodb_undo_logs = 128 innodb_flush_neighbors = 1 innodb_log_file_size = 1G innodb_file_per_table = on bulk_insert_buffer_size = 64M myisam_sort_buffer_size = 64M myisam_max_sort_file_size = 1G myisam_repair_threads = 1 log_timestamps=system [mysqldump] quick max_allowed_packet = 64M [myisamchk] key_buffer_size = 32M sort_buffer_size = 32M read_buffer = 16M write_buffer = 16M
5 生成启动文件
cp /usr/local/mysql57/support-files/mysql.server /etc/init.d/mysqld-test vim /etc/init.d/mysqld-test
把
basedir= datadir= lock_file_path="$lockdir/mysql" $bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null &
改为, 手动指定配置文件和数据目录
basedir=/usr/local/mysql57 datadir=/data/mysql_db/mysql_test default_file=/data/mysql_db/mysql_test/my.cnf lock_file_path="$lockdir/mysql-test" $bindir/mysqld_safe --defaults-file="$default_file" --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null 2>&1 &
把数据目录的所有者改为 mysql
chown mysql.mysql /etc/init.d/mysqld-test chown mysql.mysql -R /data/mysql*
启动实例
们以 mysql 用户来启动
su - mysql [mysql@chengqm ~]$ /etc/init.d/mysqld-test start Starting MySQL.. SUCCESS!
进入 mysql 客户端
mysql -S /data/mysql_db/mysql_test/mysql.sock
到此,MySQL 已经成功安装并启动, 后续可以修改密码. 如果有报错,查看错误日志,根据具体报错信息进行修改。如果报错日志里面什么也没有,可能是配置文件有问题,或者读到了默认配置。
好了,本文到此结束,带大家了解了《MySQL 安装(二进制版)》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

- 上一篇
- 【压力测试】使用mysqlslap进行mysql基准测试

- 下一篇
- 记一次 Hibernate 数据表创建失败
-
- 斯文的帆布鞋
- 太细致了,已加入收藏夹了,感谢博主的这篇博文,我会继续支持!
- 2023-04-05 04:18:54
-
- 清秀的信封
- 这篇技术贴太及时了,太详细了,很好,码住,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-03-31 07:05:00
-
- 高兴的黄蜂
- 这篇文章内容真是及时雨啊,作者大大加油!
- 2023-03-23 16:57:35
-
- 甜美的小甜瓜
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢楼主分享文章!
- 2023-03-06 21:46:16
-
- 数据库 · MySQL | 2小时前 | mysql 字符集 中文乱码 utf8mb4 utf8mb4_unicode_ci
- MySQL中文乱码解决方案与字符集修改命令大全
- 339浏览 收藏
-
- 数据库 · MySQL | 1天前 | 索引 数据类型 字符集 存储引擎 CREATETABLE
- MySQL新建表操作指南与建表技巧
- 462浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 条件判断
- CASEWHEN条件判断的嵌套使用详解与实战场景分析
- 469浏览 收藏
-
- 数据库 · MySQL | 1个月前 | java php
- CSV文件批量导入MySQL的性能优化秘籍大揭秘
- 289浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- GaleraCluster多主集群配置与冲突解决攻略
- 239浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 窗口函数实战
- MySQL窗口函数实战案例深度剖析
- 315浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 20次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 29次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 35次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 43次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 36次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览