阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Centos7.2 Systemd 方式编译 Mysql5.7.11

282次阅读
没有评论

共计 5396 个字符,预计需要花费 14 分钟才能阅读完成。

导读 MySQL 5.7 版本的发布,也就是说从现在开始 5.7 已经可以在生产环境中使用,有任何问题官方都将立刻修复。

Centos7.2 Systemd 方式编译 Mysql5.7.11

MySQL 5.7 主要特性:

原生支持 Systemd
更好的性能:对于多核 CPU、固态硬盘、锁有着更好的优化
更好的 InnoDB 存储引擎
更为健壮的复制功能:复制带来了数据完全不丢失的方案,传统金融客户也可以选择使用 MySQL 数据库。此外,GTID 在线平滑升级也变得可能
更好的优化器:优化器代码重构的意义将在这个版本及以后的版本中带来巨大的改进,Oracle 官方正在解决 MySQL 之前最大的难题
原生 JSON 类型的支持
更好的地理信息服务支持:InnoDB 原生支持地理位置类型,支持 GeoJSON,GeoHash 特性
新增 sys 库:以后这会是 DBA 访问最频繁的库
MySQL 5.7 已经作为数据库可选项添加到 OneinStack — lnmp 安装工具中

安装依赖包


yum -y install make gcc-c++ cmake bison-devel ncurses-devel

下载 mysql 源码包

源码包有两种版本:
mysql-5.7.11.tar.gz 不带 boost 库,需要自行下载。

mysql-boost-5.7.11.tar.gz 自带 boost 库,在解压后的根目录,推荐下载。

wget http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-boost-5.7.11.tar.gz

curl -O http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-boost-5.7.11.tar.gz

tar -zxf mysql-boost-5.7.11.tar.gz

cd mysql-5.7.11

编译

生成 makefile

cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DSYSCONFDIR=/etc \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \ [字符集]
-DDEFAULT_COLLATION=utf8_general_ci \ [排序规则 必须有,不然初始化数据库困难]
-DDOWNLOAD_BOOST=1 \ [从 MySQL 5.7.5 开始 Boost 库是必需的]
-DWITH_BOOST=/root/mysql-5.7.11/boost \
-DWITH_SYSTEMD=1 [支持 Systemd]
加上 -DWITH_SYSTEMD= 1 可以使用 systemd 控制 mysql 服务,默认是不开启 systemd 的。

然后

make -j 2 && make install

mysql 将会安装到 /usr/local/mysql 路径
慢慢等……

配置 MySQL
添加 mysql 用户和组


groupadd mysql

useradd -g mysql -s /sbin/nologin mysql

修改 /usr/local/mysql 权限


chown -R mysql:mysql /usr/local/mysql

创建 mysql PID 默认目录

在 mysqld.service,把默认的 pid 文件指定到了 /var/run/mysqld/ 目录,而并没有事先建立该目录,因此要手动建立该目录并把权限赋给 mysql 用户。

mkdir -p /var/run/mysqld
chown mysql:mysql /var/run/mysqld

mysql 三个运行文件默认位置


log : /var/log/mysqld.log
pid : /var/run/mysqld/mysqld.pid
sock : /tmp/mysql.sock

拷贝 my.cnf 和 mysqld.service


cp support-files/my-default.cnf /etc/my.cnf

mysql 5.7 默认将 mysqld.service (/usr/local/mysql/) 文件安装到了 mysql 安装目录下的 usr/lib/systemd/system/,将 mysqld.service 复制到 /usr/lib/systemd/system/ 目录下

[root@localhost]/usr/local/mysql#cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system

添加环境变量

— 编辑 /etc/profile 文件在最后添加如下两行 —

vim /etc/profile

PATH=/usr/local/mysql/bin:$PATH
export PATH

source /etc/profile

 

初始化 无密码 mysql 数据库


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

出现下列内容,初始化成功
2016-02-22T03:56:27.254356Z 1 [Warning] root@localhost is created with an empty password ! Please consider switching off the –initialize-insecure option.

-–initialize 会生成一个随机密码 (保存在~/.mysql_secret),而 -–initialize-insecure 不会生成密码,在 MySQL 安全配置向导 mysql_secure_installation 设置密码时,可自由选择 mysql 密码等级。

-–datadir 目标目录下不能有数据文件。

之前版本初始化程序 mysql_install_db 是在 /usr/local/mysql/script 下,并会在将来被移除,转而使用 mysqld 替代 已被废弃 mysql5.7 放在了 /usr/local/mysql/bin 目录下。

启动 mysql

 

systemctl start mysqld.service

systemctl status mysqld.service

运行 MySQL 安全配置向导 mysql_secure_installation 设置密码,mysql 服务启动后才可执行

a) 为 root 用户设置密码
b) 删除匿名账号
c) 取消 root 用户远程登录
d) 删除 test 库和对 test 库的访问权限
e) 刷新授权表使修改生效

[root@localhost mysql]# mysql_secure_installation

Securing the MySQL server deployment.

Connecting to MySQL using a blank password. [使用空密码连接到 MySQL]

VALIDATE PASSWORD PLUGIN can be used to test passwords
and improve security. It checks the strength of password
and allows the users to set only those passwords which are
secure enough. Would you like to setup VALIDATE PASSWORD plugin?[VALIDATE 密码插件可以被用来测试密码
并提高安全性。你是否想设置 VALIDATE 密码插件?]

Press y|Y for Yes, any other key for No: y

There are three levels of password validation policy: [有三种级别的密码验证策略:]

LOW Length >= 8
MEDIUM Length >= 8, numeric, mixed case, and special characters
STRONG Length >= 8, numeric, mixed case, special characters and dictionary file
[最小长度 > = 8
中等长度 > = 8,数字,大小写混合和特殊字符
最长长度 > = 8,数字,混合大小写,特殊字符和字典文件 ]

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0 [请输入 0 = 低,1 = 中 2 = 强:0]
Please set the password for root here. [请在这里设置 root 用户的​​密码。]

New password: [新密码:]

Re-enter new password: [重新输入新密码:]

Estimated strength of the password: 25 [密码的估计强度:25]
Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y [您是否希望继续与提供的密码(按 y | Y 表示是,因为没有任何其他键):Y?]
… Failed! Error: Your password does not satisfy the current policy requirements [… 失败!错误:您的密码不符合当前的要求]

New password:

Re-enter new password:

Estimated strength of the password: 50 [密码的估计强度:50]
Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y
By default, a MySQL installation has an anonymous user,
allowing anyone to log into MySQL without having to have
a user account created for them. This is intended only for
testing, and to make the installation go a bit smoother.
You should remove them before moving into a production
environment. [默认情况下,MySQL 安装有一个匿名用户,
允许任何人登录到 MySQL.]

Remove anonymous users? (Press y|Y for Yes, any other key for No) : y [删除匿名用户?]
Success. [成功。]

Normally, root should only be allowed to connect from
‘localhost’. This ensures that someone cannot guess at
the root password from the network. [通常情况下,Root 只允许其进行 ’localhost'( 本地) 连接
。]

Disallow root login remotely? (Press y|Y for Yes, any other key for No) : n [禁止远程 root 登录?]

… skipping. [… 跳过。]
By default, MySQL comes with a database named ‘test’ that
anyone can access. This is also intended only for testing,
and should be removed before moving into a production
environment. [默认情况下,MySQL 带有一个名为“测试”数据库, 任何人都可以访问。这也是仅用于测试,并且应该移动到生产之前被删除环境。]

Remove test database and access to it? (Press y|Y for Yes, any other key for No) : n [删除测试数据库和访问权限?]

… skipping. [… 跳过。]
Reloading the privilege tables will ensure that all changes
made so far will take effect immediately. [刷新授权表以确保所有的变化取得将立即生效。]

Reload privilege tables now? (Press y|Y for Yes, any other key for No) : [现在刷新授权表?]

… skipping.
All done! [全部完成!]

开放 Root 远程连接权限
mysql -u root -p
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; 

  此处含有隐藏内容,需要正确输入密码后可见!

mysql>FLUSH PRIVILEGES; [刷新权限]

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计5396字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7999706
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流! 大家好,我是星哥,今天才思枯竭,不写技术文章了!来吐槽一下 CSDN。...
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...
飞牛NAS玩转Frpc并且配置,随时随地直连你的私有云

飞牛NAS玩转Frpc并且配置,随时随地直连你的私有云

飞牛 NAS 玩转 Frpc 并且配置,随时随地直连你的私有云 大家好,我是星哥,最近在玩飞牛 NAS。 在数...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集

Prometheus:监控系统的部署与指标收集 在云原生体系中,Prometheus 已成为最主流的监控与报警...
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...