三分钟Docker-推送本地镜像到仓库
时间:2022-07-24
本文章向大家介绍三分钟Docker-推送本地镜像到仓库,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
在上篇文章中,我们完成了应用程序容器化,把webapi项目构建镜像并容器化运行。本文将会演示如何把自己构建的镜像上传到docker官网的仓库和自己私有仓库
本地镜像推送到官网的registry
1.创建仓库
点击Docker Desktop图标->Repositories-》create
跳转到官网创建页面
2.Docker tag (标记镜像)、push(推送镜像) 到仓库
使用一下命令,推送本地镜像到仓库
docker tag local-image:tagname new-repo:tagname
docker push new-repo:tagname
在操作之前执行登录命令,否则会提示:unauthorized: incorrect username or password
docker login
Username (mingchengnet):
Password:
Login Succeeded
然后执行Tag和push命令
docker tag aastore.productcatalog.api:dev mingchengnet/aastore:dev
docker push mingchengnet/aastore:dev
docker tag 后面的aastore.productcatalog.api:dev是你要上传的本地镜像。mingchengnet(账号名称)/aastore(仓库名称):dev(起的新镜像名称) 成功提示:
The push refers to repository [docker.io/mingchengnet/aastore]
cd7e3f7827e5: Pushed
bf4376f176a3: Pushed
d86ec58d3137: Pushed
8c30868fe23a: Pushed
886801dff0ea: Pushed
49b759454bb2: Pushed
95ef25a32043: Pushed
dev: digest: sha256:109d899344cd6524b32f02f484feaac5382d0dff24cfe55801d645e6e56c3910 size: 1794
推送、并搭建私有的registry
1.拉取Docker 官方提供了一个搭建私有仓库的镜像 registry,运行容器并暴露端口5050映射端口5000
docker pull registry
docker run -d -p 5050:5000 --restart=always registry
在浏览器里访问http://127.0.0.1:5050/v2/ 输出{},表示私有仓库搭建成功
2.执行Tag(标记镜像)和push(上传镜像)命令
docker tag aastore.productcatalog.api:dev localhost:5050/aastore.productcatalog.api:v1.0
docker push localhost:5050/aastore.productcatalog.api:v1.0
输出
v1.0: Pulling from aastore.productcatalog.api
Digest: sha256:109d899344cd6524b32f02f484feaac5382d0dff24cfe55801d645e6e56c3910
Status: Image is up to date for localhost:5050/aastore.productcatalog.api:v1.0
localhost:5050/aastore.productcatalog.api:v1.0
在浏览器里访问http://127.0.0.1:5050/v2/_catalog,就能看到仓库中包含镜像:aastore.productcatalog.api
下篇演示如何运行在k8s中。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 数据处理 | pandas入门专题——离散化与one-hot
- 聊聊dubbo-go的failfastCluster
- 一分钟学Python|Python的循环语句
- OpenCV4.4 中SIFT特征匹配调用演示
- 这些Python库虽然冷门,但功能真的很强大!
- SQL查找是否"存在",别再count了,很耗费时间的
- 采用 Vue 编写的功能强大的 Swagger-ui 页面
- SQL 计算中位数
- SQL 打印成绩单
- TypeScript 快速入门
- ES的新特性
- PHP设计模式|观察者模式
- JavaScript 中 this 的错误认识、绑定规则、常见问题讲解
- 实践:SpringBoot实现定时任务的动态增删启停
- Java并发编程的艺术[3]