iSulad部署以及使用方案

文章目录

部署isulad

系统版本:openEuler 22.03 LTS版本,建议用欧拉系统

一、基础安装

bash 复制代码
# 克隆地址
git clone https://gitee.com/openeuler/iSulad.git
# 重新安装依赖环境meson
sudo apt remove meson -y
sudo apt install -y python3-pip
pip3 install --user meson
# 运行测试版本
~/.local/bin/meson --version
export PATH="$HOME/.local/bin:$PATH"
# 安装依赖
sudo apt-get install -y libgmock-dev
# 安装1.7以上版本的go
wget https://go.dev/dl/go1.20.14.linux-amd64.tar.gz
sudo tar -C /usr/local -xzf go1.20.14.linux-amd64.tar.gz
echo 'export PATH=/usr/local/go/bin:$PATH' >> ~/.bashrc
source ~/.bashrc
# 安装依赖
sudo env "PATH=$PATH" bash -x CI/install_depends.sh
# 依赖最后如果有可以忽略:install_depends.sh: line 155: /root/.cargo/env: No such file or directory
# 更改权限执行安装
cd ~/iSulad
mkdir -p build
cd build

cmake .. \
  -DCMAKE_INSTALL_PREFIX=/usr \
  -DENABLE_LCR=OFF \
  -DENABLE_RUNC=ON

make -j$(nproc)
sudo make install

补充:

bash 复制代码
# 如果要重新编译
# 删除依赖项
sudo rm -rf /root/lcr
sudo rm -rf /root/lxc
sudo rm -rf /root/cri-tools
sudo rm -rf /root/dnsname
sudo rm -rf /root/plugins
# 停止服务
sudo systemctl stop isulad

# 1️⃣ 删二进制
sudo rm -f /usr/local/bin/isulad
sudo rm -f /usr/local/bin/isula

# 2️⃣ 删动态库(关键)
sudo rm -f /usr/local/lib/libisula*
sudo rm -f /usr/local/lib/liblcr*
sudo rm -f /usr/local/lib/libshim*

# 3️⃣ 刷新链接器缓存
sudo ldconfig

# 4️⃣ 清运行时数据(避免脏数据)
sudo rm -rf /var/lib/isulad
sudo rm -rf /run/isulad

二、修改配置文件

bash 复制代码
# 创建基础配置文件config.json,systemcontainer_config.json
mkdir -p /etc/default/isulad/
vim /etc/default/isulad/config.json
cp /etc/default/isulad/config.json /etc/default/isulad/systemcontainer_config.json
# 需要安装runc,用runc替换默认的runtime方案,所以按照如下config.json内容设置
sudo apt install runc

config.json文件内容

bash 复制代码
{
  "hook_spec": "/etc/isulad/hooks",
  "start_timeout": 120,
  "registry-mirrors": [
        "https://docker.1ms.run"
   ],
  "log_level": "INFO",
  "ociVersion": "1.0.2",
  "default_runtime": "runc",
  "runtimes": {
    "runc": {
      "path": "/usr/sbin/runc",
      "runtime_root": "/run/isulad/runc",
      "runtime": "runc"
    }
  }
}

三、配置成服务,service文件如下

bash 复制代码
[Unit]
Description=iSulad daemon
Documentation=https://gitee.com/openeuler/iSulad
After=network.target

[Service]
Type=simple

# 关键:前台运行
ExecStart=/usr/local/bin/isulad

# 自动重启
Restart=always
RestartSec=2

# 提高资源限制(避免容器启动异常)
LimitNOFILE=1048576
LimitNPROC=1048576
LimitCORE=infinity

# cgroup(建议)
Delegate=yes

# kill 行为
KillMode=process

[Install]
WantedBy=multi-user.target

四、前台调试启动isulad

bash 复制代码
# 查询可执行文件位置
which isulad
# 运行测试
sudo strace -f -o /root/isulad.trace /usr/local/bin/isulad
# 查看是否启动
ps -ef | grep isulad
# 查看启动异常报错日志
sudo tail -50 /root/isulad.trace
# 查看系统运行日志
tail -200 /var/lib/isulad/isulad.log

使用

isulad是华为推出的一套通用容器引擎,使用方法同docker类似,需要配置镜像源,拉取镜像

修改镜像源

bash 复制代码
vim /etc/isulad/daemon.json
{
    "registry-mirrors": [
        "https://docker.m.daocloud.io",
        "https://docker.1panel.live"
    ]
}
bash 复制代码
# 拉取镜像
isula pull quay.io/rockylinux/rockylinux:8
# 查看镜像列表
sudo isula images
# 启动运行容器
sudo isula run -dit --net=host  --privileged --name isula_openfilter 镜像id  /bin/bash
# 查看是否运行
sudo isula ps
# 拷贝主机文件夹到容器root目录下
sudo isula cp 文件夹 容器id:/root/
# 进入容器
sudo isula exec -it 容器id /bin/bash
# 将正在运行的容器导出为文件
isula export -o export.tar 容器id
# 将tar镜像导入为本地镜像
isula import export.tar my-image:latest
相关推荐
爱学习 爱分享16 小时前
k8s 开启防火墙,容器内部无法访问外部 ip
tcp/ip·容器·kubernetes
叶帆16 小时前
【YFIOs】Docker方式部署
运维·docker·容器
小猿姐17 小时前
Clickhouse Kubernetes Operator 实测:哪种方案更适合生产?
运维·数据库·kubernetes
岳来17 小时前
Docker 的 --privileged 特权模式学习
docker·容器·--privileged
彩色的黑'''17 小时前
[root@localhost ~]#,Linux系统的命令提示符为啥现在变成-bash-4.2#了,哪里设置的
linux·运维·bash
树下水月18 小时前
文件分片上传接口(Easyswoole)被nginx拦截,并返回状态码400和408的抓包排查过程
运维·nginx
南境十里·墨染春水18 小时前
linux学习进展 shell编程
linux·运维·学习
goyeer19 小时前
【ITIL4】32服务实践 - 问题管理(Problem Management)
linux·运维·服务器·企业数字化·it管理·itil·it治理
cen__y20 小时前
Linux11(网络编程)
linux·运维·服务器·c语言·网络·网络协议·tcp/ip
脑子加油站20 小时前
k8s-持久化存储
云原生·容器·kubernetes·k8s-持久化存储