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基准测试
- 上一篇
- 【压力测试】使用mysqlslap进行mysql基准测试
- 下一篇
- 记一次 Hibernate 数据表创建失败
-
- 数据库 · MySQL | 2天前 |
- MySQL数值函数大全及使用技巧
- 117浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- 三种登录MySQL方法详解
- 411浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL数据备份方法与工具推荐
- 420浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL数据备份方法与工具推荐
- 264浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL索引的作用是什么?
- 266浏览 收藏
-
- 数据库 · MySQL | 6天前 |
- MySQL排序原理与实战应用
- 392浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQLwhere条件查询技巧
- 333浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用数据类型有哪些?怎么选更合适?
- 234浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用命令大全管理员必学30条
- 448浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL高效批量插入数据方法大全
- 416浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL性能优化技巧大全
- 225浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL数据备份4种方法保障安全
- 145浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3182次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3393次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3424次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4528次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3802次使用
-
- 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浏览

