Armbian OS(基于ubuntu24) 源码编译mysql 5.7

news2025/1/11 8:08:39

最近弄了个S905X3的盒子刷完Armbian OS (基于ubuntu24),开始折腾Arm64之旅。第一站就遇到了MySQL的问题,由于MySQL没有提供Arm64版本,又不想塞Docker镜像,因此选择源码来编译MySQL5.7。下面记录详细过程和遇到的一些问题

CMAKE

最新的mysql均采用cmake的环境,因此要编译从cmake开始。Armbian OS默认安装的都是精简系统,得自行安装一下cmake

apt install cmake

至于BuildEssiontial,貌似默认就带了,于是继续往下走

万年的MySQL57,万年的OPENSSL1.1

要装MySQL,一个蛋疼的组件就是OPENSSL,众所周知从ubuntu22开始,openssl 1.1版就已经没有在默认库带上了。其它系统上还可以通过强制指定库来处理,Arm系统下,只得自己下来源码编译

wget https://mirrors.tencent.com/openssl/source/old/1.1.1/openssl-1.1.1v.tar.gz

然后展开后一路make && make install就好了

下载MYSQL57源码

下载最新带boost的源码包

https://cdn.mysql.com/archives/mysql-5.7/mysql-boost-5.7.44.tar.gz

下来后然后展开

tar -xvf mysql-boost-5.7.44.tar.gz

然后把依赖更新一下,对于ubuntu24来说,是这几个

apt-get install libncurses-dev
apt install pkg-config
apt install libtirpc-dev

补丁&开始编译

源码展开后,要补丁一下,否则mysql client工具会报segmentation fault错误无法使用:

在源码解压文件中,找到terminal.h源码文件并编辑

find / -name "terminal.h" -print | head -n 1 | xargs vi

将其中的ifdef __sun 段注释掉完全开放
修改后是这样

/* #ifdef __sun */
extern int tgetent(char *, const char *);
extern int tgetflag(char *);
extern int tgetnum(char *);
extern int tputs(const char *, int, int (*)(int));
extern char* tgoto(const char*, int, int);
extern char* tgetstr(char*, char**);
/* #endif */

然后就可以开始编译了,进入mysql展开的目录(我的是展开到了/opt/setups/mysql/mysql-5.7.44),执行以下代码先开启4核(我的HK1BOX是4核ARM):

export MAKEFLAGS=-j4

进入到展开的源码目录执行,然后下面是编译命令:

cmake . -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_BOOST=/opt/setups/mysql/mysql-5.7.44/boost/

最好加个nohup后台执行,因为太。。。。漫长了。

在我的小盒子里开4个线程,7W的满载功率,跑了1个小时才编译完,这还是开4线程跑的

幸好改装了风扇压住了温度,最高保持在50度(室温25)

配置MYSQL

建立一个MYSQL用户,然后把目标目录授权给该用户

groupadd mysql
useradd mysql -s /sbin/nologin -M -g mysql
chown -R mysql:mysql /usr/local/mysql

把mysql加入到路径,这样后面执行命令就方便了

echo "export PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
source /etc/profile

优化一下配置,对于我们这种小盒子系统,资源占用越小越好

vi /etc/my.cnf

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html

[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
datadir=/opt/mysql/data
socket=/opt/mysql/mysql.sock

# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

log-error=/opt/mysql/mysqld.log
pid-file=/opt/mysql/mysqld.pid

#密码检查规则关闭
#validate_password=off

max_allowed_packet = 16M
skip-character-set-client-handshake
default-storage-engine=INNODB
character_set_server=utf8mb4
collation-server=utf8mb4_unicode_ci
init-connect='SET NAMES utf8mb4'
lower_case_table_names=1
max_connections=1000

server-id=1
log-bin=mysql-bin
expire_logs_days=7

performance_schema_max_table_instances=200
table_definition_cache=200
table_open_cache=128

然后按配置的初始化一下目录和权限

mkdir -p /opt/mysql/data
chown -R mysql:mysql /opt/mysql/

执行初始化

mysqld --defaults-file=/etc/my.cnf --initialize --user=mysql

然后查看root默认密码:

cat /opt/mysql/mysqld.log | grep "temporary password"

写个启动服务

vi /etc/systemd/system/mysqld.service

内容如下:

[Unit]
Description=MySQL Server Daemon
After=network.target

[Service]
User=mysql
Group=mysql
Type=forking
PIDFile=/opt/mysql/mysqld.pid
ExecStart=/usr/local/mysql/bin/mysqld --daemonize
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutStartSec=120
TimeoutStopSec=10
KillMode=process
Restart=on-failure
LimitNOFILE=5000

[Install]
WantedBy=multi-user.target

然后设置自启动:

systemctl enable mysqld

前面都正确的话,应该本地就可以用root+初始密码进入了

mysql -uroot -p"Mu>aiR,Zx502" mysql

然后修改下默认密码,例如:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'admin'

重启mysqld服务,完事

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1820368.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

磁盘管理 以及磁盘的分区 详细版

磁盘管理 track:磁道,就是磁盘上同心圆,从外向里,依次1号、2号磁道sector:扇区,将磁盘分成一个一个扇形区域,每个扇区大小是512字节,从外向里,依次是1号扇区、2号扇区cylinder&…

swift5 在当前控制器先dismiss后pop

如下图需要在present当前控制器时用全局变量firmwareUpgradePresentingVC先引用上一个控制器(下面的代码亲测有效) func dismissAndPop() {self.dismiss(animated: false) {firmwareUpgradePresentingVC.navigationController!.popViewController(animat…

比利时海外媒体宣发,发稿促进媒体通稿发布新形势-大舍传媒

引言 随着全球化的推进,海外媒体的影响力也日益增强。在这一背景下,比利时海外媒体的宣发工作成为了媒体通稿发布的新形势。大舍传媒作为一家专注于宣传推广的公司,一直致力于与比利时博伊克邮报(boicpost)合作&#…

ubuntu软件安装

目录 更新Ubuntu软件下载地址 1. 寻找国内镜像源 2. 备份Ubuntu默认的源地址 3. 更新源服务器列表 4. 更新源 更新Ubuntu软件下载地址 1. 寻找国内镜像源 所谓的镜像源:可以理解为提供下载软件的地⽅,⽐如 Android ⼿机上可以下载软件的 91 ⼿机助…

荣耀正式发布Magic V Flip,打造全形态折叠屏矩阵

6月13日,荣耀Magic V Flip科技时尚大秀在上海举行。作为荣耀旗下首款小折叠手机,荣耀Magic V Flip的问世标志着荣耀完成折叠屏全体系的最终部署,成为少数集齐现有各类折叠屏手机形态的品牌之一。 荣耀从消费者需求出发,以AI和折叠…

Spring Security——添加验证码

目录 项目总结 新建一个SpringBoot项目 VerifyCode(生成验证码的工具类) WebSecurityController控制器 VerifyCodeFilter(自定义过滤器) WebSecurityConfig配置类 login.html登录页面 项目测试 本项目是以上一篇文章的项目…

【知识整理】软件版本号的定义及规范

版本号简述 在软件开发项目中,版本号是一个非常重要的概念,它能够告诉用户软件的功能、质量和安全性等信息,同时也可以帮助开发者追踪软件的历史和进展,并做好版本控制工作。在本文中,我们将介绍版本号的定义及规范&a…

创新入门|生成式AI创新赋能优势解析,获取生成式AI知识的10大方法

生成式AI技术对员工和企业影响深远。对于员工而言,生成式AI能够提升工作效率,简化重复性任务,并为创意和决策提供支持。对于企业而言,生成式AI在产品创新、市场营销、客户服务和运营优化等方面发挥重要作用,帮助预测市…

一篇文章全面了解Ajax框架

目录 什么是AJAX? 如何使用AJAX? 语法 url详解 URL的概念 URL的组成 URL查询参数 axios axios-查询参数 axios-请求配置 常用请求方法 axios-错误处理 HTTP协议 HTTP协议-请求报文 HTTP协议-响应报文 接口文档 AJAX原理 AJAX原理 - XM…

【STM32】飞控设计

【一些入门知识】 1.飞行原理 【垂直运动】 当 mg>F1F2F3F4,此时做下降加速飞行 当 mg<F1F2F3F4,此时做升高加速飞行 当 mgF1F2F3F4 ,此时垂直上保持匀速飞行。 【偏航飞行】 ω 4 ω 2 ≠ ω 1 ω 3 就会产生水…

选择制造业生产管理系统指南

在当今日益激烈的市场竞争中,制造业企业要想保持领先地位,就必须拥有一套高效、智能的生产管理系统。选择一套合适的制造业生产管理系统,不仅能帮助企业优化生产流程、提高生产效率,还能降低生产成本、提升产品质量。 一、发现制…

Unity UGUI ScrollRect 滑动显示左右箭头

目录 一、前言 二、效果 三、代码解析 EnhancedScrollRect.cs 解析 Start 方法 HandleArrowVisibility 方法 EnhancedScrollRectEditor.cs 解析 OnEnable 方法 OnInspectorGUI 方法 四、完整代码 EnhancedScrollRect.cs EnhancedScrollRectEditor.cs 五、总结 De…

ollama系统更改模型存放位置

1.windows 设置完后可以在cmd中检查一下:echo %ollama_models% 2.linux 首先第一步:cd /etc/systemd/system/ 打开配置文件vim ollama.service 第二步:目录下的environment里面分号隔开添加OLLAMA_MODELS环境变量 第三步:source …

单张图像扩散模型(Single Image DIffusion Model)

论文:SinDDM: A Single Image Denoising Diffusion Model, ICML 2023 去噪扩散模型(DDM)在图像生成、编辑和恢复方面带来了惊人的性能飞跃。然而,现有DDM使用非常大的数据集进行训练。在这里,介绍一个用于…

tkinter文本对齐方式

tkinter文本对齐方式 文本对齐方式效果代码 文本对齐方式 左对齐(left):默认对齐方式,文本从左边界开始。右对齐(right):文本从右边界开始。居中对齐(center)&#xff1…

代码生成-CodeGeeX2本地部署体验

一 CodeGeeX2介绍: CodeGeeX2 是多语言代码生成模型 CodeGeeX (KDD’23) 的第二代模型。不同于一代 CodeGeeX(完全在国产华为昇腾芯片平台训练) ,CodeGeeX2 是基于 ChatGLM2 架构加入代码预训练实现,得益于 ChatGLM2 的…

深圳尚水智能IPO迷局:创始人不看好公司发展退出,比亚迪加入

近日,上海证券交易所披露的信息显示,深圳市尚水智能股份有限公司(下称“尚水智能”)及其保荐人民生证券撤回上市申请文件。因此,上海证券交易所决定终止对其首次公开发行股票并在科创板上市的审核。 据贝多财经了解&am…

前端技术回顾系列 10|TS 泛型在类和接口中的应用

在微信中阅读,关注公众号:CodeFit。 创作不易,如果你觉得这篇文章对您有帮助,请不要忘了 点赞、分享 和 关注 我的公众号:CodeFit,为我的持续创作提供动力。 上文回顾:约束泛型(Generic Constraints) 上一篇文章我们回顾了 泛型 在 TypeScript 中的高级用法 —— 泛型…

为什么需要负样本

假如我们只有正样本,模型在最开始训练的时候都是错误的,随着模型的迭代,准确率逐渐从0到1,最终将所有的样本都判别成正样本,也就是都在线的上方。 但真实的场景中有正有负,例如我们要做一个猫狗分类器&…

anaconda安装pytorch-快速上手99%可以(可以虚拟环境OR不进行虚拟环境)

一、预备工作 先检查自己是否有anaconda 在cmd里面输入conda --version查看 二、在anaconda中创建虚拟环境 1.1 打开Anaconda Prompt 1.2 进行自定义安装python 将其中的自定义地址和版本换成自己想安装的地址和版本 我这里安装的地址是E:\Anaconda\DL,python版本是3.8.3…