利用K8S技术栈打造我的私有云(连载之:基础镜像制做与实验)

封面图片

注: 本文首发于 My 公众号 CodeSheep ,可 长按扫描 下面的 当心心 来订阅 ↓ ↓ ↓docker

CodeSheep · 程序羊



【利用K8S技术栈打造我的私有云系列文章目录】vim


任何一家云主机厂商提供给用户的主机功能其实讲白了就是一个操做系统基础镜像的运行实例。所以本篇博文将讲解如何在本地构建一个带ssh组件的centos底包镜像并上传到docker hub上供下载使用。centos


docker hub注册

注册网址:https://hub.docker.com/bash

Docker Hub


命令行中登陆到docker hub

命令行中输入:docker loginssh

docker login


制做centos7.4镜像

####**一、第一步:**去远端拉取一个最新的centos最基础镜像,基于此镜像来制做测试

docker pull centoscentos7

####**二、第二步:**启动该docker容器操作系统

docker run -it centos:latest /bin/bash命令行

####**三、第三步:**在启动的容器中来安装sshdcode

yum -y install openssh-server
yum -y install openssh-clients

####**四、第四步:**咱们来尝试启动一下sshd服务,会发现有报错

启动sshd服务命令: /usr/sbin/sshd -D 报以下错误:

Could not load host key: /etc/ssh/ssh_host_rsa_key
Could not load host key: /etc/ssh/ssh_host_ecdsa_key
Could not load host key: /etc/ssh/ssh_host_ed25519_key

咱们来解决以上错误:

ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ""
ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ""
ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key -N ""

此时再次来启动sshd服务应该无错误了

####**五、第五步:**编辑sshd_config配置文件

执行命令:vim /etc/ssh/sshd_config 将配置文件中本来UsePAM yes换成UsePAM no

####**六、第六步:**修改root的密码

执行命令:passwd root 输入两次密码便可

####**七、第七步:**咱们用exit命令来退出容器

####**八、第八步:**基于刚退出的容器咱们来制做带ssh功能的centos镜像 docker commit bf5b84f8e2d8 docker.io/hansonwang/centos7.4_ssh

(1)注意此处的bf5b84f8e2d8即为刚才运行的容器的id,可用docker ps -a查看 (2)注意此处的commit格式,必须为docker.io/<你的dockerhub用户名>/centos7.4_ssh


push镜像到远端

docker push docker.io/hansonwang/centos7.4_ssh:latest

一样须要注意此处的push格式,必须为docker.io/<你的dockerhub用户名/完整的镜像名

以下图所示:

docker push

同时咱们去docker hub上也能看到咱们刚push的镜像:

Repositories


效果验证

为了验证镜像确实被推到远端,咱们将本地刚打包好的镜像删除,而后从远端pull下来运行看看

docker pull hansonwang/centos7.4_ssh

能够成功pull下来:

从新pull镜像

咱们来测试一下该镜像里是否包含有ssh组件:运行其并用ssh链接到容器中: 运行容器:docker run -d -p 2222:22 docker.io/hansonwang/centos7.4_ssh:latest /usr/sbin/sshd -D ssh接入:ssh root@localhost -p 2222 此时会让你输入密码,而后成功登入容器之中:

ssh接入centos容器

相关文章
相关标签/搜索