centos7安装mysql5.7gz_CentOS7安装MySQL5.7数据库以及配置

一、MySQL5.7主要特性:

原生架构支持centos7的Systemd

(1.)更好的性能:对于多核的CPU、固态硬盘、锁有着更好的优化、更好的innoDB存储引擎。

(2.)更为健壮的复制功能:复制带来了数据完全不丢失的方案,传统金融客户也

可以选择使用MySQL数据库。

(3.)新增sys库:以后这会是DBA访问最频繁的库

(4.)更好的优化器:优化器的代码重构的意义将在5.7版本及以后的版本中带来巨大的改进

oracle官方正在解决MySQL之前最大的难题,原生JSON类型的支持

注意:JSON(JavaScript object Notation)是一种轻量级的数据交换格式。

JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯

(包括C、C++、C#、Java、JavaScript、Perl、Python等)。

这些特性使JSON成为理想的数据交换语言。易于阅读和编写,同时易于机器解析

和生成(一般用于提升网络传输速率)。

JSON语法是JavaScript对象表示语法的子集数据在键值对中

数据由逗号分隔

花括号保存对象

方括号保存数组

用JSON编写的文件,可以代替.yaml格式的文件。(dockerkubernetes中的用的到,创建RC)。

注:mysql-5.6.3 已经支持了多线程的主从复制

二、源码编译安装MySQL5.7

1.系统环境:centos7.2x64位

51458b5f183739f1859bb15ecde110c8.png

因为centos7.2默认安装了mariadb-libs,所以先要卸载掉。

ddf61f89fc509afe4b9aab23ee7d6b66.png

2.安装相关依赖包

cmake:由于从MySQL5.5版本开始弃用了常规的configure编译方法,所以需要CMAKE编译器,用

于设置mysql的编译参数。如:安装目录、数据存放目录、字符编码、排序规则等。

Boot: 从Mysql5.7.5开始Boost库是必需的,MySQL源码中用到了C++的Boost库,要求必须安

装boost1.59.0或以上版本。

GCC是Linux下的C语言编译工具,MySQL源码编译完全由C和C++编写,要求必须安装GCC

bison:Linux下C/C++语法分析器

ncurses:字符终端处理库

下载所需软件:

下载mysql-5.7.13.tar.gz

下载Boost_1_59_0.tar.gz

3.安装cmake及相关下载好的软件

1.安装cmake:

a4864ab65bea0ed25da73f9c2072132f.png

34f93e4583ab0c3ac22811ea95c82b56.png

cmake -version  查看版本:

4e3a22b4570e4a0cccbaa340806b9ca3.png

2.安装ncurses:

055c9552df30e40fd4e8fce2a8b29bb8.png

3.安装bison:

9abfcd4ee261318189e816cfb6cf8997.png

4.安装boost:

因为boost是一个提前编译好的软件所以这里无需在进行配置和编译,所以直接移动到指定的目录即可直接使用。

e13a04cc23c3fcbfaf6b899726b28bf7.png

4.创建MySQL用户和用户组及目录

新建MySQL组合MySQL用户,禁止登录shell ,-r选项:代表系统用户

b574796efb80997c678fe64aaa9084f5.png

5.编译安装MySQL5.7.18

(1.)解压mysql源码包:

04849d7f0e1941a4e745a7e38cb87b37.png

(2.)执行cmake命令前进行编译配置:

491a13ebae743b0b50464aef90e95d58.png

注意:在mysql5.5-5.6版本中是不需要加上-DWITH_SYSTEMD=1参数,否则会报错!!!

(3.)开始编译安装:

e1c3a63e465f861cbdde9cf21d5f2d8f.png

配置解释:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql  :mysql安装的根目录

-DMYSQL_DATADIR=/usr/local/mysql/data     :mysql数据库文件存放目录

-DSYSCONFDIR=/etc  :mysql配置文件所在目录

-DWITH_MYISAM_STORAGE_ENGINE=1 :添加MYISAM引擎支持

-DWITH_INNOBASE_STORAGE_ENGINE=1 :添加InnoDB引擎支持

-DWITH_ARCHIVE_STORAGE_ENGINE=1   :添加ARCHIVE引擎支持

-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock :指定mysql.sock位置

-DWITH_PARTITION_STORAGE_ENGINE=1 :安装支持数据库分区

-DEXTRA_CHARSETS=all   :使mysql支持所有的扩展字符

-DDEFAULT_CHARSET=utf8 :设置mysql的默认字符集为utf-8

-DDEFAULT_COLLATION=utf8_general_ci  :设置默认字符集校对规则

-DWITH_SYSTEMD=1 :可以使用systemd控制mysql服务

-DWITH_BOOST=/usr/local/boost :指向boost库所在目录

注意:更多参数执行: #cmake . -LH

为了加快编译速度可以按照下面的方式去编译安装:

make  -j   $(grep  processor  /proc/cpuinfo  |  wc   -l )

-j  参数表示根据CPU核数指定编译时的线程数,可以加快编译速度。默认为1个线程编译。

注意:若要重新运行cmake配置,需要删除CMakeCache.txt文件

#make  clean

#rm  -f   CMakeCache.txt

6.优化MySQL的执行路径

88297405cebd1142c065ee46c22abeab.png

182634a3a60a76ef6741420cd1991ded.png

7.设置权限并初始化MySQL系统授权表

46b78c46929c520212ab6435d5127c8b.png

e131e5512aaecc3658f8172496c0b861.png

注意: 以上root初始化操作时要加--initialize参数,生成一个随机密码(注意保存密码登录时使用)

MySQL5.7.6之前的版本执行这个脚本进行初始化系统数据库:

/usr/local/mysql/bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql

--datadir=/usr/local/mysql/data

有密码的初始化:

#bin/mysqld --initialize   --user=mysql  --basedir=/usr/local/mysql  --datadir=/usr/local/mysql/data

无密码的初始化:

#/usr/local/mysql/bin/mysqld --initialize-insecure  --user=mysql --basedir=/usr/local/mysql  --datadir=/usr/local/mysql/data

8.创建配置文件

vim  /etc/my.cnf

41a2b4962a7db208545fca823d6a879f.png

以上服务器启动失败,查看错误日志文件

4485598e288c40d18f801bb70c4a6a52.png

在mysqld.service,把默认的pid文件指定到了/var/run/mysqld目录,而并没有事先建立该目录,因此要手动建立该目录并把权限赋给MySQL用户。(这种方法是临时的,因为/var/run/下的目录关机就没有了)。

e7c28bea775df156af2800959a63b090.png或者修改/usr/lib/system/system/mysqld.service:

0eb68dcfe08b6f595be852e016ba76f7.png

#systemctl   daemon-reload

29ac0e2121af72a5e130f1aa4e14301e.png

5b4cf15d4d80802f70738c0410923fd6.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值