Debian、kali类虚拟机网络设置
Linux发行版分类
先说一下Linux发行版的分类,因为不同的发行版,各自设置的网络的方式就不相同,
- 我常用的Linux发行版
-- Debian
--- debian
--- ubuntu
--- kali
-- Red Hat
--- cent OS
-- Other
--- Arch Linux
为了追求准确性,如下文章就是针对Debian分支来讲解的网络设置。
NAT模式
NAT模式的原理
网络拓扑图
本来网络访问的流程是路由器发送数据到路由器,比如家里的路由器里面有192.168.1.100、192.168.1.101两台机器,向外部的路由器发送数据,数据包会标记上路由出口是113.113.113.113的192.168.1.100发送的,响应包也按照这个记录返回到100机器。但是如果用NAT模式,100、101虚拟机直接把宿主机当成路由器发送流量出去,数据包会标记上路由出口是113.113.113.113的100发送的(100的数据是加密过的,只有NAT能知道怎么返回),这样能发送出去,也能接收回来,但是没有记录到那台虚拟机器了。因为只记录到路由节点。
优势
- NAT模式最大的优势是虚拟系统接入互联网非常简单,只需要宿主机器能访问互联网,虚拟机就能上网。你不需要配置IP地址,子网掩码,网关,DNS(有时DNS地址还是要根据实际情况填的)等网络配置文件。
缺点
- 但是它的缺点也很明显,虚拟机无法和本局域网中的其他真实主机进行通讯,包括和宿主机ping。他只能ping外网的主机。
- Kali一些场景就是用来搞内网渗透,都不能ping局域网其他机器,那搞个毛线呀,果断要放弃这个模式,采用桥接模式。
- 如果你溯源的时候听到,溯源目标的局域网是采用NAT出口流量的,那么也意味着,即使你监控到局域网里面一台主机不断和恶意站点连接,你也无法通过网络的方式找到具体是那一台机器,只能换其他方式找。
设置NAT
设置网络为NAT模式,大部分虚拟机安装的时候默认都是使用NAT模式,
Bridged(桥接)模式
Bridged模式的原理
网络拓扑图
桥接模式,虚机机就是局域网中的一台独立的主机,它可以访问局域网内的任何一台机器,也能访问外网。主机网卡和虚拟网卡的IP地址处于同一个网段,子网掩码、网关、DNS等参数都相同(这些都得自己去配置)。
这种方式是直接将虚拟网卡(VMnet0)桥接到一个物理网卡上面,所以称为桥接。由于他相当于是一块真实网卡了,那就会有mac,如果所在的网络环境入网是要绑定mac的话,那么会有一定麻烦性。
Bridged模式设置步骤
打开虚拟网络编辑器
自动网卡
选择VMnet0 虚拟设备
自定义网卡
如果自动网卡不行,就试试自定义网卡。
桥接模式的静态、动态IP设置
静态
vim /etc/network/interfaces
auto eth0
iface eth0 inet static
address 192.168.1.5
netmask 255.255.255.0
gateway 192.168.1.254
# 注意,子网掩码和网关必须和宿主机的一致,ip不能和局域网已有的ip相同
# 重启网卡,右上角会出现断开网络的图标
/etc/init.d/network-manager restart
如果重启网卡失效,尝试重启机器。
动态
动态就是设置成DHCP,动态获取路由分配的ip,要是设置静态ip不好使,就试试用动态方式。
vim /etc/network/interfaces
auto eth0
iface eth0 inet dhcp
# 重启网卡,右上角会出现断开网络的图标
/etc/init.d/network-manager restart
如果重启网卡失效,尝试重启机器。
家里路由、公司路由的认证区别
如果遇到用桥接模式设置完后,不了外网(nat模式不受影响)。确认网络文件的配置都正确,虚拟机和宿主机能ping通(不通则需要关闭物理机与虚拟机的防火墙),虚拟机依旧ping不通www.baidu.com的情况。
一般是因为公司对入网设备有上网权限的认证,桥接模式下虚拟机网络与物理机用的同一个网卡,但是虚拟机用的虚拟网卡的mac是和宿主机不同的,即使你修改相同,公司路由也不会让第二个相同mac入网。只要虚拟机的mac地址未通过认证,就没有入网的权限。
简单的说就是,家里路由器的认证方式比较宽泛,只要有拨号认证就行了。但是企业路由需要输入账号密码确认后,绑定mac,没有绑定mac的是不允许入网的,桥接模式其实就是模拟了一块物理网卡,生成了新mac,这个网卡没有通过认证肯定是进不了企业网的。
解决方式就是生成虚拟机网卡mac后,找负责网络同事将虚拟机网卡的mac地址提供给他,让他加入公司内网使用权限内,就可以了。
参考文章:
https://blog.csdn.net/myuhua/article/details/99441927
桥接模式中用connman连接wifi的尝试
就是一直报错说没有.service files ,搜了一下google没有解决,感觉在虚拟机上弄网络,需要对网络有一定了解,不然容易卡在某个步骤上 没有解决思路,我建议是买块usb硬盘,直接上真机吧。
Host-only(仅主机模式)模式
网络拓扑图
在 Host-Only 模式下,虚拟网络是一个全封闭的网络,它唯一能够访问的就是主机。其实 Host-Only 网络和 NAT 网络很相似,不同的地方就是 Host-Only 网络没有 NAT 服务,所以虚拟网络不能连接到 Internet 。主机和虚拟机之间的通信是通过 VMware Network Adepter VMnet1 虚拟网卡来实现的。
这个模式一般人都用不到,先忽略。
Debian、kali类虚拟机网络设置的更多相关文章
- VirtualBox虚拟机网络设置
VirtualBox虚拟机网络设置 测试环境:物理机win10企业版本,VirtaulBox版本5.0.14,虚拟机安装Windows XP及linux系统 想实现虚拟机上网的最简单方式,修改虚拟机网 ...
- virtualbox 虚拟机网络设置
1.宿主机网卡设置 virtualbox 第一块网卡设置 virtualbox第二块网卡设置 2.虚拟机网络设置 找到以上设置中MAC地址对应的那个网卡: 配置网络: 重启网络,ok.
- linux虚拟机网络设置(本机使用wiff,自己的网)
一.linux虚拟机网络设置(https://jingyan.baidu.com/album/4e5b3e1957979d91901e24f1.html?picindex=16) 选中虚拟机,点击 ...
- 虚拟机网络设置(NAT模式)
虚拟机网络设置(NAT模式) linux 1. 设置虚拟机网络 1.1. NAT子网设置 1.2. 网卡配置文件设置 1.3. 重启网络服务 1.4. 配置端口转发 2. 配置网络共享 预期想要搭建本 ...
- Linux虚拟机网络设置问题
使用的是VM 工作站15 和以前的不一样 没有什么虚拟机网络设置 :打开Edit->Virtual NetWork editor, 选中VMnet8,然后点击NAT Setting按钮,再点击D ...
- linux笔记:linux系统安装-虚拟机网络设置
vmware虚拟机网络配置的3种方式: 1.桥接:在桥接模式下,VMWare虚拟出来的操作系统就像是局域网中的一台独立的主机(主机和虚拟机处于对等地位),它可以访问网内任何一台机器.在桥接模式下,我们 ...
- VMware虚拟机网络设置
背景介绍 在用 VMware workstation 安装好虚拟机后,需要给虚拟机配置网络,配置网络的方法有桥接.NAT. 采用桥接的方法需要占据物理机网段的ip地址,可能会与物理机同一网段的其 ...
- [web] 虚拟机网络设置
三种模式 桥接(Bridged):主机网卡--虚拟网桥--虚拟机网卡,把主机虚拟为交换机,虚拟机ip需与主机设置在同一网段,网关与DNS与主机网卡一致 地址转换(NAT):主机网卡--虚拟NAT设备- ...
- VirtualBox Linux虚拟机 网络设置 centos
VirtualBox网络设置成桥接 进去系统打开终端 vi /etc/sysconfig/network-scripts/ifcfg-enp0s3 用Vim编辑器打开配置文件,输入命令:vi /etc ...
随机推荐
- 浏览器自动化的一些体会6 增强的webBrowser控件
这里谈两点 1.支持代理服务器切换 一种方法是修改注册表,不是太好的做法,而且,只能改全局设置,不能改局部(比如只让当前的webBrowser控件使用代理,而其他应用不用代理) 另外一个较好的方法,示 ...
- Kubernetes实战总结 - 自定义Prometheus
一.概述 首先Prometheus整体监控结构略微复杂,一个个部署并不简单.另外监控Kubernetes就需要访问内部数据,必定需要进行认证.鉴权.准入控制, 那么这一整套下来将变得难上加难,而且还需 ...
- python3 - selenium常用的参数
# 选用开发者模式,创建一个浏览器对象,可避免被检测到是selenium模拟浏览器 chrome_options = webdriver.ChromeOptions() chrome_options ...
- Spring中眼花缭乱的BeanDefinition
本篇博客主要参考:Spring官网阅读(四)BeanDefinition(上) 引入主题 为什么要读Spring源码,有的人为了学习Spring中的先进思想,也有的人是为了更好的理解设计模式,当然也有 ...
- Oracle 根据单元格内容不同来判断不同条件
select xxx,xxx from xxx where decode(AAA,0,BBB,1,CCC)='12345' 如果AAA字段等于0则AAA=''12345' 否则如果BBB字段等于1则B ...
- jvm之方法内联优化
前言 在日常中工作中,我们时不时会代码进行一些优化,比如用新的算法,简化计算逻辑,减少计算量等.对于java程序来说,除了开发者本身对代码优化之外,还有一个"人"也在背后默默的优化 ...
- ubuntu 下添加环境变量
ubuntu 下添加环境变量 方法1: 第一种临时设置,用 export 指令,如在$PATH中增加JAVA文件夹: $export PATH=$PATH:/usr/local/lib/jdk1.6. ...
- 分享一个关于Cookie做的实验结果
实验本身是很枯燥的,我尽量把它讲的有趣些. 起因 去网上搜了下关于Cookie的介绍,看了好几篇都长得很一样,阉割一下内容不外乎说是"不同浏览器限制cookie数不同,大致在30-50这个范 ...
- route和过滤器的基础知识
过滤器 1.局部过滤器 在当前组件内部使用过滤器(对某些数据进行装饰) //声明 filters:{ '过滤器的名字':function(val,a,b){ //a 就是will ,val就是当前的数 ...
- json对象遍历顺序问题
对json对象遍历我们一般使用for in循环,或者Object.keys + 数组方法.在接触js以来听到过一种说法: for in 遍历顺序是不可靠的 但是在实际开发中for in 循环也是按照其 ...