win10使用Docker以及在天池比赛上提交容器镜像文件

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: win10使用Docker以及在天池比赛上提交容器镜像文件

一.安装Docker

根据前面的链接,先安装WSL2,开启Hyper-v,安装Docker Desktop

遇到的坑:

1.Windows功能里面没有Hyper-v(解决办法:升级win10系统到专业版)

2.安装WSL时候,重启出现 无法完成功能配置,撤销设置。(试过网上所有的办法,都无法解决。解决办法:右下角所有设置-windows设置-更新与安全 修复,等于重装C盘)

二.设置Docker Desktop

右击-setting

Resources里面其他不用动,最后的Ubuntu-20.04打开(如果安装的其他版本就会显示其他版本的ubuntu)。

在这里修改镜像源

三.

创建文件夹,必要文件Dockfile,requirements.txt,rush.sh和一些运行用的.py文件或文件夹

记得打开文件扩展名,我们需要修改后缀

.py文件就不阐述了,就是你需要运行的文件。

三.建立镜像并推送到镜像仓库

1.编写requirements.txt文件

安装pipreqs

pip install pipreqs
  • 打开 cmd 并cd 到要输出的目录 (如目录:docker_submit_demo)
  • 激活安装了pipreqs的虚拟环境
conda activate pytorch
  • 然后输入的命令
pipreqs ./ --encoding=utf-8
  • 就可以看到生成了requirements.txt文件

补充:执行下面代码就会把项目用到的所有组件装上

pip3 install -r requirements.txt

2.编写run.sh

创建txt文件,复制下面内容,并修改名字为run.sh

#!/bin/sh
CURDIR="`dirname $0`" #获取此脚本所在目录
echo $CURDIR
cd $CURDIR #切换到该脚本所在目录
python hello_world.py

3.编写Dockerfile文件

创建txt文件,复制下面内容,名字修改为Dockerfile

# Base Images
## 从天池基础镜像构建
FROM registry.cn-shanghai.aliyuncs.com/tcc-public/python:3
## 把当前文件夹里的文件构建到镜像的根目录下(.后面有空格,不能直接跟/)
ADD . /
## 指定默认工作目录为根目录(需要把run.sh和生成的结果文件都放在该文件夹下,提交后才能运行)
WORKDIR /
## Install Requirements(requirements.txt包含python包的版本)
## 这里使用清华镜像加速安装
RUN pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt
## 镜像启动后统一执行 sh run.sh
CMD ["sh", "run.sh"]

4.上传镜像至阿里云容器镜像仓库

阿里云容器镜像服务

在这之前完成阿里云容镜像仓库用户名和密码设置,并创建命名空间和镜像仓库,创建完仓库,进入仓库,可以找到公网地址,和登陆这个仓库的命令

## docker登陆(push镜像需要登陆,服务器地址为赛事要求的,这里以上海为例):
docker login --username=你自己的用户名 registry.cn-shanghai.aliyuncs.com
## 不要忘记加.
docker build -t 公网地址/版本号 .
## 构建完成后可先验证是否正常运行,正常运行后再进行推送。
CPU镜像:docker run 公网地址/版本号 sh run.sh
GPU镜像:nvidia-docker run 公网地址/版本号 sh run.sh
## 推送到镜像仓库,如果出错,可能没登录
docker push 公网地址/版本号 

版本号就任意发挥了,任意字母和数字组合

也可以打开Docker Desktop,查看本地的镜像,占用空间过大可以直接清理。

当然也可以在pycharm安装阿里云相关插件可以直接构建镜像并推送到仓库。

相关实践学习
通过workbench远程登录ECS,快速搭建Docker环境
本教程指导用户体验通过workbench远程登录ECS,完成搭建Docker环境的快速搭建,并使用Docker部署一个Nginx服务。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
29天前
|
Docker 容器
进入Docker容器中
进入Docker容器中
35 2
|
3天前
|
存储 Kubernetes Docker
Kubernetes(K8S)集群管理Docker容器(概念篇)
Kubernetes(K8S)集群管理Docker容器(概念篇)
|
3天前
|
存储 Ubuntu 安全
Docker容器常用命令
Docker容器常用命令
15 1
|
6天前
|
Java 持续交付 Maven
云效产品使用常见问题之流水线的容器读取本地的挂载文件失败如何解决
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
9天前
|
存储 运维 监控
构建高效稳定的Docker容器监控体系
【4月更文挑战第18天】 在现代微服务架构中,Docker容器已成为部署和运行应用的标准环境。随之而来的挑战是如何有效监控这些容器的性能与健康状况,确保系统的稳定性和可靠性。本文将探讨构建一个高效稳定的Docker容器监控体系的关键技术和方法,包括日志管理、性能指标收集以及异常检测机制,旨在为运维人员提供实用的指导和建议。
|
18天前
|
Linux Docker 容器
docker 容器常用命令
docker 容器常用命令
13 0
|
18天前
|
Linux Shell 虚拟化
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
28 0
|
18天前
|
存储 Linux Shell
centos 部署docker容器 安装 、基本使用方法(一)
centos 部署docker容器 安装 、基本使用方法(一)
32 0
|
26天前
|
Kubernetes 网络协议 Docker
Docker 容器的DNS
Docker 容器的DNS
28 1
|
29天前
|
关系型数据库 MySQL Nacos
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
48 1