《MySQL DBA修炼之道》——2.2 官方版本的安装

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

本节书摘来自华章出版社《MySQL DBA修炼之道》一书中的第2章,第2.2节,作者:陈晓勇,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.2 官方版本的安装

下面将以Linux下MySQL 5.1和MySQL 5.5的安装为例进行讲解。为了避免冲突,可以考虑先卸载Linux下自带的MySQL安装包,可使用“rpm -qa |grep MySQL”检测是否安装了MySQL相关包。
推荐大家使用二进制版本的安装,主要原因是简单方便,而且官方的二进制包也是经过了充分的测试验证和参数优化的。使用源代码编译的方式安装可能会有一定性能的提升,但在实际应用中,可能会由于编译源码而出现各种问题,如果不清楚编译的参数,建议还是使用二进制版本。此外,无论是使用二进制版本还是源码编译,大规模的部署都必须尽量做到自动化安装,否则安装部署的成本会比较高。
2.2.1 二进制包的安装
首先登录官网,下载二进制版本,步骤如下。
1)进入www.mysql.com。
2)选择downloads(GA)。
3)单击Download from MySQL Developer Zone。
4)单击MySQL Community Server。
5)选择相应的平台、版本,比如,选择64位Linux平台下的MySQL二进制包“Linux - Generic(glibc 2.5)(x86,64-bit),Compressed”。
下面开始二进制版本的安装。
1.在root下安装MySQL
这种安装方式为默认方式,这里以“mysql-5.1.45-linux-x86_64-icc-glibc23.tar.gz”为例进行讲解。
以root身份登录,运行如下命令安装MySQL。

useradd mysql
cd /usr/local
tar zxvf /tmp/mysql-5.1.45-linux-x86_64-icc-glibc23.tar.gz
ln -s mysql-5.1.45-linux-x86_64-icc-glibc23 mysql
cd mysql
cp support-files/my-large.cnf /etc/my.cnf
chown -R mysql .
chgrp -R mysql .
scripts/mysql_install_db --user=mysql
chown -R root .
chown -R mysql data
mv data /home/mysql/
ln -s /home/mysql/data .
AI 代码解读

上面的命令中移动data目录到其他分区(/home/mysql),是因为/usr/local下的磁盘空间可能不够。一般数据目录会存放到和操作系统不一样的分区或磁盘中。
下面是安装后的目录及文件说明。
安装后在安装目录mysql/bin中有如下内容。
mysqld:MySQL服务主程序。
mysqld_safe:MySQL服务启动脚本。
mysql:MySQL命令行工具。
mysqladmin:MySQL客户端(管理数据库)。
perror:显示错误码(状态码)含义。
mysqlbinlog:是处理二进制日志文件的实用工具。
将MySQL配置为自启动服务,并启动。

cp support-files/mysql.server /etc/init.d/mysqld
chkconfig mysqld on
/etc/init.d/mysqld start
AI 代码解读

运行如下命令设置MySQL root密码。
/usr/local/mysql/bin/mysqladmin -u root password 'your_password'
之后,使用MySQL自带的脚本或手动执行命令强化安全,删除匿名用户。自动化的方式是在root用户下执行如下命令。
./bin/mysql_secure_installation
然后按照提示操作,删除匿名账户和空密码的账户。
手动删除匿名账户的操作方法如下。

shell> mysql -u root
mysql> DELETE FROM mysql.user WHERE User = '';
mysql> FLUSH PRIVILEGES
AI 代码解读


bdb263419aac65e0a8a385cbb5fad6378b758c19

建议使用/usr/bin/mysql_secure_installation 脚本进行安全配置,它会帮你删除匿名账号。安装完成后,注意把要执行命令的路径添加到系统的PATH变量里,命令如下。

vi ~mysql/.bash_profile
export PATH=/usr/local/mysql/bin:$PATH
AI 代码解读

2.安装在特定的用户下面
首先,编辑一份自己的配置文件,指定PORT、SOCKET等参数变量。安装和启动的时候需要指定这个配置文件,其他操作和默认安装类似。比如,要安装到“$HOME/app/”下,命令如下。

cd $HOME/app
tar zxvf /path/mysql-5.1.45-linux-x86_64-icc-glibc23.tar.gz
ln -s  mysql-5.1.45-linux-x86_64-icc-glibc23 mysql
cd mysql
scripts/mysql_install_db --defaults-file=/home/garychen/app/mysql/my.cnf  --user=garychen
AI 代码解读

如果配置文件没有指定数据目录的话,则默认是在/home/garychen/app/mysql/data下。
启动方式如下。
./bin/mysqld_safe --defaults-file=/home/garychen/app/mysql/my.cnf --user=garychen &


65bcfa42e58f36e546393f1adc5dedadc001be46

此外,如果是生产环境下的大批量部署,一般建议定制自己的自动化安装脚本,或者通过自动化平台安装。
2.2.2 源码编译安装
本书不建议一般使用者使用源码编译的方式进行安装,如果决定编译安装,最好想想是否真的值得这样做,它可能对于性能提升并无多大作用,但却可能会带来潜在的不稳定因素,你必须确保自己对某些编译选项很熟悉,因为许多生产问题都来自于错误的编译方式。
可采用如下的命令查看已经安装的MySQL编译选项。
cat /usr/local/mysql/bin/mysqlbug | grep CONFIGURE_LINE
下面以MySQL 5.5为例讲解源码编译安装的基本步骤。
1)下载“MySQL-5.5.33.tar.gz”。
2)确认系统已经安装了cmake。
3)编译安装MySQL,命令如下。
#创建运行MySQL的用户
shell> groupadd mysql
shell> useradd -r -g mysql mysql
#开始编译安装
shell> tar zxvf mysql-VERSION.tar.gz
shell> cd mysql-VERSION
shell> cmake . -LH  # overview with help text
shell> cmake .
shell> make-j 8
shell> make install
#安装后配置、初始化数据库
shell> cd /usr/local/mysql
shell> chown -R mysql .
shell> chgrp -R mysql .
shell> scripts/mysql_install_db --user=mysql
shell> chown -R root .
shell> chown -R mysql data
#启动MySQL Server
shell> cp support-files/my-medium.cnf /etc/my.cnf
shell> bin/mysqld_safe --user=mysql &
#添加到自启动服务
shell> cp support-files/mysql.server /etc/init.d/mysql.server
shell>chkconfig mysql.server on
#设置root密码
/usr/local/mysql/bin/mysqladmin -u root password  'your_password'
#类似二进制安装,还需要进行安全强化,运行
./bin/mysql_secure_installation
AI 代码解读
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
27 9
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
59 14
MySQL版本升级(8.0.31->8.0.37)
本次升级将MySQL从8.0.31升级到8.0.37,采用就地升级方式。具体步骤包括:停止MySQL服务、备份数据目录、下载并解压新版本的RPM包,使用`yum update`命令更新已安装的MySQL组件,最后启动MySQL服务并验证版本。整个过程需确保所有相关RPM包一同升级,避免部分包遗漏导致的问题。官方文档提供了详细指导,确保升级顺利进行。
79 16
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
46 7
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
95 24
Windows Server 安装 MySQL 8.0 详细指南
安装 MySQL 需要谨慎,特别注意安全配置和权限管理。根据实际业务需求调整配置,确保数据库的性能和安全。
77 9
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
148 7
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
45 3