虚拟机ip不停地变每次使用ssh不好登录?有手就行!

简介: 虚拟机ip不停地变每次使用ssh不好登录?有手就行!


桥接模式下固定ip?No

如果你的机器是在一个不变的IP段,比如192.168.0.*,那么使用这种方式是完全可以的

也就是选定桥接模式之后,设置一下固定ip就行。

但是对于你的ip段变的话,比如公司的ip是192.168.10.#的IP段,回家后热点是172.20.10.#,比如说我,那我就得想个办法了,不然我每次使用ssh登还得不停地修改ip

Avahi服务,你值得拥有

Avahi基础知识:

1. 定义:

Avahi是一个开源的零配置网络服务发现工具,旨在提供在局域网中自动发现网络服务的能力。它基于Zeroconf协议(也称为Bonjour或mDNS)实现,允许设备在局域网中自动注册和发现服务,而无需手动配置。

2. 基本概念:

  • Zeroconf协议: Zeroconf是一组协议,包括mDNS(多播DNS)和DNS-SD(DNS服务发现)。这些协议允许设备在没有专门服务器的情况下自动配置网络和发现服务。
  • mDNS: mDNS允许设备通过在局域网内广播其主机名和IP地址的方式,实现本地域名解析,而不需要中央DNS服务器。这有助于在没有预先配置的情况下发现其他设备。
  • DNS-SD: DNS服务发现允许设备在网络上广告和查找可用的网络服务。设备可以向局域网广播它们提供的服务,并且其他设备可以查询局域网中的可用服务。
  • Avahi服务: Avahi是一个实现Zeroconf协议的开源软件。它在Linux和类Unix系统中广泛使用,为设备提供自动发现服务和本地域名解析的功能。
  • 服务类型和服务实例: 在Avahi中,服务类型是描述服务的规范,而服务实例是特定设备上运行的实际服务。例如,打印机服务类型可以有多个打印机实例。

使用Avahi在虚拟机环境中的应用:

在虚拟机环境中,Avahi可以用于:

  1. 自动发现服务: 虚拟机可以通过Avahi广播其提供的服务,其他设备可以通过查询来发现这些服务,无需手动配置。
  2. 本地域名解析: 虚拟机可以使用Avahi来提供简单的本地域名解析,使设备能够通过主机名而不是IP地址相互访问。
  3. 简化网络配置: Avahi通过自动发现服务和提供本地域名解析,简化了虚拟机在局域网中的网络配置,使得设备更容易集成到网络中。

总的来说,Avahi为虚拟机提供了零配置网络服务发现的功能,使得在虚拟化环境中更加方便地实现设备之间的通信和服务发现。

Avahi解决方案

虚拟机网络面临的挑战:

  1. 网络隔离: 虚拟机通常需要与主机和其他虚拟机进行通信,但有时也需要隔离以确保安全性。
  2. 网络配置复杂性: 手动配置虚拟机网络参数,如IP地址和子网掩码,可能会变得繁琐,特别是在复杂的网络拓扑中。
  3. 服务发现: 虚拟机和其他设备之间的服务发现通常需要额外的配置,而且在动态网络环境中可能变得复杂。
  4. 设备即插即用: 随着虚拟机的动态创建和销毁,确保新虚拟机能够即插即用,即立即在网络中可用,是一个挑战。

Avahi在虚拟化环境中的解决方案:

  1. 自动服务发现: Avahi使用Zeroconf协议,特别是mDNS和DNS-SD,允许虚拟机自动广播和发现服务。这解决了虚拟机和其他设备之间的服务发现问题,使得设备能够自动了解网络上的可用服务。
  2. 简化网络配置: Avahi通过提供零配置网络服务发现的能力,减轻了虚拟机网络配置的复杂性。虚拟机不再需要手动配置网络参数,而是通过Zeroconf协议自动获取IP地址和域名。
  3. 局域网内部本地域名解析: Avahi可以提供简单的本地域名解析,使设备能够使用主机名而不是IP地址相互访问。这在动态网络环境中尤其有用,当虚拟机的IP地址可能变化时,使用主机名可以更方便地进行通信。
  4. 灵活的网络隔离: Avahi可以根据网络需求配置虚拟机的隔离程度。通过使用Avahi提供的服务发现功能,虚拟机可以在需要时与其他设备通信,同时保持必要的网络隔离。
  5. 即插即用支持: 由于Avahi提供了自动服务发现和本地域名解析的功能,新创建的虚拟机可以立即在网络中可用,实现了即插即用的支持。

总体而言,Avahi在虚拟化环境中通过其零配置网络服务发现的能力,解决了虚拟机网络面临的诸多挑战。它简化了网络配置、提供了灵活的网络隔离,使得虚拟机能够更轻松地融入复杂的网络拓扑中。

虚拟机中配置Avahi服务

在虚拟机中部署Avahi服务通常涉及以下步骤,这里以基于Debian/Ubuntu系统为例:

步骤 1: 安装Avahi服务

sudo apt-get update
sudo apt-get install avahi-daemon

这将安装Avahi服务并启动它。安装完成后,Avahi会自动运行,并监听局域网上的mDNS请求。

步骤 2: 配置Avahi服务

Avahi的配置文件通常位于 /etc/avahi/avahi-daemon.conf。你可以根据需要进行修改,但默认配置通常已经足够。

sudo nano /etc/avahi/avahi-daemon.conf

确保 publish-workstation=yes,这将确保虚拟机能够在局域网上广播其服务。保存并退出。

步骤 3: 重启Avahi服务

sudo service avahi-daemon restart

这会重新启动Avahi服务,以便应用新的配置。

步骤 4: 测试服务发现

你可以使用avahi-browse工具来测试Avahi服务的可用性。首先,确保已安装avahi-utils

sudo apt-get install avahi-utils

然后运行以下命令来查看局域网上的Avahi服务:

avahi-browse -a

这将列出在局域网上广播的所有服务和设备。你应该能够看到虚拟机的服务(例如SSH服务)。

这就是在虚拟机中部署Avahi服务的基本步骤。请注意,具体的步骤可能会因系统的不同而有所不同。确保按照你虚拟机所使用的操作系统的相关文档进行适当的调整。

配置成功展示

测试成功

相关文章
|
12月前
|
应用服务中间件 网络安全 数据安全/隐私保护
网关服务器配置指南:实现自动DHCP地址分配、HTTP服务和SSH无密码登录。
哇哈哈,道具都准备好了,咱们的魔术秀就要开始了。现在,你的网关服务器已经魔法满满,自动分配IP,提供网页服务,SSH登录如入无人之境。而整个世界,只会知道效果,不会知道是你在幕后操控一切。这就是真正的数字世界魔法师,随手拈来,手到擒来。
569 14
|
Ubuntu Shell 网络安全
安装了ubuntu虚拟机后发现shell无法连接 ubuntu开启ssh连接
【8月更文挑战第23天】安装了ubuntu虚拟机后发现shell无法连接
2710 6
|
Ubuntu Linux 网络安全
在Linux云服务器上限制特定IP进行SSH远程连接的设置
温馨提示,修改iptables规则时要格外小心,否则可能导致无法远程访问你的服务器。最好在掌握足够技术知识和理解清楚操作含义之后再进行。另外,在已经配置了防火墙的情况下,例如ufw(Ubuntu Firewall)或firewalld,需要按照相应的防火墙的规则来设置。
675 24
|
JavaScript 应用服务中间件 Linux
【应用服务 App Service】解决无法从Azure门户SSH登录问题
【应用服务 App Service】解决无法从Azure门户SSH登录问题
418 0
|
域名解析 API PHP
VM虚拟机全版本网盘+免费本地网络穿透端口映射实时同步动态家庭IP教程
本文介绍了如何通过网络穿透技术让公网直接访问家庭电脑,充分发挥本地硬件性能。相比第三方服务受限于转发带宽,此方法利用自家宽带实现更高效率。文章详细讲解了端口映射教程,包括不同网络环境(仅光猫、光猫+路由器)下的设置步骤,并提供实时同步动态IP的两种方案:自建服务器或使用三方API接口。最后附上VM虚拟机全版本下载链接,便于用户在穿透后将服务运行于虚拟环境中,提升安全性与适用性。
1073 7
|
安全 网络安全 数据安全/隐私保护
Debian 12系统中允许Root远程SSH登录解决方法!
在 Debian 12 系统中开启 SSH 远程 Root 登录需修改 SSH 配置文件 (`sshd_config`),将 `PermitRootLogin` 设置为 `yes` 并确保密码认证启用。完成后重启 SSH 服务并验证连接。若防火墙启用,需放行端口 22。注意,直接开放 Root 登录可能带来安全风险,建议使用普通用户登录后切换至 Root。
2217 1
|
监控 Ubuntu 安全
debian或Ubuntu中开启ssh允许root远程ssh登录的方法
在Debian或Ubuntu系统中启用root用户的SSH远程登录需要编辑SSH配置文件、设置root密码并重启SSH服务。虽然这可以在某些情况下提供便利,但必须注意安全性,通过使用强密码、限制IP访问、使用SSH密钥认证等方法来保护服务器的安全。
7914 5
|
运维 网络安全
解决ssh: connect to host IP port 22: Connection timed out报错(scp传文件指定端口)
通过这些步骤和方法,您可以有效解决“ssh: connect to host IP port 22: Connection timed out”问题,并顺利使用 `scp`命令传输文件。
16032 7
|
网络协议 Ubuntu Linux
解决ssh: connect to host IP port 22: Connection timed out报错(scp传文件指定端口)
解决 `ssh: connect to host IP port 22: Connection timed out` 报错涉及检查 SSH 服务状态、防火墙配置、网络连通性和主机名解析等多个方面。通过逐步排查上述问题,并在 `scp` 命令中正确指定端口,可以有效解决连接超时的问题,确保文件传输的顺利进行。希望本文提供的解决方案能帮助您快速定位并解决该错误。
4112 3
|
网络安全 虚拟化 Docker
SSH后判断当前服务器是云主机、物理机、虚拟机、docker环境
结合上述方法,您可以对当前环境进行较为准确的判断。重要的是理解每种环境的特征,并通过系统的响应进行综合分析。如果在Docker容器内,通常会有明显的环境标志和受限的资源视图;而在云主机或虚拟机上,虽然它们也可能是虚拟化的,但通常提供更接近物理机的体验,且可通过硬件标识来识别虚拟化平台。物理机则直接反映硬件真实信息,较少有虚拟化痕迹。通过这些线索,您应该能够定位到您所处的环境类型。
1160 2