ARMv8.0下duckdb的安装与编译过程-解决 Failed to allocate block of 2048 bytes


背景

duckdb 是一个很流行的单机版数据库引擎
同事下载了相关的预编译的二进制, 发现duckdb会报错如下:
"Out of Memory Error: Failed to allocate block of 2048 bytes"
详细的错误信息为:
./duckdb
v0.9.0 0d84ccf478
Enter ".help" for usage hints.
Connected to a transient in-memory database.
Use ".open FILENAME" to reopen on a persistent database.
D select 1 ;
Error: unable to open database ":memory:": Out of Memory Error: Failed to allocate block of 2048 bytes

简单的验证

github 上面很多类似的错误提示信息的issue
大部分都指向了 ARMv8的 64KB的页大小问题 需要注明
x86大部分的页大小是 4KB
但是aarch64的页面大小却是 64KB
验证方法
getconf PAGESIZE
65536 大部分报错都提示与页大小强相关.
解决方法也比较简单:
编译时增加参数为:
-DBUILD_JEMALLOC_EXTENSION=0
就可以解决这个问题.

一波三折

看到问题issue其实还是很高兴的
直接进行了相关的操作 git clone https://github.com/duckdb/duckdb
cd duckdb
cmake -DBUILD_JEMALLOC_EXTENSION=0
time make 等待了30分钟后(ARM编译比较慢)
duckdb 9.2 的编译结果依旧是报错 看到issue里面说需要切换到最新分支, 直接懵逼了
这个已经是 2023.10.20 时最新的分支了 . 依旧报错.
自己在9.1 9.2 的两个版本进行了多次编译, 耗费了接近一天的时间(这个是支线工作)
依旧不行

问题解决

为了解决上面的问题
自己按照issue里面提的 直接下载了 v0.5.0 的的预编译包,发现是可以的
但是同事反馈, 这个预编译包很多特定有丢失. 这两个场景很容易猜测到是不是 9.0的版本出现了比较坑的Bug
为了验证. 晚上开始进行一下版本降级的编译与测试 步骤为
cd duckdb
mkdir build8.0 build8.1 build9.0 [root@BM119 duckdb]# cd duckdb/
[root@BM119 duckdb]# ll
总用量 220
drwxr-xr-x 13 root root 311 10月 21 00:00 benchmark
drwxr-xr-x 9 root root 305 10月 19 15:12 build
drwxr-xr-x 9 root root 305 10月 20 22:35 build8.0
drwxr-xr-x 9 root root 305 10月 20 23:14 build8.1
drwxr-xr-x 9 root root 305 10月 21 00:26 build9.0 然后进入到不同的版本build 里面执行相关命令
比如 build8.0
执行命令为:
cd duckdb
git checkout v0.8.0
cd build8.0
cmake -DBUILD_JEMALLOC_EXTENSION=0 ..
time make 需要注意
第一步的 git checkout v0.8.0 将duckdb的版本进行进行一下切换. 到具体的版本号上面
cmake 在build8.0的子目录下面,通过 .. 获取上一级目录的资源信息.
然后再build8.0 的目录下面执行make, 就会产生特定版本的duckdb的二进制 checktout 的提示为:
之前的 HEAD 位置是 0d84ccf478 Merge pull request #9101 from carlopi/i686
HEAD 目前位于 e8e4cea5ec Merge pull request #7550 from hannes/httpfsstaticopensslforsure 然后cmake时会展示版本信息
[root@BM119 build]# cmake ..
-- git hash e8e4cea5ec, version v0.8.0
CMake Warning at CMakeLists.txt:443 (message):
Please use a recent compiler for debug builds

结论

duckdb的 v0.9.0 以及之后的版本aarch64编译后会报错
v0.8.1的版本增加了 -DBUILD_JEMALLOC_EXTENSION=0 后还是可以正常运行的
应该是官方的bug. 可能duckdb v0.9.0 忘记考虑这个场景了.
其实可以提一个issue 让duckdb官方处理 !-_-!
验证效果 [root@BM119 build8.1]# ./duckdb
v0.8.1 6536a77232
Enter ".help" for usage hints.
Connected to a transient in-memory database.
Use ".open FILENAME" to reopen on a persistent database.
D select 1;
┌───────┐
│ 1 │
│ int32 │
├───────┤
│ 1 │
└───────┘
D 问题解决.

ARMv8.0下duckdb的安装与编译过程-解决 Failed to allocate block of 2048 bytes的更多相关文章

  1. CentOS 7.0下使用yum安装MySQL

    CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的.为了解决这个问题,我们要先下载mysql的repo源. 1 ...

  2. MSW下wxWidgets的安装与编译

    教程摘自网上各大博客.贴吧.论坛,结合自己的实践做了一些实质性的修改. 一.安装 首先从http://sourceforge.net/projects/wxwindows/files/2.8.12/w ...

  3. centos7.2下caffe的安装及编译

    1.前期准备 安装依赖 sudo yum install protobuf-devel leveldb-devel snappy-devel opencv-devel boost-devel hdf5 ...

  4. Red Hat5下源码安装mysql5.6过程记录

    1.安装cmake包 [root@edu soft]# tar -xzf cmake-.tar.Z [root@edu soft]# cd cmake- [root@edu cmake-]# ./co ...

  5. caffe搭建--caffe在invidia+cpu 酷睿2Q9300 + ubuntu16.04.2上面的安装和编译过程

    本文原创,转载请注明出处. ------------------------------------------------分割线-------------------------------- 概要 ...

  6. Linux下源码安装redis,编译安装

    1.下载redis源码 [root@localhost opt]# wget http://download.redis.io/releases/redis-4.0.10.tar.gz 2.解压缩 [ ...

  7. Yii2.0 下使用 composer 安装七牛

    最近在捣鼓一个网站,要上传图片,于是选择了七牛.由于Yii2.0框架本身并不具有七牛用来上传图片的接口,只能自己动手给Yii2.0框架安装七牛了. 首先在根目录下的 composer.json 进行配 ...

  8. linux下boost的安装与编译

    1.从boost官网下载boost库包: 2.然后解压到linux下的任意一个文件夹, 3.进入boost_1_57文件夹下,不同的boost版本会解压城不同的库文件夹, 4.执行././bootst ...

  9. Centos7.0下MySQL的安装

    1.下载mysql的repo源 $ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm 2.安装mysql-comm ...

  10. linux 中gcc的·安装、编译过程

    一.安装gcc编译器 通过命令gcc -v查看当前的GCC版本 [root@localhost /]# gcc -v Reading specs from /usr/i386-glibc-2.1-li ...

随机推荐

  1. 用Linux搭建网站(LAMP)

    安装环境 演示服务器版本为CentOS 8 安装apache 下载apache yum install httpd httpd-devel 启动apache服务器 systemctl start ht ...

  2. Spring WebFlux 简介

    本文基于 Spring Boot 2.6.0 基于之前提到的 Reactor 的出现,使得编写响应式程序成为可能.为此,Spring 的开发团队决定添加有关 Reactor 模型的网络层.这样做的话将 ...

  3. Java NIO 简介

    NIO 简介 ​ 自 JDK 1.4 以来,引入了一个被称为 NIO(New IO) 的 IO 操作,是标准 IO 一个替代品.Java 的 NIO 提供了一种与传统意义上的 IO 不同的编程模型.有 ...

  4. Langchain-Chatchat项目:1.2-Baichuan2项目整体介绍

      由百川智能推出的新一代开源大语言模型,采用2.6万亿Tokens的高质量语料训练,在多个权威的中文.英文和多语言的通用.领域benchmark上取得同尺寸最佳的效果,发布包含有7B.13B的Bas ...

  5. 如何上传你的组件到npm

    前言 以react为例子 webpack作为打包工具 准备工作 安装node npm上注册账号 https://www.npmjs.com/ 创建要上传组件 新建项目 生成package.json文件 ...

  6. 懂分析、会预测,你见过这样的华为云DAS吗?

    摘要:数字化时代下,华为云数据管理服务DAS基于AI技术,于近期推出了智能SQL分析(包括慢SQL发现.SQL透视).workload级别索引推荐.存储空间预测等运维特性,加上原有的数据库运维能力,构 ...

  7. CodeArts TestPlan:一站式测试管理平台

    摘要:华为云正式发布CodeArts TestPlan,这是一款自主研发的一站式测试管理平台,沉淀了华为30多年高质量的软件测试工程方法与实践,覆盖测试计划.测试设计.测试执行和测试评估等全流程. 本 ...

  8. 没想到,学棋五年的我竟然输给了昇腾CANN!

    摘要:整整两天,上百场对弈,TA竟然未尝一败,真是让人拍案叫绝. 近日,一位神秘"人物"亮相华为昇腾CANN技术开放日现场,引得众人簇拥,吸粉无数.从现场AI棋艺大战的画面中我们可 ...

  9. 讲透学烂二叉树(五):分支平衡—AVL树与红黑树伸展树自平衡

    简叙二叉树 二叉树的最大优点的就是查找效率高,在二叉排序树中查找一个结点的平均时间复杂度是O(log₂N): 在<讲透学烂二叉树(二):树与二叉/搜索/平衡等树的概念与特征>提到 二叉排序 ...

  10. IOS上架流程详解,包含审核避坑指南!

    ​ 准备 开发者账号 完工的项目 上架步骤 一.创建App ID 二.创建证书请求文件 (CSR文件) 三.创建发布证书 (CER) 四.创建Provisioning Profiles配置文件 (PP ...