ARM 架构源码编译部署 MySQL 5.7.42完整实战文档

文章目录

一、环境说明

  • 系统:Huawei Cloud EulerOS 2.0 (aarch64)
  • 内核:5.10.x
  • 架构:aarch64(ARM64)
  • MySQL版本:5.7.42(Source Distribution)
  • 安装方式:源码编译安装

二、为什么只能源码编译?

  1. 官方MySQL5.7已停止维护
  2. 官方5.7仅提供x86_64二进制包
  3. ARM架构(aarch64)无法使用rpm/tar二进制包
  4. Percona/Oracle均不提供5.7ARM编译包

👉 结论:只能源码编译,这是唯一可靠方案。

三、安装依赖环境

bash 复制代码
yum install -y \
gcc gcc-c++ make cmake3 \
ncurses-devel openssl-devel libaio-devel \
bison perl perl-Data-Dumper \
libtirpc-devel rpcgen \
zlib-devel

四、准备Boost(必须)

MySQL5.7强依赖Boost1.59,不能用系统Boost。

bash 复制代码
cd /usr/local/src
wget https://archives.boost.io/release/1.59.0/source/boost_1_59_0.tar.gz
tar xf boost_1_59_0.tar.gz

五、创建 MySQL 用户

bash 复制代码
groupadd mysql
useradd -r -g mysql -s /sbin/nologin mysql

六、准备目录结构

bash 复制代码
mkdir -p /usr/local/mysql
mkdir -p /data1/mysqldb/{data,log,run,tmp}
chown -R mysql:mysql /usr/local/mysql /data1/mysqldb

七、源码编译 MySQL 5.7.42

1️⃣解压源码

bash 复制代码
cd /usr/local/src
tar xf mysql-5.7.42.tar.gz
cd mysql-5.7.42
mkdir build && cd build

2️⃣CMake 配置(关键)

bash 复制代码
cmake .. \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/data1/mysqldb/data \
-DSYSCONFDIR=/etc \
-DMYSQL_TCP_PORT=3306 \
-DMYSQL_UNIX_ADDR=/data1/mysqldb/run/mysql.sock \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_SSL=system \
-DWITH_ZLIB=system \
-DENABLED_LOCAL_INFILE=1 \
-DDEFAULT_CHARSET=utf8mb4 \
-DDEFAULT_COLLATION=utf8mb4_general_ci \
-DWITH_BOOST=/usr/local/src/boost_1_59_0

看到 Configuring done 即表示成功

3️⃣ 编译与安装

bash 复制代码
make -j$(nproc)   # 使用当前机器全部 CPU 核心并行编译(nproc=CPU核数),编译速度最快,但会瞬间拉满 CPU,生产环境慎用
make -j8          # 限制并行编译任务数,避免对线上业务造成影响,8代表CPU核数
make install

八、初始化数据库

1️⃣ 初始化(无密码模式)

bash 复制代码
/usr/local/mysql/bin/mysqld --initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/data1/mysqldb/data

root 初始密码为空

九、MySQL 配置文件

bash 复制代码
vim /etc/my.cnf
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /data1/mysqldb/data
port = 3306

socket = /data1/mysqldb/tmp/mysql.sock
pid-file = /data1/mysqldb/run/mysqld.pid
log-error = /data1/mysqldb/log/mysqld.log

character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
max_connections = 500

[client]
socket = /data1/mysqldb/tmp/mysql.sock
port = 3306

十、systemd 服务配置

bash 复制代码
cat >/etc/systemd/system/mysqld.service <<'EOF'
[Unit]
Description=MySQL Server
After=network.target


[Service]
Type=simple
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf
Restart=on-failure


[Install]
WantedBy=multi-user.target
EOF

十一、启动MySQL

bash 复制代码
systemctl daemon-reload
systemctl enable mysqld
systemctl start mysqld

十二、首次登录与安全设置

bash 复制代码
mysql -uroot

设置 root 密码

bash 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'Root@123456';
FLUSH PRIVILEGES;
相关推荐
麦聪聊数据4 分钟前
为何通用堡垒机无法在数据库运维中实现精准风控?
数据库·sql·安全·低代码·架构
2的n次方_25 分钟前
CANN Ascend C 编程语言深度解析:异构并行架构、显式存储层级与指令级精细化控制机制
c语言·开发语言·架构
L、21836 分钟前
深入理解CANN:面向AI加速的异构计算架构详解
人工智能·架构
AI+程序员在路上43 分钟前
Nand Flash与EMMC区别及ARM开发板中的应用对比
arm开发
chian-ocean2 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
Max_uuc2 小时前
【架构心法】嵌入式系统的“防御性编程”:如何构建一个在灾难中存活的系统
架构
lbb 小魔仙2 小时前
面向 NPU 的高性能矩阵乘法:CANN ops-nn 算子库架构与优化技术
线性代数·矩阵·架构
是码龙不是码农3 小时前
支付防重复下单|5 种幂等性设计方案(从初级到架构级)
java·架构·幂等性
云边有个稻草人3 小时前
CANN异构架构:以ops-nn为翼,驱动AIGC底层计算新突破
架构·aigc
心疼你的一切3 小时前
模态交响:CANN驱动的跨模态AIGC统一架构
数据仓库·深度学习·架构·aigc·cann