登录
首页 >  Golang >  Go问答

构建 CockroachDB 在 RPi 时出现“段错误”情况

来源:stackoverflow

时间:2024-03-07 08:45:26 148浏览 收藏

一分耕耘,一分收获!既然都打开这篇《构建 CockroachDB 在 RPi 时出现“段错误”情况》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

问题内容

我正在尝试从 rpi 3 上的源代码构建 cockroachdb,遵循几篇文章(这个和这个)。

我的树莓派设置: 操作系统:2018-06-27-raspbian-stretch cpu:armv7 修订版 4(v71) 内存:1g + 交换:1.5g go版本:go1.11 linux/arm

我在“制作”时修复了一些有关第三方库的错误,但现在我陷入了困境:

pi@raspberrypi:~/work/go/src/github.com/cockroachdb/cockroach $ make build TAGS='stdmalloc' -j2
GOPATH set to /home/pi/work/go
go build -o cockroach -v  -tags 'stdmalloc make arm_linux_gnueabihf_stdmalloc' -ldflags '-X github.com/cockroachdb/cockroach/pkg/build.typ=development -extldflags "" -X "github.com/cockroachdb/cockroach/pkg/build.tag=v2.2.0-alpha.00000000-668-gf76d921f42-dirty" -X "github.com/cockroachdb/cockroach/pkg/build.rev=f76d921f4262356fde83312d0f471262d995f1e0" -X "github.com/cockroachdb/cockroach/pkg/build.cgoTargetTriple=arm-linux-gnueabihf"   -X "github.com/cockroachdb/cockroach/pkg/build.utcTime=2018/09/11 12:47:32"' ./pkg/cmd/cockroach
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x0 pc=0x2372b8]

goroutine 1 [running]:
runtime/internal/atomic.goLoad64(0x3d65bdc, 0x0, 0x5607a20)
/usr/local/go/src/runtime/internal/atomic/atomic_arm.go:124 +0x1c
github.com/cockroachdb/cockroach/pkg/util/humanizeutil.(*BytesValue).String(0x55fb578, 0x5607a01, 0x56d9ea0)
/home/pi/work/go/src/github.com/cockroachdb/cockroach/pkg/util/humanizeutil/humanize.go:109 +0x28
github.com/cockroachdb/cockroach/pkg/cli.(*bytesOrPercentageValue).String(0x57b4920, 0x56d9ea0, 0x7)
/home/pi/work/go/src/github.com/cockroachdb/cockroach/pkg/cli/flags_util.go:492 +0x20
github.com/cockroachdb/cockroach/vendor/github.com/spf13/pflag.(*FlagSet).VarPF(0x54d3a00, 0x25cf778, 0x57b4920, 0x1ef3864, 0xe, 0x0, 0x0, 0x56d2900, 0x169, 0x56d9ea0)
/home/pi/work/go/src/github.com/cockroachdb/cockroach/vendor/github.com/spf13/pflag/flag.go:778 +0x24
github.com/cockroachdb/cockroach/vendor/github.com/spf13/pflag.(*FlagSet).VarP(0x54d3a00, 0x25cf778, 0x57b4920, 0x1ef3864, 0xe, 0x0, 0x0, 0x56d2900, 0x169)
/home/pi/work/go/src/github.com/cockroachdb/cockroach/vendor/github.com/spf13/pflag/flag.go:786 +0x5c
github.com/cockroachdb/cockroach/pkg/cli.VarFlag(0x54d3a00, 0x25cf778, 0x57b4920, 0x1ef3864, 0xe, 0x0, 0x0, 0x0, 0x0, 0x1fa4462, ...)
/home/pi/work/go/src/github.com/cockroachdb/cockroach/pkg/cli/flags.go:129 +0x6c
github.com/cockroachdb/cockroach/pkg/cli.init.5()
/home/pi/work/go/src/github.com/cockroachdb/cockroach/pkg/cli/flags.go:324 +0x6c0
Makefile:1288: recipe for target 'docs/generated/settings/settings.html' failed
make: *** [docs/generated/settings/settings.html] Error 2
make: *** Deleting file 'docs/generated/settings/settings.html'

有什么想法可能是错误的吗?


解决方案


谢谢你的提问。我是该博客文章的原作者。看起来您遇到了与 https://github.com/golang/go/issues/9959 相关的问题。看起来 golang 在原子访问时需要 64 位字的 64 位对齐。在整个项目中执行这一点有些棘手。不过,我们可以尝试通过删除 pkg/util/ humanizeutil/ humanize.go:109 (看起来没有必要)上的原子访问并将其替换为 return IBytes(*b.val) 来实现此功能。这至少应该能让你克服这个障碍。不过,在此之后您可能会遇到其他问题。不幸的是,CockroachDB 从未围绕 32 位 ARMv7 构建建立 CI,因为该项目从未正式支持 32 位架构。

但是,64 位 ARMv8 版本的维护更加积极。事实上,我们已经引入了完整的交叉编译工具链来在 x86_64 主机上构建适用于 ARMv8 的 CockroachDB。可以通过运行 build/builder.sh mkrelease arm64-linux-gnueabi 来启动使用此工具链的编译。生成的二进制文件可以放到运行 64 位操作系统(如 https://wiki.debian.org/RaspberryPi3)的 RaspberryPi 上。实际上我上周尝试过这一点,没有遇到任何问题。

以上就是《构建 CockroachDB 在 RPi 时出现“段错误”情况》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>