本文主要介绍MySQL二进制软件包的安装/启动/关闭过程。

也许有人要问为什么要选择二进制的安装方式呢?

其实答案很简单,官方版本中已经把所有功能都配置好了,我们可以很方便地拿来使用。

官方MySQL有四个版本:GA版本、DMR版本、RC版本和Beta版本。一般情况下,生产环境或者测试环境都

选择GA版本(常规可用的版本,经过bug修复测试过)。

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

下载完成以后可以检验一下MD5,我这边之前下载的版本,这边就演示这个命令的使用(md5sum 文件名)

[root@tse2 downloads]# md5sum mysql-5.7.-linux-glibc2.-x86_64.tar.gz
d903d3dbf235b74059a4b3e216c71161 mysql-5.7.-linux-glibc2.-x86_64.tar.gz

1、安装前系统环境检测

不管是MySQL哪个版本的安装,为了可以很顺利地把MySQL数据库安装好,做好后期数据库的优化工作,在前期进行Linux的系统检测是十分有必要的。

1.1、selinux和iptables需要关闭,把SELINUX=disabled,改完重启服务器生效。

我这里没有iptables用的是firewall所以不用关闭iptables

1.2、I/O调度系统默认是cfq模式,这里强烈建议使用deadline模式

查看I/O调度文件:

[root@tse2 downloads]# cat /sys/block/sda/queue/scheduler
noop [deadline] cfq

1.3、swap分区的设置

swpapiness值的大小对如何使用swap分区有着很大的影响。

它有0和100两个极限值,0代表最大限度地使用物理内存,然后才使用swap分区,这种行为很有可能导致系统内存溢出,出现OOM的错误,从而导致MySQL被意外kill掉,所以需要谨慎设置。

100则是积极地使用swap分区,并且把内存上面的数据及时搬到swap分区里(不建议)。这里建议大家不分配swap,或者分配4GB的空间就足够了。

如何查看swappiness文件呢?

[root@tse2 grub2]# cat /proc/sys/vm/swappiness

[root@tse2 grub2]# sysctl -a|grep swap
sysctl: reading key "net.ipv6.conf.all.stable_secret"
sysctl: reading key "net.ipv6.conf.default.stable_secret"
sysctl: reading key "net.ipv6.conf.ens192.stable_secret"
sysctl: reading key "net.ipv6.conf.lo.stable_secret"
vm.swappiness =

想要修改swappiness的值,编辑/etc/sysctl.conf,加入vm.swappiness的值即可。

1.4、文件系统的选择

这里建议使用xfs文件系统,相比ext4,它更方便管理,支持动态扩容,删除文件也很方便。

1.5、操作系统的限制

先来查看一些当前操作系统的限制情况,使用ulimit -a查看:

这里标记了两个最为重要的参数,一个叫open files,另一个叫max user processes。

open files如果设置不合理,而当前服务器的连接过多或者表过多时,就有可能会出现打不开表或者访问不了表的现象。

默认情况下,Linux最大句柄数为1024个,表示单个进程最多可以访问1024个文件句柄。如要超过默认值,就会出现文件句柄超限的错误”too many open files“。

max user processes参数的用途:有时候我们可能会跑很多实例,但是发现创建不了新的连接,报出“resource temporarily unavailable”的错误,表示没有足够的资源。

为了防止以上两种报错情况,我们可以修改系统的软硬限制。编辑/etc/security/limits.conf,加入限制的相关内容。记得更改完内容之后,需要重启操作系统才能生效。

[root@tse2 grub2]# vim /etc/security/limits.conf
* soft nproc
* hard nproc
* soft nofile
* hard nofile

1.6、numa需要关闭

简单来讲关闭numa功能,可以更好地分配内存,不需要采用swap的方式来获取内存。

因为有经验的系统管理员和DBA都知道使用swap导致的数据库性能下降有多么的恶心。

关闭方式也分在BIOS、操作系统中关闭,或者是在数据库启动过程中关闭。

[root@tse2 bin]# numa --interleave=all /mysql/app/bin/mysqld_safe -defaults-file=/etc/my.conf &

2、MySQL5.7版本安装过程

检查完操作系统环境后,进入MySQL安装阶段,总结为“三部曲+一步走”的方式。

2.1、第一部曲

创建MySQL用户,指定MySQL所在的用户组,命令如下:

[root@tse2 /]# groupadd mysql
[root@tse2 /]# useradd -g mysql mysql -s /sbin/nologin

软件包的家目录(basedir)我这边是习惯统一放在/data/downloads下面:

[root@tse2 downloads]# pwd
/data/downloads

创建下列目录:

安装目录:/mysql/app

配置目录:/mysql/config

数据目录:/mysql/data

日志目录:/mysql/logs

备份目录:/mysql/backup

临时目录:/mysql/tmp

#tmp目录主要放sock和pid文件

[root@tse2 downloads]# mkdir -p /mysql/{app,config,data,logs,backup,tmp}

也要对MySQL目录授权:

[root@tse2 downloads]# chown -R mysql:mysql /mysql/

需要解压MySQL软件包,命令如下:

[root@tse2 downloads]# tar -zxvf mysql-5.7.-linux-glibc2.-x86_64.tar.gz -C /mysql/app/

移动包文件到/mysql/app/目录

[root@tse2 app]# mv /mysql/app/mysql-5.7.-linux-glibc2.-x86_64/* ./

删除mysql-5.7.23-linux-glibc2.12-x86_64目录

[root@tse2 app]# rm -rf /mysql/app/mysql-5.7.-linux-glibc2.-x86_64

2.3、第二部曲

由于是二进制的安装方式,这里的数据库配置文件需要自己配置好,到此完成最后一部曲

my.cnf配置文件下载地址:https://files.cnblogs.com/files/Sungeek/my.7z

密码:tse

2.4、最后一步

mysqld命令初始化数据库:

[root@tse2 mysql]# /mysql/app/bin/mysqld --defaults-file=/etc/my.cnf --basedir=/mysql/app --datadir=/mysql/data/ --user=mysql --initialize

注:如果在初始化过程中加上--initialize参数,表示会生成一个临时的数据库初始化密码,

记录在log-error(错误日志)里面,如果加上--initialize-insecure参数,代表无密码进入。建议使用生成初始化密码的方式!

启动数据库后台运行:

[root@tse2 mysql]# /mysql/app/bin/mysqld_safe --defaults-file=/etc/my.cnf & #后台运行

数据库启动成功之后,进入数据库的初始化密码会在/mysql/logs/error.log下面:

[root@tse2 logs]# cat /mysql/logs/error.log |grep password

使用初始化密码进入数据库之后,需要修改数据库root密码,设置为永不过期:

/mysql/app/bin/mysql -uroot -p
mysql>SET PASSWORD = '';
mysql>ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
mysql>flush privileges;

或者下面命令:

/mysql/app/bin/mysql -uroot -p
mysql>alter user root@localhost identified by '';
mysql>flush privileges;

以上就是MySQL5.7版本的安装启动方式和系统优化的部分优化说明。

Linux下通过二进制方式安装mysql5.7版本和系统优化的更多相关文章

  1. Linux下通用二进制方式安装MySQL

    1.下载glibc版本的MySQL: https://downloads.mysql.com/archives/community/ 2.查看mysql用户和mysql组是否存在(用户和组的信息存在/ ...

  2. 关于centos7中使用rpm方式安装mysql5.7版本后无法使用root登录的问题

    最近在centos7中通过rpm方式安装了最新版本的mysql-server 5.7 (mysql57-community-release-el7-7.noarch.rpm) ,发现安装成功后无法使用 ...

  3. Linux下基于源代码方式安装MySQL 5.6

    MySQL为开源数据库,因此能够基于源代码实现安装.基于源代码安装有很多其它的灵活性. 也就是说我们能够针对自己的硬件平台选用合适的编译器来优化编译后的二进制代码.依据不同的软件平台环境调整相关的编译 ...

  4. 离线环境下使用二进制方式安装配置Kubernetes集群

    本文环境 Redhat Linux 7.3,操作系统采用的最小安装方式. Kubernetes的版本为 V1.10. Docker版本为18.03.1-ce. etcd 版本为 V3.3.8. 1. ...

  5. [转]在ubuntu linux下以编译方式安装LAMP(apache mysql php)环境

    FROM : http://www.cnblogs.com/eleganthqy/archive/2010/02/28/1675217.html 最近转向到了使用ubuntu做桌面,安装好系统以来一直 ...

  6. CentOS6.5和RedHat6.5下以rpm方式安装mysql-5.6.20

    转帖;http://blog.csdn.net/mw08091020/article/details/39234207 a.检查下linux是不是已经安装了mysql rpm -qa | grep - ...

  7. 二进制方式安装mysql5.7.24

    1.实验环境 [root@test-mysql ~]# cat /etc/redhat-release CentOS Linux release 7.3.1611 (Core) 2.浏览器下载mysq ...

  8. 基于通用二进制方式安装MySQL-5.7.24(比源码安装MySQL快许多)及破密码

    确保系统中有依赖的libaio软件 yum -y install libaio 使用wget命令下载mysql-5.7.24软件包 wget http://mirrors.sohu.com/mysql ...

  9. Linux下用rpm方式安装MySQL

    1.MySQL下载地址. www.mysql.com/downloads/mysql-4.0.html 下载MySQL 5.1版本的2个包(根据你的实际需求下载所需要的包): MySQL-server ...

随机推荐

  1. ORM跨表查询总结

    一.基于对象的查询-->子查询 1.一对多 正向查询:基于 字段 反向查询:基于 表名__set.all() 注意:表名全部小写 2.多对多 正向查询:基于 字段.all() 反向查询:基于 表 ...

  2. RocketMQ 实战之快速入门

    原文地址:https://www.jianshu.com/p/824066d70da8 最近 RocketMQ 刚刚上生产环境,闲暇之时在这里做一些分享,主要目的是让初学者能快速上手RocketMQ. ...

  3. linux 为动态分配的Virtualbox虚拟硬盘扩容

    如何为动态分配的Virtualbox虚拟硬盘扩容 查看虚拟硬盘是否是动态分配大小 打开虚拟机的设置界面,在左侧栏点击存储.在存储树下面选择你的虚拟硬盘.在右边可以看见虚拟硬盘的信息.在下面可以看见,我 ...

  4. git使用中遇到的问题

    1.拉取时报错:Permission denied (publickey) 先检查一下你的乌龟设置是否用的不是乌龟自己的SSH 2.TortoiseGit报错: Couldn’t load this ...

  5. openpyxl库实现对excel文档进行编辑(追加写入)

    首先,这个库只支持xlsx格式的excel文件 预期,对”excel_test.xlsx“的A1单元格写入”hello word“ 1.安装”openpyxl“库,pip install openpy ...

  6. 深入Node.js的进程与子进程:从文档到实践

    欢迎关注Github仓库,这是一个自2018年起持续更新的前端&算法开源博客.目前已有node学习.js面试笔记.css3动画设计.webpack4系列教程.设计模式.剑指offer·js版等 ...

  7. H5新增特性

    1.pattern:写正则,但是需要和form表单连着用 2.WebSocket "网络套接字", 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议.在 W ...

  8. 压力测试---Jemeter的使用

    一.线程组配置 线程组相当于有多个用户,同时去执行相同的一批次任务.每个线程之间都是隔离的,互不影响的.一个线程的执行过程中,操作的变量,不会影响其他线程的变量值. Delay Thread crea ...

  9. jdk8 ConcurrentHashMap分析

    ConcurrentHashMap分析 tryPresize() transfer() putVal() addCount() sumCount() class ConcurrentHashMap { ...

  10. JQuery--50个必备的实用jQuery代码段.

    原文出处:http://my.oschina.net/chengjiansunboy/blog/55496?p=2#comments 1. 如何修改jQuery默认编码(例如默认UTF-8改成改GB2 ...