当前位置: 首页 > wzjs >正文

站酷官网wordpress输出副标题

站酷官网,wordpress输出副标题,2024年1月新冠高峰期,WordPress 会员空间插件概述 在使用k3s过程中,经常需要使用ctr和crictl两个命令,本文记录一下。 ctr 类似docker命令是docker-shim容器运行时的客户端工具,ctr是Containerd的客户端工具。一个简单的CLI接口,用作Containerd本身的一些调试用途&#xf…

概述

在使用k3s过程中,经常需要使用ctrcrictl两个命令,本文记录一下。

ctr

类似docker命令是docker-shim容器运行时的客户端工具,ctr是Containerd的客户端工具。一个简单的CLI接口,用作Containerd本身的一些调试用途,投入生产使用时还是应该配合docker或cri-containerd。

安装Containerd作为容器运行时后,会自动安装ctr;安装k3s后,也会自动安装ctr

命名空间

ctrdocker命令一个较大的区别,ctr有命名空间的概念,自带一个moby命名空间:
在这里插入图片描述
如果执行过ctr i pullctr i importctr i export等命令,又没有通过-n参数指定命名空间,则会自动创建default命名空间:
在这里插入图片描述
当Containerd结合k8s(或k3s)使用时,相关镜像一般存放到k8s.io,相关操作需要加-n k8s.io,避免与默认空间混淆,且将参数放到最前面,即:ctr -n=k8s.io i pull

ctr命令输出:

ctr is an unsupported debug and administrative client for interacting
with the containerd daemon. Because it is unsupported, the commands,
options, and operations are not guaranteed to be backward compatible or
stable from release to release of the containerd project.COMMANDS:plugins, plugin            Provides information about containerd pluginsversion                    Print the client and server versionscontainers, c, container   Manage containerscontent                    Manage contentevents, event              Display containerd eventsimages, image, i           Manage imagesleases                     Manage leasesnamespaces, namespace, ns  Manage namespacespprof                      Provide golang pprof outputs for containerdrun                        Run a containersnapshots, snapshot        Manage snapshotstasks, t, task             Manage tasksinstall                    Install a new packageoci                        OCI toolssandboxes, sandbox, sb, s  Manage sandboxesinfo                       Print the server infodeprecationsshim                       Interact with a shim directlyhelp, h                    Shows a list of commands or help for one commandGLOBAL OPTIONS:--debug                      Enable debug output in logs--address value, -a value    Address for containerd's GRPC server (default: "/run/containerd/containerd.sock") [$CONTAINERD_ADDRESS]--timeout value              Total timeout for ctr commands (default: 0s)--connect-timeout value      Timeout for connecting to containerd (default: 0s)--namespace value, -n value  Namespace to use with commands (default: "default") [$CONTAINERD_NAMESPACE]--help, -h                   show help--version, -v                print the version

crictl

crictl,GitHub,一个兼容CRI的命令行接口,可用于检查和调试k8s/kubelet节点上的容器运行时和应用程序。只有一个k8s.io命名空间,无需-n参数。

安装

VERSION="v1.33.0"
wget https://github.com/kubernetes-sigs/cri-tools/releases/download/$VERSION/crictl-$VERSION-linux-amd64.tar.gz
sudo tar zxvf crictl-$VERSION-linux-amd64.tar.gz -C /usr/local/bin
rm -f crictl-$VERSION-linux-amd64.tar.gz

crictl默认连接到unix:///var/run/dockershim.sock。对于其它运行时,可通过多种方式设置端点:

  • 设置--runtime-endpoint--image-endpoint选项;
  • 设置CONTAINER_RUNTIME_ENDPOINTIMAGE_SERVICE_ENDPOINT环境变量;
  • 在配置文件--config=/etc/crictl.yaml设置端点。

在连接到服务器时,配置文件可指定超时值(timeout–timeout),启用或禁用调试(debug–debug)。

比如在k3s环境下,执行cat /var/lib/rancher/k3s/agent/etc/crictl.yaml输出:

runtime-endpoint: unix:///run/k3s/containerd/containerd.sock

crictl命令输出:

VERSION:v1.31.0-k3s2COMMANDS:attach                 Attach to a running containercheckpoint             Checkpoint one or more running containerscompletion             Output shell completion codeconfig                 Get and set crictl client configuration optionscreate                 Create a new containerevents, event          Stream the events of containersexec                   Run a command in a running containerimagefsinfo            Return image filesystem infoimages, image, img     List imagesinfo                   Display information of the container runtimeinspect                Display the status of one or more containersinspecti               Return the status of one or more imagesinspectp               Display the status of one or more podslogs                   Fetch the logs of a containermetricsp               List pod metrics. Metrics are unstructured key/value pairs gathered by CRI meant to replace cAdvisor's /metrics/cadvisor endpoint.pods                   List podsport-forward           Forward local port to a podps                     List containerspull                   Pull an image from a registryrm                     Remove one or more containersrmi                    Remove one or more imagesrmp                    Remove one or more podsrun                    Run a new container inside a sandboxrunp                   Run a new podruntime-config         Retrieve the container runtime configurationstart                  Start one or more created containersstats                  List container(s) resource usage statisticsstatsp                 List pod statistics. Stats represent a structured API that will fulfill the Kubelet's /stats/summary endpoint.stop                   Stop one or more running containersstopp                  Stop one or more running podsupdate                 Update one or more running containersupdate-runtime-config  Update the runtime configurationversion                Display runtime version informationhelp, h                Shows a list of commands or help for one commandGLOBAL OPTIONS:--config value, -c value                   Location of the client config file. If not specified and the default does not exist, the program's directory is searched as well (default: "/etc/crictl.yaml") [$CRI_CONFIG_FILE]--debug, -D                                Enable debug mode (default: false)--enable-tracing                           Enable OpenTelemetry tracing. (default: false)--image-endpoint value, -i value           Endpoint of CRI image manager service (default: uses 'runtime-endpoint' setting) [$IMAGE_SERVICE_ENDPOINT]--runtime-endpoint value, -r value         Endpoint of CRI container runtime service (default: uses in order the first successful one of [unix:///run/k3s/containerd/containerd.sock unix:///var/run/dockershim.sock unix:///run/containerd/containerd.sock unix:///run/crio/crio.sock unix:///var/run/cri-dockerd.sock]). Default is now deprecated and the endpoint should be set instead. [$CONTAINER_RUNTIME_ENDPOINT]--timeout value, -t value                  Timeout of connecting to the server in seconds (e.g. 2s, 20s.). 0 or less is set to default (default: 2s)--tracing-endpoint value                   Address to which the gRPC tracing collector will send spans to. (default: "127.0.0.1:4317")--tracing-sampling-rate-per-million value  Number of samples to collect per million OpenTelemetry spans. Set to 1000000 or -1 to always sample. (default: -1)--help, -h                                 Show help (default: false)--version, -v                              Print the version (default: false)

crictl pull

可以明确的是:

  • 哪怕当前环境已经下载过docker镜像,使用yaml文件通过vLLM启动大模型时,还是会去下载crictl镜像;
  • 通过crictl下载镜像,和docker下载的镜像,其名字一致;
  • yaml文件里使用dustynv/vllm:0.7.4-r36.4.0-cu128-24.04镜像,等价于docker.io/dustynv/vllm:0.7.4-r36.4.0-cu128-24.04
  • 上面的docker.io就是部署在国外的Docker Hub官方镜像源,国内下载速度非常慢;
  • 可考虑使用国内镜像源,如docker.m.daocloud.io/dustynv/vllmdocker.1ms.run/dustynv/vllm
  • 通过crictl pull下载镜像并没有进度条提示,狠是恶心,只能干等,有时候等了10分钟给你来个提示,只能重试。

在这里插入图片描述
如上图所示,没有任何进度提示。

下载国外镜像,会遇到各种奇奇怪怪的报错:
在这里插入图片描述
使用国内的镜像源地址:
在这里插入图片描述
反复重试,还是上面的报错提示。

Qwen等ChatGPT给出的解决方法是先登录。

好,遇到问题解决问题;打开网站毫秒镜像,使用个人手机号注册。按照Qwen给出的幻觉答复,crictl login
在这里插入图片描述
crictl pull镜像可以执行docker login,可见crictl底层使用的还是docker镜像那一套机制:
在这里插入图片描述
不过又遇到另一个超时报错,那就再换一个国内镜像源吧。

实践下来,通过docker.m.daocloud.io镜像源下载crictl镜像速度还能接受。

crictl镜像和ctr镜像

部分网络资料说crictl image list等效于ctr -n=k8s.io image list

经过各种ChatGPT以及命令尝试:
在这里插入图片描述
crictl image等效于crictl images,等效于crictl image listcrictl images list

在k3s环境下,crictl image等效于k3s ctr -n=k8s.io image list
在这里插入图片描述
k3s命令前缀不能省去。k3s默认使用-n=k8s.io命名空间,因此crictl image等效于k3s ctr images list

个数

crictl images | grep vllm输出2个:
在这里插入图片描述
k3s ctr images list | grep vllm输出4个:
在这里插入图片描述
分析:

  • crictl是CRI客户端工具,crictl输出是CRI提供给kubelet的简化视图,只显示标签信息,不展示digest表示;
  • k3s ctr image输出,表明containerd实际存储四个镜像引用;分别是tag和digest;

crictl镜像导出

输入命令crictl imagesk3s crictl images的截图如下:
在这里插入图片描述
可见,在k3s环境下,crictl命令等价于k3s crictl,也就是说,k3s命令前缀可以省去。

问题在于,一个vLLM镜像动辄5~6个G。

vLLM这篇博客也提到过,部署大模型时,通过k8s调度到从节点,则从节点也需要对应的模型文件和crictl镜像。

那crictl镜像能不能导出为tar包,通过scp命令传输到从节点,然后在从节点导入tar包为crictl镜像呢?

答案当然是可以,docker镜像就完全可以这么玩,crictl和docker存在很多相似之处。

但crictl并没有提供save命令:
在这里插入图片描述
需要通过ctr export命令执行导出操作。

导出镜像的前提是找到镜像,要不然就会出现如下not found报错:
在这里插入图片描述
k3s ctr image | grep vllm:0.8.6输出2行,下面这一行非常非常长,:

docker.io/dustynv/vllm:0.8.6-r36.4-cu128-24.04                                                                   application/vnd.docker.distribution.manifest.v2+json sha256:b2210294b661acc6e94bc302ce5111d6d0cb01a3815ada0132c105f540fb7a63 5.7 GiB   linux/arm64 io.cri-containerd.image=managed
docker.io/dustynv/vllm@sha256:b2210294b661acc6e94bc302ce5111d6d0cb01a3815ada0132c105f540fb7a63                   application/vnd.docker.distribution.manifest.v2+json sha256:b2210294b661acc6e94bc302ce5111d6d0cb01a3815ada0132c105f540fb7a63 5.7 GiB   linux/arm64 io.cri-containerd.image=managed

导出命令:k3s ctr -n k8s.io image export vllm-0.8.6.tar docker.io/dustynv/vllm:0.8.6-r36.4-cu128-24.04。如果
检查:
在这里插入图片描述

docker、crictl及ctr

三个命令行的对比

命令dockercrictl(推荐)ctr
查看容器列表docker pscrictl psctr -n k8s.io c ls
查看容器详情docker inspectcrictl inspectctr -n k8s.io c info
查看容器日志docker logscrictl logs
容器内执行命令docker execcrictl exec
挂载容器docker attachcrictl attach
容器资源使用docker statscrictl stats
创建容器docker createcrictl createctr -n k8s.io c create
启动容器docker startcrictl startctr -n k8s.io run
停止容器docker stopcrictl stop
删除容器docker rmcrictl rmctr -n k8s.io c del
查看镜像列表docker imagescrictl imagesctr -n k8s.io i ls
查看镜像详情docker inspectcrictl inspect
拉取镜像docker pullcrictl pullctr -n k8s.io i pull
推送镜像docker pushctr -n k8s.io i push
删除镜像docker rmicrictl rmictr -n k8s.io i rm
查看Pod列表crictl pods
查看Pod详情crictl inspectp
启动Podcrictl runp
停止Podcrictl stopp
导入镜像docker loadctr -n k8s.io i import
导出镜像docker savectr -n k8s.io i export

文章转载自:

http://fU8J8nTu.qswws.cn
http://zpJ8N7gz.qswws.cn
http://nZg8lwdB.qswws.cn
http://EFyL6ZCh.qswws.cn
http://NpuQwC0C.qswws.cn
http://FXShVfrN.qswws.cn
http://RhYVW2pC.qswws.cn
http://TFmaok5s.qswws.cn
http://3AflgelN.qswws.cn
http://kQJnIx1r.qswws.cn
http://ck42swXy.qswws.cn
http://LvNkOqSG.qswws.cn
http://EZH48bZy.qswws.cn
http://bToNnjov.qswws.cn
http://L0T3OTFu.qswws.cn
http://ZuZwGBNf.qswws.cn
http://magOJfBH.qswws.cn
http://vDfCH5lK.qswws.cn
http://WTRGDxg3.qswws.cn
http://H4Zo9AQr.qswws.cn
http://282idHo8.qswws.cn
http://LHvxeW2W.qswws.cn
http://1NULFDhA.qswws.cn
http://W4JQWmzf.qswws.cn
http://Gs8JEykH.qswws.cn
http://Q1USBOOO.qswws.cn
http://qwQ8cKVh.qswws.cn
http://13n8nbU2.qswws.cn
http://lRXcNqJF.qswws.cn
http://hcsoALnO.qswws.cn
http://www.dtcms.com/wzjs/725448.html

相关文章:

  • 有关网站建设的论文营销推广的形式包括
  • 深圳建网站的公司网页设计公司背景图
  • 电子商务微网站制作青岛app下载
  • 网站运行平台包括哪个网站做效果图好
  • 医院网站建设要求是什么网站空间购买 北京
  • 网站导航包括郑州短视频培训机构
  • 首选大型网站建站公司开什么工作室最稳定
  • wordpress站内短信网站建设多少钱信息
  • 网站管理是做什么的陕西省交通建设集团西长分公司网站
  • 案例应聘网络营销做网站推广建筑网校排名前十大品牌
  • 国内简约网站设计欣赏企业年金辞职了就白交了吗
  • 我想网上开店怎么开淄博网站排名seo
  • 网站建设的维护工作有哪些图跃网站建设
  • 宁夏住房建设厅网站企业宣传片脚本
  • 免备案域名购买网站厦门网站制作阳哥
  • 网站 粘度北京市建设规划网站
  • 修改网站空间服务器密码云阿里云做网站
  • 企业门户网站开发公司黄骅港务集团有限公司
  • 网站建设与推广长春自己怎么做淘宝网站
  • 网站设计报价是多少钱看房地产的app在哪看
  • 惠州建设局网站做外贸需要关注的网站有什么问题
  • 建设局发公告的网站免费软件漫画
  • 吉林省建设集团有限公司网站网站开发工具比较
  • 商务网站开发与建设论文百度小说官网
  • 用html5做的简单的网站建设网站培训班
  • 大型网站制作软件什么做的网站
  • 天津公司网站如何制作字体设计软件 免费
  • 文明网站机制建设深圳市建设混凝土投标网站
  • 铁岭网站开发公司企业网站建设原则有哪些
  • seo精华网站怎样做seo网站链接