构建可以ssh连接的容器镜像

构建可以ssh连接的容器镜像

构建可以通过ssh进行连接容器镜像,实现远程登录容器的目的。

ubuntu ssh容器镜像

你可以使用以下Dockerfile来构建一个可以SSH的容器镜像:

dockerfile 复制代码
FROM ubuntu:20.04

MAINTAINER lldhsds

# 配置apt国内源
COPY sources.list /etc/apt/

# 安装OpenSSH Server
RUN apt-get update && apt-get install -y openssh-server

# 创建SSH服务的必要目录
RUN mkdir /var/run/sshd

# 设置root用户的密码
RUN echo 'root:ubuntu' | chpasswd

# 允许root用户通过SSH登录
RUN sed -i 's/#PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config

# 暴露SSH端口
EXPOSE 22

# 启动SSH服务
CMD ["/usr/sbin/sshd", "-D"]

在dockerfile同目录下,创建镜像源文件sources.list,内容如下:

bash 复制代码
deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
# deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
# deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse

使用以下命令构建和运行镜像:

bash 复制代码
docker build -t ubuntu-ssh .
docker run -d -p 2222:22 ubuntu-ssh

然后,你可以通过SSH连接到容器:

bash 复制代码
ssh root@localhost -p 2222

centos ssh容器镜像

可以使用以下Dockerfile来构建一个可以SSH的容器镜像:

dockerfile 复制代码
FROM centos:7

MAINTAINER lldhsds

RUN rm -rf /etc/yum.repos.d/*

ADD repo.tar.gz /etc/yum.repos.d/

RUN yum install openssh-clients openssh-server -y && \
    ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key && \
    ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key && \
    ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key && \
    sed -i 's/#UseDNS yes/UseDNS no/' /etc/ssh/sshd_config && \
    echo "root:centos"| chpasswd

EXPOSE 22

CMD ["/usr/sbin/sshd", "-D"]

根据需要调整密码和配置!

dockerfile同目录下,创建repo.tar.gz,内容如下:

bash 复制代码
tar zcvf repo.tar.gz centos7.repo

其中cenos7.repo内容如下:

bash 复制代码
[base]
name=CentOS-$releasever - Base - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/
gpgcheck=1
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7

#released updates
[updates]
name=CentOS-$releasever - Updates - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/updates/$basearch/
gpgcheck=1
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7

#additional packages that may be useful
[extras]
name=CentOS-$releasever - Extras - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/extras/$basearch/
gpgcheck=1
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7

#additional packages that extend functionality of existing packages
[centosplus]
name=CentOS-$releasever - Plus - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/centosplus/$basearch/
gpgcheck=1
enabled=0
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7

#contrib - packages by Centos Users
[contrib]
name=CentOS-$releasever - Contrib - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/contrib/$basearch/
gpgcheck=1
enabled=0
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7
相关推荐
多则惑少则明9 小时前
SSM开发(一)JAVA,javaEE,spring,springmvc,springboot,SSM,SSH等几个概念区别
spring boot·spring·ssh
元气满满的热码式10 小时前
K8S中Service详解(一)
云原生·容器·kubernetes
元气满满的热码式13 小时前
K8S中ingress详解
云原生·容器·kubernetes
matrixlzp14 小时前
K8S 启动探测、就绪探测、存活探测
云原生·容器·kubernetes
Dusk_橙子14 小时前
在K8S中,如何使用EFK实现日志的统一管理?
云原生·容器·kubernetes
Tony115414 小时前
Kubernetes v1.28.0安装dashboard v2.6.1(k8s图形化操作界面)
云原生·容器·kubernetes
龙胖不下锅14 小时前
k8s资源预留
云原生·容器·kubernetes
超级阿飞14 小时前
利用Kubespray安装生产环境的k8s集群-排错篇
docker·容器·kubernetes
喝醉酒的小白14 小时前
在 Kubernetes 上快速安装 KubeSphere v4.1.2
云原生·容器·kubernetes
liuzhenghua6615 小时前
k8s优雅重启
云原生·容器·kubernetes