使用二进制的方式安装mysql实践纪要

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 下面是记录使用二进制的方式安装mysql的步骤 2011.3.5      使用二进制安装的好处 mysql安装为什么大部分使用二进制安装。而不是源码手动去编译?mysql使用的glibc进行开发的。

下面是记录使用二进制的方式安装mysql的步骤 2011.3.5

     使用二进制安装的好处

mysql安装为什么大部分使用二进制安装。而不是源码手动去编译?

mysql使用的glibc进行开发的。glibc库是一个底层api,所以只要是linux,都会有glibc库。所以,mysql安装不需要考虑环境是否符合要求。移植性很方便。直接将编译好的二进制代码复制到另外一个机器上,也是可以用的。

原理性东西:一般在linux下安装一个软件,不同软件所需要的函数库不同。于是会遇到一个现象:一个软件复制到另外一个平台可能无法运行。安装软件需要先侦测环境就是出于此考虑。因为mysql使用的是通用的glibc函数库。没有对其他东西的依赖性。所以,从一个平台复制到另外一个平台能够通用。并不需要去侦测环境。直接使用编译好的二进制即可

手动编译安装,显得步骤麻烦。基于mysql的特点,二进制安装完全可以。

注:mysql5.5安装的时候,需要用到cmake命令,所以需要保证你的机器上安装了该命令。没有的话,还要去安装该cmake。也显得麻烦。我暂时不想去安装最新版本的了。


如果使用二进制安装升级怎么进行?

升级获取的还是二进制压缩包。那么,直接将指向目录切换到新的目录即可。

不需要涉及到像php一样,手动编译可以达到自己定制模块的好处。而mysql安装的时候不需要涉及到模块

mysql官方建议安装方式:二进制安装。

实践过程

大致思路就是:解压二进制文件放到指定的目录。然后安装基本的数据库,权限方面会用到。
然后,启动mysql就行了。

第一步:创建一个用户组和用户。

组名和用户名的名字都为mysql。

命令:1.groupadd mysql
      2.useradd -r -g mysql mysql


第二步:解压二进制压缩包。
一般放到"/usr/local/src"目录下去。
结果会变成:/usr/local/src/mysql安装目录

有很多种方式。一般可以直接进去要解压要存放的目录。
运行命令:tar zxvf 压缩包源  注释:第二个参数可以填要解压到的位置。第二个参数不填,就会将压缩包源解压到运行tar命令的当前目录。一般都是使用这种特性进行解压:你要解压到哪里就先进入哪里运行tar命令。




第三步:建立一个软链接。

在"usr/local"下建立一个软链接(自己定义名为mysql)。软链接的目录是为了指向"/usr/local/src/mysql安装目录"

命令:ln -s /usr/local/src/mysql安装目录 /usr/local/mysql    参数说明:-s参数表示建立软链接

ln命令的格式为,ln -s  快捷方式指向的位置(目录)  快捷方式名称(位置)

去local目录下查看,看是否成功生成了一个软链接。使用"ls -al"查看,特点是软连接上会有个箭头符号。

其实这一步就是为了提供一种快捷操作的方式。其实不建立软连接也是可以用的,为什么要这样做?
升级管理有用:新版本单独建立一个目录存放的。假如你升级mysql了。只要将这个软连接指向的目录修改即可。


第四步:权限检查与修改
主要是保证"mysql安装目录"的所有者为mysql用户,所属组也为mysql组。

1.chown -R mysql . //将当前目录的所有者改为mysql用户  要加上-R参数。这个参数表示循环遍历子节点。子节点都起作用
2.chgrp -R mysql . //将当前目录的所有组改为mysql组

常见的问题:忘记加上-R参数。结果下面节点没有权限。启动错误,访问错误等等一系列的问题。




第五步:安装初始化数据库
运行mysql安装目录下的文件:/scripts/mysql_install_db

命令备忘:scripts/mysql_install_db --user=mysql //这是进入mysql安装目录下进行运行的,所以需要输入路径"scripts/"
注意:必须在安装目录下执行。不能切换到scripts目录下,然后执行"./mysql_install_db --user=mysql",否则会报如下错误:

FATAL ERROR: Could not find ./bin/my_print_defaults

 

因为脚本mysql_install_db里面所使用的是这种形式的相对路径"./bin/my_print_defaults",所以必须是在"mysql安装目录"下,才能找得到所需文件。

第二次试验的时候,还报出一个错误:./bin/my_print_defaults: cannot execute binary file




第六步:my.cnf配置文件拷贝
将my.cnf文件移到etc/目录下去。
命令:cp support-files/my-medium.cnf /etc/my.cnf






第七步:启动mysql


马上启动mysql的命令是:bin/mysqld_safe --user=mysql & //"&"表示在后台运行
这里使用&的经验备忘:执行上面命令后,一直定在一个地方。没有任何反应了。并没有报错信息。还是成功的。此时使用ctrl+c。然后去看看


之后,想让服务器启动的时候就跟着启动mysql服务器,在一个目录下放一个文件:

cp support-files/mysql.server /etc/init.d/mysql.server
support-files/mysql.server在二进制安装目录下可以找到的。












完成后进行的步骤:
第一步:如何查看mysql是否安装成功。
一个方法是:去查看3306端口是否开启
命令:netstat -ntl  可以列出所有侦听的端口

第二个方法:使用mysql命令连接一次服务器
命令: mysql -u root

小技巧:为了省去每次执行客户端都要进入目录的麻烦。将客户端的路径加入环境变量中去。

shell命令:export PATH=$PATH:/usr/local/src/mysql-5.1/bin/

export命令备忘: export 变量名=变量值,这里变量名是PATH 变量值设置成在原来的$PATH基础上加,有多个值,那么值之间以分号":"隔开。
这样,在任意路径中。都可以通过:"mysql -u 用户名 -p" 的形式使用客户端了。

 

 

所遇问题总结

第一个问题:

问题描述:SQLSTATE[HY000] [2002] Can't connect to local MySQL server through socket '/usr/local/mysql/tmp/mysql.sock'


问题经验:

不能通过 '/tmp/mysql.sock'连到服务器,而php标准配置正是用过'/tmp/mysql.sock'

1.php.ini中可以配置通过哪个sock去连接mysql
2.而mysql的配置文件中也可以自由配置使用哪个位置的sock文件

错误提示中显示了错误2002号。结合手册如下说明:

错误:2002 (CR_CONNECTION_ERROR)

消息:不能通过套接字'%s' (%d)连接到本地MySQL服务器。


第二个问题:权限问题。

解决问题的经验是:如果遇到启动mysql错误。首先应该去看看权限是否有。设置对了没。

比如启动使用"service mysqld start"常常看到如下错误提示:

mysqld_safe Logging to '/usr/local/mysql/data/localhost.localdomain.err'.
110306 23:17:20 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data
110306 23:17:20 mysqld_safe mysqld from pid file /usr/local/mysql/data/localhost.localdomain.pid ended

看不懂意思。这些信息会在data/*.err文件中记录的。不知道上述报错信息的原因。

查看目录下的子节点,发现所有者和所属组并不都是mysql。我直接设置好目录的所有者和所属组都是mysql后。就行了。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
存储 Ubuntu 关系型数据库
Ubuntu 20.04 卸载与安装 MySQL 5.7 详细教程
该文档提供了在Ubuntu上卸载和安装MySQL 5.7的步骤。首先,通过`apt`命令卸载所有MySQL相关软件包及配置。然后,下载特定版本(5.7.32)的MySQL安装包,解压并安装所需依赖。接着,按照特定顺序安装解压后的deb包,并在安装过程中设置root用户的密码。安装完成后,启动MySQL服务,连接数据库并验证。最后,提到了开启GTID和二进制日志的配置方法。
|
12天前
|
关系型数据库 MySQL 数据安全/隐私保护
MySQL安装
MySQL安装
36 1
|
5天前
|
关系型数据库 MySQL Linux
【MySQL】如何在Linux上安装MySQL
【MySQL】如何在Linux上安装MySQL
43 1
|
11天前
|
存储 关系型数据库 MySQL
MySQL表分区的选择与实践小结
当面对百万或千万级数据量的表,即使有索引,查询速度也可能较慢。此时,可以采取分库、分表或分区策略来提升性能。分库分表涉及创建新数据库或表,可能需更改逻辑代码;
61 3
|
12天前
|
关系型数据库 MySQL Linux
在Linux系统中安装MySQL数据库
在Linux系统中安装MySQL数据库
64 3
|
12天前
|
Ubuntu 关系型数据库 MySQL
|
14天前
|
安全 关系型数据库 MySQL
解决centos7.0安装mysql后出现access defind for user@'localhost'的错误
在使用yum 安装完mariadb, mariadb-server, mariadb-devel后
19 0
|
17天前
|
SQL 存储 关系型数据库
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!(下)
必知的 MySQL 索引失效场景【包括实践验证】,别再踩坑了!
91 2
|
15天前
|
关系型数据库 MySQL API
实时计算 Flink版产品使用合集之可以通过mysql-cdc动态监听MySQL数据库的数据变动吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
124 0
|
10天前
|
存储 SQL 关系型数据库
【MySQL】数据库基础 -- 详解
【MySQL】数据库基础 -- 详解