当前位置: 代码网 > 服务器>服务器>云虚拟主机 > Docker创建自己的镜像与上传流程详解

Docker创建自己的镜像与上传流程详解

2024年05月20日 云虚拟主机 我要评论
引入在部署毕节服务器时遇到了个问题:  因为在三台服务器做好ovirt-engine超融合后,在主节点服务器上部署可视化平台需要安装mysql5.7,但是安装mysql时需要卸载一

引入

在部署毕节服务器时遇到了个问题:

  因为在三台服务器做好ovirt-engine超融合后,在主节点服务器上部署可视化平台需要安装mysql5.7,但是安装mysql时需要卸载一些依赖,但是由于怕影响原有的postgresql数据库和ovirt-engine的服务组件,选择了用docker容器部署mysql数据库。

  在顺利创建好容器,配置好mysql远程连接后,发现用navicat死活连不上,部署mysql8也连不上,能改的配置文件都改了,路由也开放了,端口也开放了,就是不得行。非常怀疑是ovirt-engine超融合的一些设置影响了docker容器和宿主机的网络沟通。

  后面没办法就创建了台虚拟机作为mysql服务器。

  隔了一天偶然翻博客发现docker容器有个主机模式,这玩应好像直接用的宿主机的网络和端口。于是尝试着在自己公司部署了一下,还真行。然后就想着直接部署好创建一个自己的镜像,以后方便点。于是就有了这篇部署记录。

了解docker的资源隔离和主机模式

此模式下 dockers 容器与宿主机在同一个网络中,但没有独立ip地址。

docker使用了linuxnamespaces技术来进行资源隔离,如:

  • pid namespace隔离进程
  • mount namespace隔离文件系统
  • network namespace隔离网络等

一个docker容器一般会分配一个独立的network namespace。但如果启动容器的时候使用host模式,那么这个容器将不会获得一个独立的network namespace,而是和宿主机共用一个network namespace。容器将不会虚拟出自己的网卡,配置自己的ip等,而是使用宿主机的ip和端口。

创建 centos7 容器

创建mysql数据目录

mkdir -p /usr/mysql/data

创建容器

docker run -dit --name mysql5.7  --privileged=true --network=host \
-v /usr/mysql/data:/var/lib/mysql \
centos:centos7 /usr/sbin/init

因为用了主机模式--network=host,所以就不用映射端口了。

进入容器

docker exec -it mysql5.7 /bin/bash

安装必要的工具

yum install -y wget

部署mysql5.7

创建docker hub仓库

https://hub.docker.com/

注册登录创建自己的仓库,可以是公共也可以是私有

注意自己的仓库命名,最好是见名知义,因为仓库名就是后面镜像的名称

在服务器上登录你的 docker

docker login

生成镜像

创建自己的镜像

docker commit -m "centos7 with mysql5.7" -a "echoo" a3dee73dbafa cent7sql:5.7

-m 描述信息

-a 作者信息 a3dee73dbafa 容器id

cent7sql:5.7 镜像名:版本标签

注意:当你登录了自己的 docker后,查看镜像你会发现镜像名多了点东西 如docker.io/centos,这里的docker.io就是docker hub的公共用户名,centos则是镜像仓库的名字。 此时我这个镜像名是不符合规则的,如果直接推送会报错,必须按照用户名/仓库名:版本标签 这样的规则命名,这就是为啥上面创建仓库的时候说最好要见名知义。

更改镜像名字(重新打一个标签)

docker tag cent7sql:5.7 echoo2787/centos7:sql5.7

这样的命名就可以啦

提交镜像

docker push echoo2787/centos7:sql5.7

这个命令在创建仓库完成后那个页面右边可以找到

等待推送完成就好,如果报拒绝错误,检查是不是镜像命名和要求不一致。

到此这篇关于docker创建自己的镜像与上传流程详解的文章就介绍到这了,更多相关docker创建镜像内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com