利用hashicorp packer把dbcolinux导出为虚拟机和docker格式(2)

简介: 本文关键字:Cross-compile 64-bit kernel on 32-bit machine

本文关键字:Cross-compile 64-bit kernel on 32-bit machine

在《将tinycolinux以硬盘模式安装到云主机》和《在tinycolinux32上装tinycolinux64 kernel和toolchain》2篇文章中我们手动构建了32到64的tinycolinux的基础部分,而且用的是非cross compile,即直接在一台ubt64上产生这个kernel,再后来,针对文章1 —— 以硬盘方式安装iso到主机,我们利用虚拟机devops的构建工具packer自动构建了基本的tinycorelinux pe,现在我们继续文章2,利用devops packer自动构建直接从32位编译出64位的kernel。

这就需要用到cross compile。废话不说,直接上源码。这些源码可直接附在《基于虚拟机的devops套件及把dbcolinux导出为虚拟机和docker格式》文章所提到的源码的适当部分,然后以相同的方式构建,结果会产生一个可用的64 kernel+64 toolchain的dbcolinux:

新加的script1部分

注意这里的不同,root=/dev/hda1

#HD INSTALL
cd /mnt/hda1/
gunzip -c /mnt/hda1/boot/microcore.gz > /tmp/microcore.cpio
cpio -idmv < /tmp/microcore.cpio
echo menuentry \\"dbcolinux hd\\" { >> /mnt/hda1/boot/grub/grub.cfg
echo  linux /boot/bzImage com1=9600,8n1 loglevel=3 user=tc console=ttyS0 console=tty0 noembed nomodeset root=/dev/hda1 tce=hda1 opt=hda1 home=hda1 restore=hda1 >> /mnt/hda1/boot/grub/grub.cfg
echo } >> /mnt/hda1/boot/grub/grub.cfg
rm /tmp/microcore.cpio

packer脚本部分

将这些放进provisioners中的适当部分。注意下面的_comments会引起错误,这里只是为了说明,使用时得去掉。

{
        "type": "shell",
        "pause_before":"1s",
    "_comment": “以下安装32位gcc443的官方tczs,因为grep,gcc_libs在scripts1中安装过了,所以这里不必另外安装,另外,scripts1生成的tmp得改一下权限才能在下一步上传文件”,
        "inline":
        [
        "tce-load -iw gcc.tcz",
        "tce-load -iw binutils.tcz",
        "tce-load -iw bison.tcz",
        "tce-load -iw diffutils.tcz",
        "tce-load -iw file.tcz",
        "tce-load -iw findutils.tcz",
        "tce-load -iw flex.tcz",
        "tce-load -iw gawk.tcz",
        "tce-load -iw m4.tcz",
        "tce-load -iw make.tcz",
        "tce-load -iw patch.tcz",
        "tce-load -iw pkg-config.tcz",
        "tce-load -iw sed.tcz",
        "tce-load -iw base-dev.tcz",
        "tce-load -iw linux-headers-2.6.33.3-tinycore.tcz",

        "tce-load -iw perl5.tcz",
        "tce-load -iw ncurses.tcz",
        "tce-load -iw ncurses-dev.tcz",

        "sudo sh -c 'chown tc:staff /mnt/hda1/tmp/'"

        ]
    },

    {
    "_comment": “这里开始上传编译所需的源码文件”,
      "type": "file",
      "source": "pkgs/3.x/src/64kernelandtoolchain",
      "destination": "/mnt/hda1/tmp"
    },

    {
    "_comment": “由于这里用了sudo,在scripts,2,3中所有命令默认都是经过了sudo的”,
        "type": "shell",
        "pause_before":"1s",
        "execute_command": "echo '' | sudo -S sh -c '{{ .Vars }} {{ .Path }}'",
        "scripts":
        [
        "./scripts/2.compile64toolchain.sh",
        "./scripts/3.compile64kernel.sh"
        ]
        }

compile64toolchain and compile 64 kernel

将这些放进scripts/2.compile64toolchain.sh文件中,不要轻易动这里的东西,否则格式不对产生的tls.h不能发现错误很诡异。

export PATH=$PATH:/usr/local/sbin:/usr/local/bin

#我们现在是在32位上创建for 64的交叉,从64到32不叫交叉,反之要交叉
#三元组,machtype在在正常的linux32上会输出i686-pc-linux-gnu字样,tinycorelinux上是空。但是不产生问题
export BUILD=$MACHTYPE
export HOST=x86_64-pc-linux-gnu
export TARGET=x86_64-pc-linux-gnu

#我们全程不必用sudo,因为packer文件中exe command写好了
cd /mnt/hda1/tmp/64kernelandtoolchain/
tar jxvf linux-2.6.33.3-patched.tar.bz2
tar zxvf binutils-2.20.tar.gz
tar zxvf glibc-2.12.1.tar.gz
tar zxvf mpfr-2.4.2.tar.gz
tar zxvf gmp-4.3.2.tar.gz
tar jxvf gcc-4.4.3.tar.bz2
mv gmp-4.3.2 gcc-4.4.3/gmp
mv mpfr-2.4.2 gcc-4.4.3/mpfr

cd linux-2.6.33.3 
make headers_install ARCH=x86_64 INSTALL_HDR_PATH=/mnt/hda1/usr/local/gcccross/$TARGET

cd ../binutils-2.20 && mkdir b && cd b
../configure -prefix=/mnt/hda1/usr/local/gcccross -target=$TARGET -disable-multilib
make
make install

#编译器执行文件
cd ../../gcc-4.4.3 && mkdir b && cd b
../configure -prefix=/mnt/hda1/usr/local/gcccross -target=$TARGET -enable-languages=c,c++ -disable-multilib
make all-gcc
make install-gcc

export PATH=$PATH:/mnt/hda1/usr/local/gcccross/bin

#标准C库头文件和一些必要启动文件
cd ../../glibc-2.12.1 && mkdir b && cd b
#在glibc眼里,这里的build和host一个意思,与标准的其它三元组意义不同
../configure -prefix=/mnt/hda1/usr/local/gcccross/$TARGET -build=$MACHTYPE -host=$HOST -target=$TARGET -with-headers=/mnt/hda1/usr/local/gcccross/$TARGET/include -disable-multilib libc_cv_forced_unwind=yes libc_cv_c_cleanup=yes
make install-bootstrap-headers=yes install-headers
make csu/subdir_lib
install csu/crt1.o csu/crti.o csu/crtn.o /mnt/hda1/usr/local/gcccross/$TARGET/lib
#利用新编的64gcc处理
x86_64-pc-linux-gnu-gcc -nostdlib -nostartfiles -shared -x c /dev/null -o /mnt/hda1/usr/local/gcccross/$TARGET/lib/libc.so
touch /mnt/hda1/usr/local/gcccross/$TARGET/include/gnu/stubs.h

#编译器本身的库文件
cd ../../gcc-4.4.3/b/
make all-target-libgcc
make install-target-libgcc

#标准C库
cd ../../glibc-2.12.1/b/
make
make install

#标准C++库
cd ../../gcc-4.4.3/b/
make
make install

将这些放进scripts/3.compile64kernel.sh文件中

export PATH=$PATH:/mnt/hda1/usr/local/gcccross/bin

#使用刚编译出来的gcccross,记得末尾的-
export ARCH=x86_64
export CROSS_COMPILE=x86_64-pc-linux-gnu-

cd /mnt/hda1/tmp/64kernelandtoolchain/
# 这里奇怪之处:1,不作把/usr/local/ncurses*相关的库移到/usr/下会大量符号undefined,2,在guest os中测试时如果不用sudo,依然会提示无法找到ncurses相关库,3,sudo make clean没用,一定要sudo make mrproper。4,在virtual box play make menuconfig那行时会一直闪烁,在guestos中测试是正常的,5.所以我们用了make defconfig的方法,但这里还是保留menuconfig相关的脚本
cd linux-2.6.33.3
cp -R /tmp/tcloop/ncurses-dev/usr/local/include/*.* /usr/include/
cp -R /tmp/tcloop/ncurses-dev/usr/local/lib/lib*.a /usr/lib/
cp -R /tmp/tcloop/ncurses/usr/local/lib/*.* /usr/lib/
#直接放文件可能需要重启才能被引用生效,所以这里ldconfig一下
ldconfig
export TERMINFO=/usr/share/terminfo
export TERM=linux
make mrproper
cp -f ../config-2.6.33.3-tinycore64 arch/x86/configs/x86_64_defconfig
make x86_64_defconfig
make bzImage


cp -f arch/x86/boot/bzImage /mnt/hda1/boot/bzImage64
echo menuentry \\"dbcolinux 64\\" { >> /mnt/hda1/boot/grub/grub.cfg
echo  linux /boot/bzImage64 com1=9600,8n1 loglevel=3 user=tc console=ttyS0 console=tty0 noembed nomodeset root=/dev/hda1 tce=hda1 opt=hda1 home=hda1 restore=hda1 >> /mnt/hda1/boot/grub/grub.cfg
echo } >> /mnt/hda1/boot/grub/grub.cfg

rm -rf /mnt/hda1/tmp/64kernelandtoolchain/

#这是一条触发ask的错误语句,放在你猜想可能出现错误作为中断点的地方,但是它还会继续
Dsfasdfdf

好了,scripts3文件结束,产生的镜像文件可能很大。需要针对处理一下。

————

关注我


(此处不设回复,扫码到微信参与留言,或直接点击到原文)

qrcode.png

相关文章
|
21天前
|
网络安全 虚拟化 Docker
SSH后判断当前服务器是云主机、物理机、虚拟机、docker环境
结合上述方法,您可以对当前环境进行较为准确的判断。重要的是理解每种环境的特征,并通过系统的响应进行综合分析。如果在Docker容器内,通常会有明显的环境标志和受限的资源视图;而在云主机或虚拟机上,虽然它们也可能是虚拟化的,但通常提供更接近物理机的体验,且可通过硬件标识来识别虚拟化平台。物理机则直接反映硬件真实信息,较少有虚拟化痕迹。通过这些线索,您应该能够定位到您所处的环境类型。
17 2
|
27天前
|
Docker 容器
docker的导入本地镜像和导出本地镜像
本文介绍了如何使用Docker对本地镜像进行导入和导出操作,包括从本地导入`nginx.tar`镜像以及将`open-webui`镜像导出并压缩为`open-webui.tar.gz`。
60 1
|
1月前
|
搜索推荐 应用服务中间件 nginx
docker与containerd镜像获取及导出导入的区别与注意事项(报错信息:ctr: content digest sha256........ac47: not found)
docker与containerd镜像获取及导出导入的区别与注意事项(报错信息:ctr: content digest sha256........ac47: not found)
|
1月前
|
存储 Linux 开发者
虚拟机centos7.9一键部署docker
本文介绍了如何在 CentOS 7.9 虚拟机上安装 Docker 社区版 (Docker-ce-20.10.20)。通过使用阿里云镜像源,利用 `wget` 下载并配置 Docker-ce 的 YUM 仓库文件,然后通过 `yum` 命令完成安装。安装后,通过 `systemctl` 设置 Docker 开机自启并启动 Docker 服务。最后,使用 `docker version` 验证安装成功,并展示了客户端与服务器的版本信息。文中还提供了列出所有可用 Docker-ce 版本的命令。
127 0
虚拟机centos7.9一键部署docker
|
29天前
|
Docker 容器
docker可以通过镜像id导出镜像吗?
docker可以通过镜像id导出镜像吗?
25 0
|
3月前
|
测试技术 持续交付 云计算
Docker 相对于虚拟机的优势
【8月更文挑战第27天】
74 5
|
3月前
|
安全 持续交付 虚拟化
在Docker中,Docker和虚拟机有什么不同?
在Docker中,Docker和虚拟机有什么不同?
|
3月前
|
应用服务中间件 Linux nginx
Linux虚拟机磁盘扩容、Docker容器磁盘满的问题、Docker安装nginx
这篇文章讨论了Linux虚拟机磁盘扩容的方法,包括外部配置、具体扩容步骤和扩容后的效果验证。同时,文章还涉及了Docker容器磁盘满的问题及其解决方法,如删除不必要的镜像和容器,以及调整Docker的安装路径。此外,还提到了意外情况的处理,例如误删除停止的容器后的应对措施。最后,文章还提供了使用Docker安装nginx的步骤和成功访问的截图。
Linux虚拟机磁盘扩容、Docker容器磁盘满的问题、Docker安装nginx
|
3月前
|
存储 API 开发工具
【Azure 环境】在Azure虚拟机(经典) 的资源中,使用SDK导出VM列表的办法
【Azure 环境】在Azure虚拟机(经典) 的资源中,使用SDK导出VM列表的办法
|
14天前
|
存储 Docker 容器
docker中挂载数据卷到容器
【10月更文挑战第12天】
41 5