带你读《Istio入门与实战》之三:使用Vagrant管理虚拟机

简介: 本书系统化介绍Istio技术要点与应用技巧,可帮助读者快速搭建微服务架构并进行管理。主要内容包括:service mesh基本概念与使用,Istio架构设计与主要功能,快速搭建一个微服务实验,介绍如何让服务流量控制更简单,让服务更具弹性,让服务故障测试更容易,让服务通信更安全可控,让服务更易观测与监控,以及istio维护方案。本书内容丰富、案例讲解,实用性强,非常适合入门级读者快速掌握Istio技术。

点击查看第一章
点击查看第二章

第3章

使用Vagrant管理虚拟机
本章主要介绍如何使用Vagrant管理虚拟机,为了保持实验环境的一致性,并能快速创建恢复实验环境,本章会介绍Vagrant的简单使用方式,并模拟实验时的操作步骤来使用Vagrant。借助Vagrant,我们可以更方便地管理Istio实验环境,这种快速创建实验环境的能力大大地减少了我们实验前的环境准备时间。

3.1 Vagrant简介

Vagrant是一款用于构建及配置管理虚拟机环境的开源软件,使用Ruby语言开发,主要以命令行的方式运行。Vagrant使用Oracle的开源VirtualBox虚拟化系统,与Chef、Salt、Puppet等环境配置管理软件搭配使用,使用方便且自动化程度很高。使用Vagrant可以快速构建出虚拟机环境,这将大大降低开发者创建新开发环境的难度,并减少开发时间。Vagrant还支持创建虚拟机集群,可以快速搭建出一个用于开发和实验的虚拟机集群环境。虽然Vagrant可用于云环境的虚拟机管理,但是生产环境应用不多,仍以开发环境使用场景居多。
使用Vagrant很简单,只需要配置好文件,就可以快速重建出一个可移植的工作环境,而这个功能正好可以帮助我们快速重建出一个虚拟机实现环境,帮助我们快速上手Istio,而不用于陷于实验前期的环境准备过程中可能遇到的各种棘手问题。基于这个理由,本书选择了使用Vagrant和Virtualbox快速搭建实验环境。当然,如果你对Vagrant感兴趣,想进一步了解Vagrant的使用方法,可以查阅Vagrant的官方文档。

3.2 Vagrant常用命令

注意事项:由于默认情况下,Vagrant会把临时文件和Box文件存放在用户主目录里。如果Box文件过大,会导致占用过大空间,可以通过设置环境变量VAGRANT_HOME来设定Vagrant的主目录路径。Vagrant默认设置的主目录为用户主目录的.vagrant.d文件夹。本次实验时把此环境变量设置为D:vagranthome,关于各个操作系统的环境变量的设置,请查阅相关文档。
1. 基本命令
基础命令总览:

  • box add:导入box
  • box list:查看box
  • box remove:删除box
  • init:初始化
  • up:启动
  • status:查看状态
  • ssh:SSH连接
  • reload:重载
  • halt:关闭
  • suspend:暂停
  • destroy:删除

下面举例说明这些命令的使用方法。
(1)导入Box
导入已经下载的Box命令如下:

image.png

/f/vagrant/box/centos-7.4-base.box表示Box的路径地址,这是由于使用了Git Bash的路径表示方法。如果使用CMD命令行,使用F:/vagrant/box/centos-7.4-base.box即可。此处使用的Box从第2章“实验说明”中提供的百度云盘链接上下载。
(2)查看Box
查看可用的Box如下所示:

image.png

(3)删除Box
删除不再使用的Box如下所示:

image.png

(4)初始化
初始化虚拟机如下所示:

image.png

查看未被注释配置文件内容:

image.png

(5)启动
启动虚拟机如下所示:

image.png
image.png

(6)查看状态
查看虚拟机状态如下所示:

image.png

(7)SSH连接
注意,如果Windows下使用Git Bash时无法使用SSH连接虚拟机,可以尝试使用系统自己带的命令行工具CMD连接虚拟机:

image.png
image.png

(8)重新
当我们编辑当前文件夹下的虚拟机配置文件Vagrantfile后,可以使用reload命令重载虚拟机,使配置生效。比如添加设置主机名的配置:

image.png

重载使配置文件生效:

image.png
image.png

(9)关闭
关闭虚拟机如下所示:

image.png

(10)暂停
由于上一步骤关闭虚拟机,执行本步骤时需要先启动虚拟机,然后再暂停虚拟机:

image.png

(11)删除
删除虚拟机的命令如下所示:

image.png

  1. 使用虚拟机快照命令
    虚拟机快照命令如下:
  • save:保存虚拟机快照。
  • list:查看虚拟机快照。
  • restore:用快照恢复虚拟机。
  • delete:删除虚拟机快照。

进行如下快照的相关操作时,需要先创建虚拟机并启动虚拟机。
保存虚拟机快照示例:

image.png

查看虚拟机快照示例:

image.png

用快照恢复虚拟机示例:

image.png
image.png

删除虚拟机快照示例:

image.png

3.3 模拟实验时的场景

由于后续实验时使用三台虚拟机进行实验,在实验时,不可避免地会使用Vagrant管理虚拟机环境,包括初始化创建虚拟机,启动虚拟机,连接并登录到虚拟机环境,保存实验环境,以及快速恢复实验环境等。本节会模拟后续实验场景用到的步骤,方便你熟悉整个实验环境管理的流程。
1. 初始化虚拟机集群
(1)创建虚拟机配置文件
创建名为istio的目录,并把如下的配置文件写入istio目录的Vagrantfile文件:

image.png
image.png

第5行表示创建三台虚拟机。
第7行表示使用名为"centos-7.4-base"的box。
第9行表示不自动生成新的ssh key,使用Vagrant默认的ssh key注入到虚拟机中,这么做主要是为了方便登录。不用为每台虚拟机设置ssh key登录。
第10行设置3台虚拟机主机名分别为lab1、lab2、lab3。
第12行设置3台虚拟机的私有网络为11.11.11.111、11.11.11.112、11.11.11.113。
第14~15行表示当虚拟机启动完成之后,执行inline中配置的shell命令,此命令用于开机之后的时间同步。
第17~18行表示当虚拟机启动完成之后,执行inline中配置的shell命令,此命令用于输出测试字符串。
第21~22行设置虚拟机的CPU核心数和内存大小,本次实验设置为每台虚拟机2核2G内存,可以根据自己电脑的实际情况适当加大。
上面的虚拟机集群配置文件,也是我们后续实验时所使用的虚拟机环境配置文件。
(2)启动虚拟机集群
如果启动不成功,请调整上一步骤中配置文件时CPU和Memery相关的配置。还需要确保虚拟机目录D:virtualbox中没有和此次实验中创建的同名的虚拟机目录(lab1、lab2、lab3)存在。代码如下:

image.png
image.png

(3)查看虚拟机状态
代码如下:

image.png

2. 连接虚拟机集群
1)使用Xshell导入vagrant的密钥。密钥存储在VAGRANT_HOME环境变量里指定目录的insecure_private_key文件中,添加该密钥到Xshell中。选择顶部菜单中“工具”菜单的“用户密钥管理者”,在弹出的对话框中点击“导入”按钮,选择insecure_private_key文件即可完成密钥的导入,如图3-1所示。
2)使用Xshell创建新的会话。
选择顶部菜单中“文件”菜单的“新建”,创建连接到三台虚拟机的会话。实验中配置的三台虚拟机IP地址分别为11.11.11.111、11.11.11.112、11.11.11.113,ssh端口为22,如图3-2所示。

image.png

image.png

认证方式选择Public Key,用户名为vagrant,用户密钥选择insecure_private_key,如图3-3所示。

image.png

3)Xshell连接测试。
测试结果如下所示,表明实验环境创建正确,可以在Xshell继续添加lab2、lab3虚拟机的SSH连接。
image.png
image.png

3. 暂停实验环境虚拟机
当我们的实验进行到一定步骤后,可能需要暂停,换个时间再次进行实验。这个时候我们可以直接暂停整个实验环境中的所有虚拟机,等下次再进行实验时,直接恢复之前的环境即可,非常方便。
暂停集群中所有虚拟机如下所示:
image.png

暂停集群中单个虚拟机如下所示:
image.png

恢复集群中所有虚拟机如下所示:
image.png
image.png

恢复集群中单个虚拟机,使用resume和up都能恢复暂停的虚拟机:
image.png

4. 保存与恢复实验环境
完成前面的步骤后,我们的实验虚拟机环境就已经基本搭建完成了。之后我们可以安装Docker、Git、Wget等基础软件。安装之后保存实验环境,之后实验不成功或者实验环境被污染,可以快速恢复到当前的实验环境。
保存集群中所有虚拟机快照:
image.png

保存集群中单个虚拟机快照:
image.png

删除集群中所有虚拟机快照:
image.png

删除集群中单个虚拟机快照:
image.png

查看集群中所有虚拟机快照:
image.png

查看集群中单个虚拟机快照:
image.png

恢复集群中所有虚拟机快照:
image.png

恢复集群中单个虚拟机快照:
image.png
image.png

在使用Vagrant时,可能会出现偶发的异常错误,大部分情况下,重启电脑即可解决。

3.4 本章小结

通过使用Vagrant,我们可以更快速地创建Istio的实验环境,这将大大节省我们创建实验环境的时间。当我们的实验环境被污染时,也可以使用Vagrant快速恢复到之前的实验环境,这也使得我们可以重复验证Istio功能,并节省了重复准备实验环境的时间,大大提升了实验效率。

相关文章
|
8月前
|
存储 运维 API
云计算中的虚拟机管理
云计算中的虚拟机管理
150 0
|
8月前
|
监控 Oracle Java
《深入浅出Java虚拟机 — JVM原理与实战》带你攻克技术盲区,探索各大JVM虚拟机特色 —— JVM故障排除指南(先导篇)
《深入浅出Java虚拟机 — JVM原理与实战》带你攻克技术盲区,探索各大JVM虚拟机特色 —— JVM故障排除指南(先导篇)
129 0
|
1月前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
7月前
|
监控 Java 调度
探秘Java虚拟机(JVM)性能调优:技术要点与实战策略
【6月更文挑战第30天】**探索JVM性能调优:**关注堆内存配置(Xms, Xmx, XX:NewRatio, XX:SurvivorRatio),选择适合的垃圾收集器(如Parallel, CMS, G1),利用jstat, jmap等工具诊断,解决Full GC问题,实战中结合MAT分析内存泄露。调优是平衡内存占用、延迟和吞吐量的艺术,借助VisualVM等工具提升系统在高负载下的稳定性与效率。
113 1
|
6月前
|
缓存 监控 Java
Java虚拟机(JVM)性能调优实战指南
在追求软件开发卓越的征途中,Java虚拟机(JVM)性能调优是一个不可或缺的环节。本文将通过具体的数据和案例,深入探讨JVM性能调优的理论基础与实践技巧,旨在为广大Java开发者提供一套系统化的性能优化方案。文章首先剖析了JVM内存管理机制的工作原理,然后通过对比分析不同垃圾收集器的适用场景及性能表现,为读者揭示了选择合适垃圾回收策略的数据支持。接下来,结合线程管理和JIT编译优化等高级话题,文章详细阐述了如何利用现代JVM提供的丰富工具进行问题诊断和性能监控。最后,通过实际案例分析,展示了性能调优过程中可能遇到的挑战及应对策略,确保读者能够将理论运用于实践,有效提升Java应用的性能。 【
224 10
|
7月前
|
存储 Java C++
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据,如局部变量和操作数;本地方法栈支持native方法;堆存放所有线程的对象实例,由垃圾回收管理;方法区(在Java 8后变为元空间)存储类信息和常量;运行时常量池是方法区一部分,保存符号引用和常量;直接内存非JVM规范定义,手动管理,通过Buffer类使用。Java 8后,永久代被元空间取代,G1成为默认GC。
72 2
|
8月前
|
Oracle Java Serverless
JVM工作原理与实战(三十六):GraalVM虚拟机
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了GraalVM、GraalVM的两种运行模式、GraalVM应用场景、参数优化和故障诊断等内容。
388 1
|
8月前
|
分布式计算 大数据 Hadoop
【经验分享】用Linux脚本管理虚拟机下的大数据服务
【经验分享】用Linux脚本管理虚拟机下的大数据服务
66 1
|
8月前
|
存储 监控 安全
JVM工作原理与实战(十六):运行时数据区-Java虚拟机栈
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了运行时数据区、Java虚拟机栈等内容。
61 0
|
8月前
|
XML 数据格式
virsh一个管理虚拟机的命令行工具
virsh是一个管理虚拟机的命令行工具,提供了丰富的命令来查看、创建、管理虚拟机。以下是一些常用的virsh命令: 1. **查看帮助和版本**: - `virsh --help`:查看virsh命令的帮助信息。 - `virsh -version`:查看virsh的版本信息。 2. **查看虚拟机**: - `virsh list`:显示当前正在运行的虚拟机。 - `virsh list --all`:显示主机下的所有虚拟机,包括未运行的。 3. **创建和管理虚拟机**: - `virsh define xml`:使用XML文件定义(创建)虚拟机。
363 0