目录引入了解Docker的资源隔离和主机模式创建 Centos7 容器部署Mysql5.7创建Docker Hub仓库生成镜像提交镜像引入 在部署毕节服务器时遇到了个问题: &ems
在部署毕节服务器时遇到了个问题:
因为在三台服务器做好ovirt-engine
超融合后,在主节点服务器上部署可视化平台需要安装mysql5.7
,但是安装mysql
时需要卸载一些依赖,但是由于怕影响原有的postgresql
数据库和ovirt-engine
的服务组件,选择了用docker
容器部署mysql
数据库。
在顺利创建好容器,配置好mysql
远程连接后,发现用navicat
死活连不上,部署mysql8
也连不上,能改的配置文件都改了,路由也开放了,端口也开放了,就是不得行。非常怀疑是ovirt-engine
超融合的一些设置影响了docker
容器和宿主机的网络沟通。
后面没办法就创建了台虚拟机作为mysql
服务器。
隔了一天偶然翻博客发现docker
容器有个主机模式
,这玩应好像直接用的宿主机的网络和端口。于是尝试着在自己公司部署了一下,还真行。然后就想着直接部署好创建一个自己的镜像,以后方便点。于是就有了这篇部署记录。
此模式下 dockers
容器与宿主机在同一个网络中,但没有独立IP地址。
docker
使用了linux
的Namespaces
技术来进行资源隔离,如:
PID Namespace
隔离进程Mount Namespace
隔离文件系统Network Namespace
隔离网络等一个Docker
容器一般会分配一个独立的Network Namespace
。但如果启动容器的时候使用host
模式,那么这个容器将不会获得一个独立的Network Namespace
,而是和宿主机共用一个Network Namespace
。容器将不会虚拟出自己的网卡,配置自己的IP等,而是使用宿主机的IP和端口。
创建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
传送门
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创建镜像内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Docker创建自己的镜像与上传流程详解
本文链接: https://lsjlt.com/news/168567.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0