arm-linux-gcc交叉编译容器 centos7 环境

简介: arm-linux-gcc交叉编译容器 centos7 环境

直接使用 arm-linux-gcc交叉编译容器 centos7 环境

docker run -tdi -p 50000:22 --name armlinuxgcc --privileged=true  registry.cn-hangzhou.aliyuncs.com/mkmk/centos:armlinuxgcc init 
进入容器后输入 
arm-linux-gcc -v
如果找不到命令。先输入
source /etc/profile
 再次输入 版本查看
 arm-linux-gcc -v
Using built-in specs.
Target: arm-none-linux-gnueabi
Configured with: /opt/FriendlyARM/mini2440/build-toolschain/working/src/gcc-4.4.3/configure --build=i386-build_redhat-linux-gnu --host=i386-build_redhat-linux-gnu --target=arm-none-linux-gnueabi --prefix=/opt/FriendlyARM/toolschain/4.4.3 --with-sysroot=/opt/FriendlyARM/toolschain/4.4.3/arm-none-linux-gnueabi//sys-root --enable-languages=c,c++ --disable-multilib --with-arch=armv4t --with-cpu=arm920t --with-tune=arm920t --with-float=soft --with-pkgversion=ctng-1.6.1 --disable-sjlj-exceptions --enable-__cxa_atexit --with-gmp=/opt/FriendlyARM/toolschain/4.4.3 --with-mpfr=/opt/FriendlyARM/toolschain/4.4.3 --with-ppl=/opt/FriendlyARM/toolschain/4.4.3 --with-cloog=/opt/FriendlyARM/toolschain/4.4.3 --with-mpc=/opt/FriendlyARM/toolschain/4.4.3 --with-local-prefix=/opt/FriendlyARM/toolschain/4.4.3/arm-none-linux-gnueabi//sys-root --disable-nls --enable-threads=posix --enable-symvers=gnu --enable-c99 --enable-long-long --enable-target-optspace
Thread model: posix
gcc version 4.4.3 (ctng-1.6.1)

这就是交叉编译器的创建过程

请自行百度 arm-linux-gcc 的使用,来进一步学习如何编译

如果你不关心容器的构建过程,下边的都不用看了。

arm-linux-gcc-4.4.3 下载路径

http://112.124.9.243/arm9net/mini2440/linux/arm-linux-gcc-4.4.3-20100728.tar.gz

构建交叉编译容器

创建空白centos7

docker run -tdi -p 50000:22 --name armlinuxgcc --privileged=true  registry.cn-hangzhou.aliyuncs.com/mkmk/centos:ssh init 

上传压缩包到 /home目录

解压

cd /home
tar -zxvf arm-linux-gcc-4.4.3-20100728.tar.gz
cp -r /home/opt/FriendlyARM/toolschain/4.4.3  /usr/local/arm

配置环境变量

vi /etc/profile
末尾添加
export PATH=$PATH:/usr/local/arm/bin
source /etc/profile
使用
arm-linux-gcc  -v
-linux-gnueabi-gcc: /lib/ld-linux.so.2: bad ELF interpreter: No such file or directory

报错

ia32-libs is missing for x86_64 platform.

缺乏 32 兼容环境

yum install epel-release
yum install glibc.i686

查看版本

arm-linux-gcc -v
Using built-in specs.
Target: arm-none-linux-gnueabi
Configured with: /opt/FriendlyARM/mini2440/build-toolschain/working/src/gcc-4.4.3/configure --build=i386-build_redhat-linux-gnu --host=i386-build_redhat-linux-gnu --target=arm-none-linux-gnueabi --prefix=/opt/FriendlyARM/toolschain/4.4.3 --with-sysroot=/opt/FriendlyARM/toolschain/4.4.3/arm-none-linux-gnueabi//sys-root --enable-languages=c,c++ --disable-multilib --with-arch=armv4t --with-cpu=arm920t --with-tune=arm920t --with-float=soft --with-pkgversion=ctng-1.6.1 --disable-sjlj-exceptions --enable-__cxa_atexit --with-gmp=/opt/FriendlyARM/toolschain/4.4.3 --with-mpfr=/opt/FriendlyARM/toolschain/4.4.3 --with-ppl=/opt/FriendlyARM/toolschain/4.4.3 --with-cloog=/opt/FriendlyARM/toolschain/4.4.3 --with-mpc=/opt/FriendlyARM/toolschain/4.4.3 --with-local-prefix=/opt/FriendlyARM/toolschain/4.4.3/arm-none-linux-gnueabi//sys-root --disable-nls --enable-threads=posix --enable-symvers=gnu --enable-c99 --enable-long-long --enable-target-optspace
Thread model: posix
gcc version 4.4.3 (ctng-1.6.1) 

简单使用

我们在/home 下新建简单代码文件

#include"stdio.h"
int main(){
printf("hello arm\n");
}

先编译生成 x86 的执行问文件

gcc helloArm.c -o hellox86
执行查看效果
./hellox86 
hello arm
arm-linux-gcc helloArm.c -o helloarm
报错  找不到 libstdc++.so.6
 yum whatprovides libstdc++.so.6
 libstdc++-4.8.5-39.el7.i686 : GNU Standard C++ Library
安装依赖
yum install libstdc++-4.8.5-39.el7.i686
arm-linux-gcc helloArm.c -o helloarm
执行
 ./helloarm 
-bash: ./helloarm: cannot execute binary file

使用arm容器

配置qemu 依赖

https://blog.csdn.net/xiang_freedom/article/details/92724299


下载上传

https://github.com/multiarch/qemu-user-static/releases

/usr/bin/qemu-aarch64-static

/usr/bin/qemu-arm-static

到宿主机的/usr/bin 目录下

chmod 777 /usr/bin/qemu-aarch64-static
chmod 777 /usr/bin/qemu-arm-static


拖取arm 容器

指定 docker 参数

docker run --rm --privileged multiarch/qemu-user-static:register
docker run -it -v /usr/bin/qemu-aarch64-static:/usr/bin/qemu-aarch64-static  -p 51000:22 --name arm64   arm64v8/ubuntu 
docker run -it -v /usr/bin/qemu-arm-static:/usr/bin/qemu-arm-static  -p 51000:22 --name arm32   arm32v7/ubuntu 

把我们之前的编译的文件放到这里 /home

直接运行 
/home/helloarm
./helloarm: No such file or directory
这里并不是说找不到可执行文件,而是找不到
执行文件中的依赖
回到宿主机
宿主机执行  readelf -a helloarm 
 [Requesting program interpreter: /lib/ld-linux.so.3]


目标安装依赖

把目标机缺少的 /lib 安装一下就好了

把宿主机 /usr/local/arm/arm-none-linux-gnueabi/lib

内容拷贝到 目标机 /lib

宿主机

cd /usr/local/arm/arm-none-linux-gnueabi/lib
tar -cvf lib2.tar *

目标机

cd lib
tar -xvf lib2.tar

arm64 换源

deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-security main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-updates main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-backports main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-security main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-updates main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ xenial-backports main multiverse restricted universe

成功在目标机执行arm代码

配置目标机

把宿主机 /usr/local/arm/arm-none-linux-gnueabi/lib

内容拷贝到 目标机 /lib

宿主机

cd /usr/local/arm/arm-none-linux-gnueabi/lib
tar -cvf lib2.tar *

目标机

cd lib
tar -xvf lib2.tar


配置好的目标机镜像

registry.cn-hangzhou.aliyuncs.com/mkmk/ubuntu:arm32

docker run -it -v /usr/bin/qemu-arm-static:/usr/bin/qemu-arm-static   --name arm32   registry.cn-hangzhou.aliyuncs.com/mkmk/ubuntu:arm32 


进入目标机后执行

/lib/helloarm
输出 :hello arm


相关文章
|
5月前
|
Kubernetes 供应链 安全
云原生环境下的容器安全与最佳实践
云原生时代,容器与 Kubernetes 成为企业应用核心基础设施,但安全挑战日益突出。本文探讨容器安全现状与对策,涵盖镜像安全、运行时防护、编排系统风险及供应链安全,提出最小权限、漏洞扫描、网络控制等最佳实践,并结合阿里云 ACK、ACR 等服务提供全链路解决方案,展望零信任、AI 安全与 DevSecOps 融合趋势。
247 5
|
4月前
|
Linux 网络安全 Docker
盘古栈云,创建带ssh服务的linux容器
创建带ssh服务的linux容器
366 146
|
6月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
452 16
|
7月前
|
Linux 编译器 开发工具
在CentOS环境下升级GCC编译器的指南
总结:本文提供了一种方法来升级CentOS的GCC编译器,通过使用CentOS的软件集合和开发者工具集工具,可以比较平滑地进行升级。在整个过程中无需从源代码编译,这样既省去了复杂的编译过程,也避免了可能出现的与系统库不兼容的风险。请注意,使用第三方仓库可能会带来系统稳定性和安全性上的潜在影响。所有操作都应谨慎进行,并确保有相应的数据备份。
974 19
|
7月前
|
存储 缓存 Serverless
【Azure Container App】如何在Consumption类型的容器应用环境中缓存Docker镜像
在 Azure 容器应用的 Consumption 模式下,容器每次启动均需重新拉取镜像,导致冷启动延迟。本文分析该机制,并提出优化方案:使用 ACR 区域复制加速镜像拉取、优化镜像体积、设置最小副本数减少冷启动频率,或切换至 Dedicated 模式实现镜像缓存,以提升容器启动效率和应用响应速度。
221 0
|
10月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
1077 25
|
11月前
|
存储 IDE Linux
零基础保姆级教程!手把手教你免费玩转Linux CentOS安装+学习环境搭建(附避坑指南)
本文详细介绍了在VMware虚拟机中安装CentOS 6.8的全过程。首先,需确保已安装VMware并开启V-CPU虚拟化功能,可通过BIOS设置或使用LeoMoon CPU-V工具检测。接着,下载CentOS镜像文件,并在VMware中新建虚拟机,配置CPU、内存、硬盘等参数。最后,加载ISO镜像启动虚拟机,按照提示完成CentOS的安装,包括语言、键盘、存储方式、地区、密码设置及硬盘分区等步骤。安装完成后,以root用户登录即可进入系统桌面,开始学习Linux命令和操作。
1132 12
零基础保姆级教程!手把手教你免费玩转Linux CentOS安装+学习环境搭建(附避坑指南)
|
8月前
|
Oracle 关系型数据库 Linux
MyEMS开源系统安装之CentOS/RHEL/Rocky/AlmaLinux/Oracle Linux
本指南介绍如何在CentOS/RHEL/Rocky/AlmaLinux/Oracle Linux服务器上部署MyEMS开源能源管理系统。内容涵盖系统准备、数据库配置、多个MyEMS服务(如myems-api、myems-admin、myems-modbus-tcp等)的安装与配置,以及Nginx服务器设置和防火墙规则调整。通过完成所有步骤,您将能够访问MyEMS Admin UI和Web UI,默认端口分别为8001和80,初始登录凭据已提供。
511 0

热门文章

最新文章