news 2026/6/24 4:55:31

rock image (by quqi99)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
rock image (by quqi99)

作者:张华 发表于:2025-12-30
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明

docker image

cat << EOF |tee app.py from flask import Flask import os app = Flask(__name__) @app.route('/') def hello(): greeting = os.environ.get("GREETING", "Hello") return f"{greeting} from the container!" if __name__ == '__main__': app.run(host='0.0.0.0', port=8080) EOF cat << EOF |tee Dockerfile FROM ubuntu:24.04 RUN apt update \ && apt install --yes --no-install-recommends python3 python3-pip \ && rm -rf /var/lib/apt/lists/* WORKDIR /app COPY requirements.txt . COPY app.py . RUN pip3 install -r requirements.txt --root / ENV GREETING="Hello Docker" ENV PORT=8080 EXPOSE \$PORT CMD ["python3", "app.py"] EOF cat << EOF |tee requirements.txt Flask==3.1.2 EOF sudo apt install docker.io -y sudo docker build -t hello:v1 . sudo docker run -d -p 8080:8080 --name hello hello:v1

rock image

rock image将使用Pebble来代替docker image中的CMD/ENTRYPOINT来定义services.
rock image并不是以传统 Docker image的形式存储在本地 registry 里,而是:在构建过程中,rockcraft 会使用 skopeo 从远程仓库(如 public.ecr.aws/ubuntu/ubuntu:24.04)拉取 base 镜像;然后将其转换为 OCI 格式,并临时存放在 /root/images/ 目录下(注意:这是在 rockcraft 启动的 lxc容器内部,不是你主机的 /root!);最终生成的是一个.rock 文件(类似 .snap),它是一个 squashfs 或tar压缩包,包含整个 rootfs 和元数据。

cat << EOF |tee rockcraft.yaml name: hello-rock base: ubuntu@24.04 version: "0.1" summary: hello rock description: | This is a hello rock image platforms: amd64: environment: GREETING: "Hello Rock" PORT: "8080" services: app: override: replace command: python3 usr/bin/app.py startup: enabled checks: app-check: override: replace http: url: http://localhost:8080/ parts: app: plugin: nil source: . build-packages: - python3 - python3-venv - python3-pip stage-packages: - python3 override-build: | pip install -r requirements.txt --root \${CRAFT_PART_INSTALL} install -D -m 755 app.py \${CRAFT_PART_INSTALL}/usr/bin/app.py EOF sudo snap install rockcraft --classic #rockcraft clean lxc delete --project rockcraft rockcraft-hello-rock-amd64-8520382 --force #NOTE: the domain 'cloudfront.net' has been blocked rockcraft pack ls hello-rock_0.1_amd64.rock lxc list --project rockcraft lxc exec --project rockcraft rockcraft-hello-rock-amd64-8520382 -- bash curl -v https://public.ecr.aws/v2/ curl -v https://d5l0dvt14r5h8.cloudfront.net/v2/ #/snap/rockcraft/current/bin/skopeo --insecure-policy --override-arch amd64 copy --retry-times 5 docker://public.ecr.aws/ubuntu/ubuntu:24.04 oci:/root/images/ubuntu:24.04 #/snap/rockcraft/current/bin/skopeo --insecure-policy copy docker://public.ecr.aws/ubuntu/ubuntu:24.04 oci:/tmp/test-ubuntu:24.04 $ lxc list --project rockcraft |grep -i container | base-instance-rockcraft-buildd-base-v71--8246325508671f1569c1 | STOPPED | | | CONTAINER | 0 | | rockcraft-hello-rock-amd64-8520382 | STOPPED | | | CONTAINER | 0 |

在docker里测试rock image:

#tar archive can be read by skopeo $ file hello-rock_0.1_amd64.rock hello-rock_0.1_amd64.rock: POSIX tar archive sudo apt install skopeo -y sudo skopeo copy oci-archive:hello-rock_0.1_amd64.rock docker-daemon:hello-rock:0.1 sudo docker run -it --rm hello-rock:0.1 curl -v http://localhost:8080 #debug it sudo docker ps |grep rock sudo docker exec frosty_wright /usr/bin/pebble logs app sudo docker run -d -p 8080:8080 -it --rm hello-rock:0.1 curl http://localhost:8080

debug it

$ sudo docker ps |grep rock 6b09134e6413 hello-rock:0.1 "/usr/bin/pebble ent…" 3 minutes ago Up 3 minutes pensive_wozniak $ sudo docker exec -it frosty_wright ps aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 0.0 0.0 1233912 11520 pts/0 Ssl+ 07:29 0:00 /usr/bin/pebble enter root 16 1.1 0.2 115816 34860 pts/0 S 07:29 0:00 python3 usr/bin/app.py root 22 50.0 0.0 7888 3840 pts/1 Rs+ 07:30 0:00 ps aux #run it in the front-end without '-d' sudo docker run -p 8080:8080 -it --rm --entrypoint /bin/sh hello-rock:0.1 # python3 /usr/bin/app.py ... * Running on http://127.0.0.1:8080 Press CTRL+C to quit
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 8:31:38

GitHub Actions矩阵测试不同Miniconda环境

GitHub Actions矩阵测试不同Miniconda环境 在现代Python项目开发中&#xff0c;尤其是涉及数据科学、机器学习或跨平台部署的场景下&#xff0c;一个常见的痛点是&#xff1a;“代码在我本地能跑&#xff0c;为什么CI失败了&#xff1f;” 更进一步的问题则是&#xff1a;即便…

作者头像 李华
网站建设 2026/6/23 8:09:50

SSH连接Miniconda容器执行批量Python任务

SSH连接Miniconda容器执行批量Python任务 在现代数据科学和AI工程实践中&#xff0c;一个常见的痛点是&#xff1a;如何在远程服务器或云主机上稳定、安全地运行多个Python项目&#xff0c;而这些项目往往依赖不同版本的库甚至不同的Python解释器。更复杂的是&#xff0c;团队…

作者头像 李华
网站建设 2026/6/20 10:47:25

【万字长文】小白要怎么学习Transfomer?

简介 本文从非AI专业人士视角&#xff0c;系统讲解了Transformer模型的前传知识。文章首先介绍处理序列数据的基本问题&#xff0c;然后详细阐述了分词(Tokenization)和词嵌入(Word Embedding)的概念与方法&#xff0c;分析了RNN在处理序列数据时的局限性&#xff0c;最后解释…

作者头像 李华
网站建设 2026/6/21 12:18:28

Jupyter Lab预加载PyTorch库:Miniconda-Python3.9提升交互式编程效率

Jupyter Lab预加载PyTorch库&#xff1a;Miniconda-Python3.9提升交互式编程效率 在深度学习项目开发中&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是环境配置——“为什么我的代码在同事机器上跑不通&#xff1f;”、“CUDA版本不匹配怎么办&#xff1f;”、…

作者头像 李华
网站建设 2026/6/21 18:24:53

小白也能懂的PyTorch安装指南:基于Miniconda-Python3.9图形化操作

小白也能懂的PyTorch安装指南&#xff1a;基于Miniconda-Python3.9图形化操作 在人工智能项目开发中&#xff0c;最让人头疼的往往不是写模型代码&#xff0c;而是环境装不上、依赖报错、GPU识别不了——明明复制了别人的命令&#xff0c;却总卡在“ImportError”或“CUDA not…

作者头像 李华
网站建设 2026/6/20 13:44:44

一文讲清SRC漏洞挖掘—CNVD国家信息安全漏洞共享平台是如何提交漏洞的

目录 文章目录00 简介01 过程中使用的工具02 详细过程一、 寻找挖洞目标1.1 工具介绍1.2 目标检索过程二、 趁手的挖洞工具2.1 工具介绍2.2 工具下载链接2.3 工具使用三、挖洞时间四、漏洞验证五、提交漏洞03 注意事项00 简介 SRC漏洞平台&#xff1a;安全应急响应中心&#x…

作者头像 李华