HCRM博客

如何在CentOS上通过源码安装MySQL?

在CentOS 7系统中,通过编译源码安装MySQL数据库是一种常见且灵活的方法,尽管这种方法相对复杂,但它提供了更高的定制性和灵活性,适用于需要高度定制化安装的场景,下面将详细介绍如何在CentOS 7中通过编译源码的方式安装MySQL数据库。

一、准备工作

1、更新系统:确保CentOS 7系统已更新到最新状态,可以使用以下命令进行更新:

如何在CentOS上通过源码安装MySQL?-图1
(图片来源网络,侵权删除)
   sudo yum update y

2、安装必要的编译工具:使用以下命令安装编译所需的工具:

   sudo yum install y gccc++ cmake make

二、下载MySQL源码

从MySQL官方网站下载MySQL的源代码包,假设我们要安装MySQL 8.0.29,可以使用如下命令下载并解压源码:

   wget https://cdn.mysql.com//Downloads/MySQL8.0/mysql8.0.29.tar.gz
   tar xzvf mysql8.0.29.tar.gz
   cd mysql8.0.29

三、编译安装MySQL

1、配置编译参数:在编译MySQL之前,需要配置编译参数,这一步非常重要,因为它决定了MySQL的功能和性能,使用以下命令配置编译参数:

   cmake \
       DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
       DDEFAULT_CHARSET=utf8mb4 \
       DDEFAULT_COLLATION=utf8mb4_unicode_ci \
       DWITH_EXTRA_CHARSETS=all \
       DWITH_MYISAM_STORAGE_ENGINE=1 \
       DWITH_INNOBASE_STORAGE_ENGINE=1 \
       DWITH_PARTITION_STOREAGE_ENGINE=1 \
       DWITH_READLINE=1 \
       DWITH_ZLIB=system \
       DWITH_LIBWRAP=0 \
       DWITH_DEBUG=0 \
       DENABLED_LOCAL_INFILE=1 \
       DWITH_SSL=system \
       DWITH_EMBEDDED_SERVER=1 \
       DWITH_PLUGIN_DIR="/usr/local/mysql/lib/plugin" \
       .

2、编译和安装:配置完成后,可以开始编译和安装MySQL,使用以下命令进行编译和安装:

   make j $(nproc)
   sudo make install

四、配置MySQL

1、创建MySQL用户和组:为了安全起见,需要为MySQL创建一个专用的用户和组,使用以下命令创建用户和组:

   sudo groupadd mysql
   sudo useradd r g mysql mysql

2、初始化MySQL数据库:将MySQL数据目录的所有权更改为mysql用户,并初始化数据库,使用以下命令:

如何在CentOS上通过源码安装MySQL?-图2
(图片来源网络,侵权删除)
   sudo chown R mysql:mysql /usr/local/mysql
   sudo /usr/local/mysql/bin/mysqld initialize user=mysql

3、启动MySQL服务:使用以下命令启动MySQL服务:

   sudo /usr/local/mysql/bin/mysqld_safe user=mysql &

4、创建MySQL服务:为了让MySQL服务在系统启动时自动启动,需要创建一个systemd服务文件,使用以下命令创建服务文件:

   sudo cat > /etc/systemd/system/mysqld.service <<EOF
   [Unit]
   Description=MySQL Server
   After=network.target
   [Service]
   User=mysql
   Group=mysql
   ExecStart=/usr/local/mysql/bin/mysqld_safe
   Restart=always
   RestartSec=10
   [Install]
   WantedBy=multiuser.target
   EOF

5、启用并启动MySQL服务:使用以下命令启用并启动MySQL服务:

   sudo systemctl enable mysqld
   sudo systemctl start mysqld

五、登录MySQL并设置root密码

1、登录MySQL:使用以下命令登录MySQL服务器:

   sudo /usr/local/mysql/bin/mysql u root

2、设置root密码:在登录后,使用以下命令设置root用户的密码:

   ALTER USER 'root'@'localhost' IDENTIFIED BY 'your_password';
   FLUSH PRIVILEGES;
   EXIT;

六、与RPM包安装的比较

通过编译源码安装MySQL与使用RPM包安装相比,有以下区别:

如何在CentOS上通过源码安装MySQL?-图3
(图片来源网络,侵权删除)

1、灵活性:编译源码可以让你根据需要选择不同的编译选项,从而获得更符合需求的功能和性能。

2、兼容性:编译源码时可以确保MySQL与现有系统环境的兼容性。

3、复杂性:编译源码安装相对复杂,需要更多的时间和专业知识。

4、维护:使用RPM包安装的MySQL更容易维护和更新,因为可以通过包管理器轻松升级。

5、社区支持:RPM包安装通常会有更好的社区支持,包括文档和问题解决。

实践心得

在实际操作过程中,我们需要注意以下几点:

1、备份:在进行任何重大操作前,确保备份重要的数据。

2、版本选择:选择适合你业务需求的MySQL版本。

3、安全性:确保设置强密码并限制root用户的远程访问。

4、性能调优:根据实际负载情况调整MySQL的配置文件。

通过上述步骤,我们成功地在CentOS 7中通过编译源码的方式安装了MySQL数据库,尽管这种方法相对复杂,但它能够提供更高的定制性和灵活性,对于需要高度定制化安装的场景,编译源码安装无疑是一个很好的选择。

本站部分图片及内容来源网络,版权归原作者所有,转载目的为传递知识,不代表本站立场。若侵权或违规联系Email:zjx77377423@163.com 核实后第一时间删除。 转载请注明出处:https://blog.huochengrm.cn/pc/19947.html

分享:
扫描分享到社交APP
上一篇
下一篇