Dockerfile制作能够ssh的ubuntu和centos7系统

2024-06-14 12:44

本文主要是介绍Dockerfile制作能够ssh的ubuntu和centos7系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一.制作ubuntu系统

1.Dockerfile内容如下

2.运行容器并验证 

二.制作centos7系统

1.Dockerfile内容如下

2.验证并测试


一.制作ubuntu系统

要求:制作一个能够远程ssh的ubuntu操作系统镜像,要求通过该镜像运容器后,内部拥有一些自动补全、vim、网络插件等常用的软件包。

1.Dockerfile内容如下

[root@localhost docker]# cat Dockerfile 
FROM ubuntu
RUN apt-get update && apt-get install -y openssh-server vim net-tools iproute2 bash-completion
RUN mkdir -p /var/run/sshd && echo 'root:nihao' | chpasswd
RUN sed -i 's/#PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config && sed -i 's@session    required     pam_loginuid.so@session    optional     pam_loginuid.so@g' /etc/pam.d/sshd
ENTRYPOINT ["/usr/sbin/sshd", "-D"] 
EXPOSE 22 
[root@localhost docker]# docker build -t myubuntu ./
[root@localhost docker]# docker images | grep myubuntu
myubuntu     latest    dbcc4cc0f303   About a minute ago   300MB

2.运行容器并验证 

[root@localhost docker]# docker run --name myubuntu -p 2222:22 -d myubuntu
[root@localhost docker]# docker ps
CONTAINER ID   IMAGE      COMMAND               CREATED              STATUS              PORTS                                   NAMES
b055d6ecb26c   myubuntu   "/usr/sbin/sshd -D"   About a minute ago   Up About a minute   0.0.0.0:2222->22/tcp, :::2222->22/tcp   myubuntu
​
[C:\~]$ ssh 192.168.2.160:2222
​
​
Connecting to 192.168.2.160:2222...
Connection established.
To escape to local shell, press 'Ctrl+Alt+]'.
​
Welcome to Ubuntu 24.04 LTS (GNU/Linux 5.14.0-162.6.1.el9_1.x86_64 x86_64)
​* Documentation:  https://help.ubuntu.com* Management:     https://landscape.canonical.com* Support:        https://ubuntu.com/pro
​
This system has been minimized by removing packages and content that are
not required on a system that users do not log into.
​
To restore this content, you can run the 'unminimize' command.
Last login: Wed Jun  5 06:01:37 2024 from 192.168.2.2
root@b055d6ecb26c:~# 
root@b055d6ecb26c:~# ss -lntup | grep 22
tcp   LISTEN 0      128          0.0.0.0:22        0.0.0.0:*    users:(("sshd",pid=1,fd=3))
tcp   LISTEN 0      128             [::]:22           [::]:*    users:(("sshd",pid=1,fd=4))
root@b055d6ecb26c:~# netstat -anp | grep 22
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1/sshd: /usr/sbin/s 
tcp        0     52 172.17.0.2:22           192.168.2.2:57982       ESTABLISHED 49/sshd: root@pts/0 
tcp6       0      0 :::22                   :::*                    LISTEN      1/sshd: /usr/sbin/s 
root@b055d6ecb26c:~# service ssh status* sshd is running

二.制作centos7系统

 要求同制作ubuntu系统一样

只是在centos系统内下载好openssh后启动ssh会报错没有主机密钥,所以我们需要在Dockerfile中使用ssh-kengen -A生成主机密钥

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

sshd: no hostkeys available -- exiting.

1.Dockerfile内容如下

[root@localhost centos]# cat Dockerfile 
FROM centos:7
RUN yum install -y openssh-server vim net-tools  bash-completion
RUN mkdir -p /var/run/sshd && echo 'nihao' | passwd --stdin root && ssh-keygen -A
RUN sed -i 's/#PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config && sed -i 's@session    required     pam_loginuid.so@session    optional     pam_loginuid.so@g' /etc/pam.d/sshd
ENTRYPOINT ["/usr/sbin/sshd", "-D"] 
EXPOSE 22 
[root@localhost centos]# docker build -t mycentos:7 ./
[root@localhost centos]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
mycentos     7         84f3511bdfb5   7 minutes ago   519MB
mytomcat     latest    c4d1c41c131b   18 hours ago    745MB
nginx        latest    e784f4560448   5 weeks ago     188MB
busybox      latest    65ad0d468eb1   13 months ago   4.26MB
tomcat       latest    fb5657adc892   2 years ago     680MB
centos       7         eeb6ee3f44bd   2 years ago     204MB
centos       latest    5d0da3dc9764   2 years ago     231MB
nginx        1.17.2    4733136e5c3c   4 years ago     126MB
[root@localhost centos]# docker run -it --name mycentos7 -p 2222:22 -d mycentos:7 
3bb789c6e2c973f2727dc8925de5f8847cf266eddb9a6510478d3015c2f01e6f
[root@localhost centos]# docker ps
CONTAINER ID   IMAGE        COMMAND               CREATED         STATUS         PORTS                                   NAMES
3bb789c6e2c9   mycentos:7   "/usr/sbin/sshd -D"   2 seconds ago   Up 2 seconds   0.0.0.0:2222->22/tcp, :::2222->22/tcp   mycentos7

2.验证并测试

[C:\~]$ ssh root@192.168.2.160:2222Connecting to 192.168.2.160:2222...
Connection established.
To escape to local shell, press 'Ctrl+Alt+]'.Last failed login: Thu Jun 13 07:42:36 UTC 2024 from 192.168.2.2 on ssh:notty
There was 1 failed login attempt since the last successful login.

这篇关于Dockerfile制作能够ssh的ubuntu和centos7系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060439

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成