使用ssh在本地环境(Windows)连接虚拟机以及其中的docker容器

配置虚拟机防火墙

防火墙的一系列操作需要root权限,默认是没有root密码的,所以首先需要设置root密码:

bash 复制代码
sudo passwd root

按提示完成root密码设置

切换到root账户

bash 复制代码
su root

启用22端口并重启防火墙

bash 复制代码
firewall-cmd --permanent --add-port=22/tcp
firewall-cmd --reload

或者直接关闭防火墙

bash 复制代码
systemctl stop firewalld.service

ssh连接虚拟机

查看IP地址

安装net-tools

首先安装查看ip地址的工具net-tools,已经有了可以不下载

bash 复制代码
sudo apt-get update
sudo apt-get install net-tools

通过ifconfig查看虚拟机ip地址
配置虚拟机SSH

  1. 安装openssh-client:sudo apt-get install openssh-client
  2. 安装openssh-server:sudo apt-get install openssh-server
  3. 启动ssh-server:sudo /etc/init.d/ssh restart
  4. 确认ssh-server工作正常:netstat -tpl (看到ssh表示工作正常)

登陆

此时便可以通过在主机cmd上通过命令通过普通用户

bash 复制代码
ssh username@ip -p port

进行登陆

如果要设置免密登陆请参考这篇https://blog.csdn.net/qq_57150526/article/details/134387937?spm=1001.2014.3001.5502

如果用root登陆则需要修改 /etc/ssh/sshd_config,在打开的文件中找到 PermitRootLogin将其改为PermitRootLogin yes,并取消注释,保存退出。

ssh连接docker容器

连接docker容器大体步骤与连接虚拟机类似。

在创建和运行docker容器时需要将容器的22端口映射到虚拟机的外部端口比如映射到20000

bash 复制代码
docker run -p 20000:22 --name ubuntu_test -itd ubuntu:latest

刚开始运行容器需要初始化容器的root密码,使用passwd命令按要求修改即可。并且完成连接虚拟机 中的各个操作即可

最后在进行免密登陆过程中~/.ssh/config中需要额外添加Port 20000

最后即可按照连接虚拟机的方法登陆了。

相关推荐
张道宁1 小时前
Windows 环境下 Docker 部署 YOLOv8 并集成 Spring Boot 完整指南
windows·yolo·docker
万里沧海寄云帆4 小时前
Windows下uv环境硬链接失败问题
windows·uv
unsynchronized5 小时前
OpenClaw 安装指南:Linux 与 Windows 系统详细教程
linux·运维·windows·ai
lpfasd1236 小时前
Kubernetes (K8s) 底层早已不再直接使用 Docker 引擎了
java·docker·kubernetes
x***r1516 小时前
R语言 4.5.1安装教程 Windows版:解压+管理员运行+自定义路径+启动验证指南
windows
非凡ghost8 小时前
Zen Browser:基于 Firefox 的极简开源浏览器,隐私与速度兼得
前端·网络·windows·学习·开源·firefox·软件需求
margu_1688 小时前
【Docker】nscenter命令详解
运维·docker·容器
木梓辛铭8 小时前
windows下部署openclaw详细方法及错误处理办法
windows·学习方法·持续部署
John_ToDebug8 小时前
死锁案例:UI 线程阻塞等待跨进程 COM 注入
c++·windows·笔记
内网渗透10 小时前
Komari 部署教程:无数据库、单文件、Docker 一键启动的监控工具
数据库·docker·容器·内网穿透·cpolar·远程办公·komari