0

0

Docker与虚拟机_在麒麟OS上搭建开发与测试环境

P粉602998670

P粉602998670

发布时间:2026-02-05 13:40:00

|

326人浏览过

|

来源于php中文网

原创

Docker轻量高效适合开发,KVM全虚拟化适配测试,二者可混合构建分层环境,并需通过SELinux、LUKS加密及kysec校验强化安全。

docker与虚拟机_在麒麟os上搭建开发与测试环境

如果您希望在麒麟OS上构建隔离、可复现的开发与测试环境,Docker容器与虚拟机是两种主流技术路径。二者在资源占用、启动速度、隔离强度和兼容性方面存在显著差异。以下是针对麒麟OS平台的具体实施方式:

一、使用Docker部署轻量级开发环境

Docker基于Linux内核的命名空间(Namespaces)与控制组(cgroups)实现进程级隔离,无需模拟完整硬件,启动快、资源开销低,适合快速拉起标准化开发环境。

1、确认麒麟OS内核版本不低于4.18,并已启用cgroup v2支持;执行uname -rcat /proc/cgroups验证。

2、安装Docker CE官方仓库源:下载适配麒麟V10/SP1的docker-ce-rootless-extrasdocker-ce-cli离线deb包,使用dpkg -i逐个安装。

3、启动Docker服务并设为开机自启:sudo systemctl start dockersudo systemctl enable docker

4、拉取麒麟OS兼容的基础镜像,例如swr.cn-south-1.myhuaweicloud.com/kunpeng/ubuntu:22.04-arm64或本地构建含Kylin SDK的定制镜像。

5、运行容器并挂载宿主机开发目录:docker run -it -v /home/user/project:/workspace -p 8080:8080 --name dev-env 镜像名 /bin/bash

二、使用KVM虚拟机部署全系统测试环境

KVM作为Linux内核原生模块,在麒麟OS中深度集成,提供硬件级虚拟化能力,可完整运行不同发行版的客户机操作系统,适用于需要内核模块调试、驱动验证或跨架构兼容性测试的场景。

1、检查CPU是否支持虚拟化:执行lscpu | grep Virtualization,输出应包含VT-xAMD-V

2、安装QEMU-KVM及相关工具sudo apt install qemu-kvm libvirt-daemon-system virt-manager,并加入kvmlibvirt用户组。

3、启用并启动libvirtd服务:sudo systemctl enable libvirtdsudo systemctl start libvirtd

4、下载麒麟OS官方提供的QCOW2格式测试镜像(如Kylin-Desktop-V10-SP1-update3-qcow2),或使用virt-install命令行创建新虚拟机。

5、配置桥接网络:编辑/etc/netplan/01-network-manager-all.yaml,将物理网卡绑定至br0桥,使虚拟机获得与宿主机同网段IP。

拍我AI
拍我AI

AI视频生成平台PixVerse的国内版本

下载

三、混合使用Docker与KVM构建分层环境

在复杂测试流程中,可在KVM虚拟机内部运行Docker守护进程,形成“虚拟机→容器”两级隔离结构,兼顾系统级兼容性与应用级弹性伸缩能力。

1、在KVM客户机中安装与宿主机一致的麒麟OS版本,确保内核参数(如net.bridge.bridge-nf-call-iptables=1)已启用。

2、于客户机内重复步骤“一”中的Docker安装流程,注意禁用systemd服务冲突:使用dockerd --config-file /etc/docker/daemon.json指定独立数据目录。

3、配置客户机Docker守护进程监听TCP端口并启用TLS认证,通过宿主机DOCKER_HOST环境变量远程调用。

4、在宿主机编写Python脚本,利用libvirt API启动虚拟机后,自动注入curl命令拉取镜像并运行测试容器。

5、所有虚拟机磁盘镜像须存放在LVM逻辑卷或XFS文件系统上,确保开启discard选项以支持QCOW2镜像在线瘦身

四、环境一致性校验与权限加固

麒麟OS默认启用SELinux与kysec安全模块,需同步调整容器与虚拟机策略,防止因安全上下文不匹配导致挂载失败或进程拒绝执行。

1、为Docker守护进程添加SELinux策略模块:sudo semanage fcontext -a -t container_file_t "/opt/kylindata(/.*)?",随后执行restorecon -Rv /opt/kylindata

2、在KVM XML定义中显式声明,避免客户机启动时因标签缺失被强制降级为permissive模式。

3、禁止以root身份直接运行容器:创建devuser组,将开发者账户加入该组,并在/etc/subuid/etc/subgid中分配独立UID/GID范围。

4、对所有虚拟机磁盘镜像启用LUKS加密:sudo cryptsetup luksFormat --type luks2 /dev/vg0/testvm.img,密钥由麒麟OS可信执行环境(TEE)托管。

5、每次环境部署后必须执行kysec-check --profile dev-env --output /var/log/env_audit.log,生成符合等保2.0三级要求的基线审计报告。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

428

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

541

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

78

2025.09.10

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1914

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2096

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1099

2024.11.28

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

445

2023.06.14

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.5万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号