当前位置: 首页 > news >正文

VMware ESXi学习笔记

esxi网络模型:
物理网卡: 一般会有多个物理网卡,用于管理口和其他(vsan)

虚拟交换机:创建虚拟交换机时,会要求选择至少1个上行链路(物理网卡)

端口组:一般一个虚拟交换机会创建两个端口组,一个虚机使用,一个vmware使用,vmware使用的即内部数据和业务使用,需要创建vmkernel;
    每个端口组可以有自己的负载均衡策略,端口安全模式
    
vmkernel: 这个是针对每个esxi, vmware内部使用的端口组要求创建vmkernel,创建时会提示选择该vmkernel的使用场景,比如vsan
    可以在创建好端口组后,直接在端口组上添加vmkernel适配器,然后可以批量选择物理机,这样可以快速在每台物理机上创建vmkernel;
    通常虚机使用的端口组不需要vmkernel,而vmware使用的则需要,比如管理面、vsan等
    vmkernel适配器就是相当于虚拟网卡,可以配置IP
    
esxi安装好后默认会创建一个标准的虚拟交换机vSwitch0,包含两个端口组Manager Network和VM Network,默认创建一个vmk0(只勾选了管理),设置的IP就是给vmk0设置IP,
vmk0连接Manager Network端口组,进而连接到vSwitch0标准虚拟交换机上,通过物理口出去

通常通过vcenter管理esxi时,会将同一机架的esxi添加为一个集群(集群内的esxi一般都在同一子网,如果不是的话后续配置vsan等需要配置ip时会很麻烦),集群要求CPU型号一致,
同时将esxi的存储组建成vsan,另外会创建一个DVS(分布式交换机),添加两个端口组,一个用来给虚机使用,一个用来给宿主机内部使用,需要创建vmkernel(包含:vMotion、置备、vSphere Replication、vSphere Replication NFC、vSAN)


esxi虚机网络负载默认是根据虚机网卡的端口ID来的,这样就会导致某个时刻,物理网卡的负载不均衡,处理办法:
1、调整虚机配置,编辑虚机,将网口的连接和启动连接关闭,确认后再次编辑打开;
2、迁移虚机到其他宿主机
3、调整端口组的负载均衡策略,改成安装物理网卡的实际负载来执行

显示物理网卡信息
[root@localhost:~] esxcli network nic list
Name     PCI Device    Driver  Admin Status  Link Status  Speed  Duplex  MAC Address         MTU  Description
-------  ------------  ------  ------------  -----------  -----  ------  -----------------  ----  -----------
vmnic0   0000:1a:00.0  i40en   Up            Up           10000  Full    8c:2a:8e:08:9c:74  9000  Intel(R) Ethernet Connection X722 for 10GbE SFP+
vmnic1   0000:1a:00.1  i40en   Up            Up           10000  Full    8c:2a:8e:08:9c:75  9000  Intel(R) Ethernet Connection X722 for 10GbE SFP+

显示标准虚拟交换机:
[root@localhost:~] esxcli network vswitch standard list
vSwitch0
   Name: vSwitch0
   Class: cswitch
   Num Ports: 9216
   Used Ports: 4
   Configured Ports: 128
   MTU: 1500
   CDP Status: listen
   Beacon Enabled: false
   Beacon Interval: 1
   Beacon Threshold: 3
   Beacon Required By:
   Uplinks: vmnic2
   Portgroups: VM Network, Management Network
   
查询标准交换机端口组:
[root@localhost:~] esxcli network vswitch standard portgroup list
Name                Virtual Switch  Active Clients  VLAN ID
------------------  --------------  --------------  -------
Management Network  vSwitch0                     1        0
VM Network          vSwitch0                     1        0

   
显示分布式交换机:
[root@localhost:~] esxcli network vswitch dvs vmware list
DVSInfra
   Name: DVSInfra
   VDS ID: 50 32 c6 7b 2e d8 28 d9-61 62 b4 c0 b4 de 7e da
   Class: cswitch
   Num Ports: 3323
   Used Ports: 8
   Configured Ports: 512
   MTU: 9000
   CDP Status: listen
   Beacon Timeout: -1
   Uplinks: vmnic5, vmnic6
   VMware Branded: true
   DVPort:
         Client: vmnic5
         DVPortgroup ID: dvportgroup-4970
         In Use: true
         Port ID: 16

         Client: vmnic6
         DVPortgroup ID: dvportgroup-4970
         In Use: true
         Port ID: 17
注意,这里的Port ID其实是DVS Port ID,不能用来抓包;esxi上没有查询分布式端口组的命令
如果要抓包,则可以通过esxcli network vm list 命令显示的虚机world id,然后再通过esxcli network vm port list -w WORLDID,这个命令会显示Port ID和DVS Port ID


输入esxtop 再按n 可显示虚机的网络使用请求,里面有port num可用来抓包,跟net-stats -l显示的por num是一样的

查询当前vsan下不可访问的虚机
esxcli vsan debug object  list --health inaccessible

esxi上进行抓包:
pktcap-uw --vmk vmk0 --dir 2 --mac 00:50:56:bd:ff:f8 -e

指定物理网卡抓包
pktcap-uw --uplink vmnic0 --dir 2 --mac 00:50:56:bd:ff:f8

这里的PortNum可以用来抓包
pktcap-uw --dir 2 --switchport [PortNum/PortID]

显示esxi上所有活跃的端口信息
[root@localhost:~] net-stats -l
PortNum          Type SubType SwitchName       MACAddress         ClientName
2214592530          4       0 DvsPortset-0     8c:2a:8e:08:9c:74  vmnic0
2214592532          4       0 DvsPortset-0     8c:2a:8e:08:9c:75  vmnic1
67108887            3       0 DvsPortset-0     00:50:56:6f:ea:93  vmk1
67108929            5       7 DvsPortset-0     00:50:56:b2:c0:6c  centos_7.0-B0000(10.131.134.25).eth0
67109120            5       9 DvsPortset-0     00:50:56:b2:c5:57  HCI6.3.0-14201(10.131.136.195).eth5
67109121            5       9 DvsPortset-0     00:50:56:b2:2f:b3  HCI6.3.0-14201(10.131.136.195).eth4
67109122            5       9 DvsPortset-0     00:50:56:b2:fc:cd  HCI6.3.0-14201(10.131.136.195).eth3
67109123            5       9 DvsPortset-0     00:50:56:b2:88:97  HCI6.3.0-14201(10.131.136.195).eth2
67109124            5       9 DvsPortset-0     00:50:56:b2:57:40  HCI6.3.0-14201(10.131.136.195).eth1
67109125            5       9 DvsPortset-0     00:50:56:b2:49:40  HCI6.3.0-14201(10.131.136.195).eth0
67109126            5       7 DvsPortset-0     00:50:56:b2:02:f5  centos_8.0-12626(10.131.134.136).eth0

可以查看某个端口的网络统计信息
[root@localhost:~] esxcli network port stats get -p 67109168
Packet statistics for port 67109168
   Packets received: 105476160732
   Packets sent: 9582511311
   Bytes received: 3982297224
   Bytes sent: 25482787
   Broadcast packets received: 85681935373
   Broadcast packets sent: 62395482
   Multicast packets received: 8661218972
   Multicast packets sent: 8699038
   Unicast packets received: 11133006387
   Unicast packets sent: 9511416791
   Receive packets dropped: 1459543
   Transmit packets dropped: 372

相关文章:

VMware ESXi学习笔记

esxi网络模型: 物理网卡: 一般会有多个物理网卡,用于管理口和其他(vsan) 虚拟交换机:创建虚拟交换机时,会要求选择至少1个上行链路(物理网卡) 端口组:一般一个虚拟交换机会创建两个端口组,一个虚机使用&a…...

Python 函数(2)

2、函数 2.1、函数传递列表 将列表传递给函数后,函数就能直接访问其内容。 下列为一个实例:将一个名字列表传递给一个名为greet_users()的函数,这个函数将会向列表中的每一个元素执行相应的信息。 def greet_users(name):for name in name…...

c++文件的读写

平常我们在编完代码后,基本都是从键盘输入,从屏幕输出(显示),但可不可以从其他地方输入输出呢? ………………………………………………………………………………………………………………… 其实可以&…...

春秋云境 | 文件上传 | CVE-2022-30887

目录 靶标介绍 开启靶场 上传一句话木马 蚁剑连接 找到 flag 靶标介绍 多语言药房管理系统 (MPMS) 是用 PHP 和 MySQL 开发的, 该软件的主要目的是在药房和客户之间提供一套接口,客户是该软件的主要用户。该软件有助于为药房业务创建一个综合数据库&#xff0…...

大模型+XDR!打开网络安全攻防演练新范式!

网络安全领域面临着日益复杂的挑战,外部攻击与内部安全威胁交织的双重压力。技术革新成为筑牢安全防线的关键,随着新一代技术的崛起,特别是大数据与人工智能的深度融合,引领着网络安全进入全新阶段。 通过构建网络安全大模型&…...

C语言----字符串

字符串 第一种定义 利用字符数组 双引号的方式定义字符串 char str1[4]"abc"; printf("%s\n",str1); 细节1: 在底层,实际存储的时候,c语言还是会帮我们把字符串"abc"转换成字符数组进行保存,并且在末尾还…...

ThreadLocal 详解(三)内存泄露原因,以及强弱引用

1、ThreadLocal内存泄漏 在Threadlocal的内部静态类中Entry将Threadlocal作为一个key,值作为value保存,他继承WeakReference,super(k),代表了Threadlocal对象是一个弱引用; static class Entry extends WeakReference…...

【Android面试八股文】说一说Android开发模式之MVC、MVP、MVVM的区别?

文章目录 一、 MVC(Model-View-Controller)二、 MVP(Model-View-Presenter)三、MVVM(Model-View-ViewModel)四、示例代码4.1. MVC 示例4.2. MVP 示例4.3. MVVM 示例五、总结在Android开发中, MVC(Model-View-Controller)MVP(Model-View-Presenter)MVVM(Model-View-…...

多叉树的深度优先遍历(以电话号码的字母组合为例)

在我们的座机上,都有这种数字与字母对应的按键。 以此为例,讲解多叉树的深度优先遍历 问题 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同…...

【YashanDB数据库】PHP无法通过ODBC连接到数据库

【问题分类】驱动使用 【关键字】ODBC、驱动使用、PHP 【问题描述】应用使用php-fpmnginx架构,通过php的ODBC拓展连接YashanDB时出现报错: [unixODBC][Driver Manager]Cant open lib /home/yashandb_odbc/libyas_odbc.so: file not found但是在应用所…...

C++ | Leetcode C++题解之第326题3的幂

题目: 题解: class Solution { public:bool isPowerOfThree(int n) {return n > 0 && 1162261467 % n 0;} };...

Ubuntu20.4上搭建FFMPEG开发环境

编译ffmpeg命令如下: 1.安装yasm(ffmpeg里面有汇编语言的部分,所以需要安装一下yasm) wget 5http://www.tortall.net/projects/yasm/releases/yasm-1.3.0.tar.gz tar xvzf yasm-1.3.0.tar.gz cd yasm-1.3.0 ./configure make && make install 2.安装nasm(2.13以上…...

谷粒商城实战笔记-144-性能压测-性能监控-堆内存与垃圾回收

文章目录 一,两种类型的应用1,CPU密集型应用示例:Apache Spark 2,IO密集型应用示例:MySQL 二,监控 我们通过压力测试对接口进行了性能评估,以确定其是否满足性能要求。 如果不符合,就…...

大模型综述

《Harnessing the Power of LLMs in Practice: A Survey on ChatGPT and Beyond》论文阅读 模型架构 两种架构: encoder-decoder架构/encoder架构:T5/BERTdecoder架构:GPT4 特点LLMsencoder-decoderorencoder-onlyBERT-style训练:掩码语言模型类型:…...

Python 常用内置函数

目录 1、enumerate函数 1.1、for循环中使用 1.2、enumerate指定索引的起始值 1.3、enumerate在线程中的作用 2、Map 函数 2.1、map()函数可以传多个迭代器对象 3、lambda表达式(匿名函数) 示例 4、sort函数和sorted函数 4.1、sort()函数 4.2、…...

什么是大数据?

1. 大数据定义 大数据到底是什么? 大数据的定义是数据种类更多、数量更多、速度更快。这也被称为三个“V”。 简单来说,大数据是更大、更复杂的数据集,尤其是来自新数据源的数据集。这些数据集非常庞大,传统数据处理软件根本无…...

Linux 内核源码分析---资源分配及系统总线

资源管理 Linux提供通用的构架,用于在内存中构建数据结构。这些结构描述了系统中可用的资源,使得内核代码能够管理和分配资源。 其中关键的数据结构resource如下: 用于连接parent, child, sibling成员规则如下: 1、每个子结点只…...

C# POST请求 各种实现方法梳理

目录 1.首先是基础的参数 2.使用RestClient 3.使用封装库 4.使用微软原生库进行请求 5.使用HttpClient进行请求 C#代码中,实现Http/Https 中的POST请求,可以有很多种方式,下面就梳理下我常用的几种方式,给大家借鉴 1.首先…...

《MySQL数据库》数据导入、导出、表处理—/—<4>

一、插入数据 1、可使用外部工具navicat导入数据的情况下 因为部分公司不允许使用外部工具去导入数据 对于大批量数据,除了上节课中使用导入向导插入数据,也可在vscode中打开csv文件,然后选中光标,长按shiftctrl,拖动…...

Java I/O (Input/Output)——文件字节流

博客主页:誓则盟约系列专栏:Java SE 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ Java I/O 简介 Java I/O(输入/输出)是 Java 程序中…...

web vue 项目 Docker化部署

Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage)&#xff1a…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

遍历 Map 类型集合的方法汇总

1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

Docker 运行 Kafka 带 SASL 认证教程

Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...

前端导出带有合并单元格的列表

// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...

HTML 列表、表格、表单

1 列表标签 作用:布局内容排列整齐的区域 列表分类:无序列表、有序列表、定义列表。 例如: 1.1 无序列表 标签:ul 嵌套 li,ul是无序列表,li是列表条目。 注意事项: ul 标签里面只能包裹 li…...

抖音增长新引擎:品融电商,一站式全案代运营领跑者

抖音增长新引擎:品融电商,一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中,品牌如何破浪前行?自建团队成本高、效果难控;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...

在WSL2的Ubuntu镜像中安装Docker

Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...