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

相关文章

在Ubuntu上打不开GitHub的完整解决方法

《在Ubuntu上打不开GitHub的完整解决方法》当你满心欢喜打开Ubuntu准备推送代码时,突然发现终端里的gitpush卡成狗,浏览器里的GitHub页面直接变成Whoathere!警告页面... 目录一、那些年我们遇到的"红色惊叹号"二、三大症状快速诊断症状1:浏览器直接无法访问症状2:终端操作异常

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

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详