Multipass 是由Ubuntu官方提供,在Linux,MacOS和Windows上快速生成 Ubuntu虚拟机 的工具。它提供了一个简单但功能强大的CLI,可让我们在本地快速进入Ubuntu系统环境并使用Linux命令,亦可以在本地计算机创建自己的迷你型云服务器。总的来说就是在本地创建Ubuntu虚拟机,可以获得云端Ubuntu服务器般的体验。
Multipass在Windows上使用Hyper-V,在MacOS上使用Hyperkit,在Linux上使用LXD,以达到用最小的开销和最快的启动时间来进行虚拟机的创建,进而在不同平台提供统一的 Linux 开发环境体验。
Multipass 提供了一个命令行界面来启动和管理 Linux 实例,根据镜像创建实例,在本地已有实例的情况下,实例的启动仅需要数十秒的时间。
无论是Windows,还是MacOS、Linux,都可以在本地通过Multipass创建一个类服务器般体验的Linux系统,我们可以在Ubuntu实例系统中安装nginx、redis、kafka、k8s等软件,进而在本地体验、学习、开发、验证Linux服务器的相关内容。
Multipass官网:https://multipass.run/
以下内容在两台Mac上实践,各例中的VM实例参数略有不同。
# 安装
$ brew install --cask multipass
# 卸载
$ brew uninstall multipass
# 卸载并删除数据
$ brew uninstall --zap multipass
(base) ➜ ~ multipass version
multipass 1.10.1+mac
multipassd 1.10.1+mac
(base) ➜ ~ multipass find
Image Aliases Version Description
snapcraft:core18 18.04 20201111 Snapcraft builder for Core 18
snapcraft:core20 20.04 20210921 Snapcraft builder for Core 20
snapcraft:core22 22.04 20220426 Snapcraft builder for Core 22
18.04 bionic 20221014 Ubuntu 18.04 LTS
... ... ...
⚠️ 可以指定镜像别名 和 实例别名
根据上一步multipass find的结果,我们使用18.04版本的镜像,其别名为bionic,创建后的实例我们命名为d1804
(base) ➜ ~ multipass launch bionic --name d1804
Launched: d1804
不指定镜像会随机选择镜像创建。同样,不指定实例别名也会随机命名。
实例创建后默认启动,即running状态。
创建实例时可以附加的参数如下:
(base) ➜ ~ multipass launch bionic --name d1804 --cpus 4 --disk 20G --mem 8G
(base) ➜ ~ multipass list
Name State IPv4 Image
d1804 Running 192.168.64.3 Ubuntu 18.04 LTS
列表中会展示各实例的本地局域网IP地址,可以把该地址当作远程服务器的地址,进而实现本地VM实例模拟远程服务器的结果,同时可以在VM实例中安装MySQL、Redis等软件,当作本地开发的云端服务。
(base) ➜ ~ multipass info d1804
Name: d1804
State: Running
IPv4: 192.168.64.3
Release: Ubuntu 18.04.6 LTS
Image hash: 5269cad5bc26 (Ubuntu 18.04 LTS)
Load: 0.00 0.06 0.06
Disk usage: 1.1G out of 4.7G
Memory usage: 73.5M out of 985.6M
Mounts: --
关闭
(base) ➜ ~ multipass stop d1804
(base) ➜ ~ multipass list
Name State IPv4 Image
d1804 Stopped -- Ubuntu 18.04 LTS
启动
(base) ➜ ~ multipass start d1804
(base) ➜ ~ multipass list
Name State IPv4 Image
d1804 Running 192.168.64.3 Ubuntu 18.04 LTS
重启
(base) ➜ ~ multipass restart d1804
Restarting d1804 ...
补充:--all参数
(base) ➜ ~ multipass start --all # 启动所有实例
(base) ➜ ~ multipass stop --all # 关闭所有实例
(base) ➜ ~ multipass shell d1804
Welcome to Ubuntu 18.04.6 LTS (GNU/Linux 4.15.0-194-generic x86_64)
* Documentation: https://help.ubuntu.com
* Management: https://landscape.canonical.com
* Support: https://ubuntu.com/advantage
System information as of Sat Nov 5 18:56:38 CST 2022
... ...
... ...
此时列表还显示被删除的实例
(base) ➜ ~ multipass delete foo
(base) ➜ ~ multipass list
Name State IPv4 Image
d1804 Running 192.168.64.3 Ubuntu 18.04 LTS
foo Deleted -- Not Available
恢复被删除的实例:
$ multipass recover foo
关键命令:multipass purge [instances...],采用纯净模式删除的实例不可恢复。
(base) ➜ ~ multipass delete foo
(base) ➜ ~ multipass purge
(base) ➜ ~ multipass list
Name State IPv4 Image
d1804 Running 192.168.64.3 Ubuntu 18.04 LTS
或者,一步到位
(base) ➜ ~ multipass delete --purge foo
不需要进入实例的shell交互环境就可以执行实例内部命令,但需要目标实例处于running状态,如果没有处于running状态,会先启动再执行相关命令。
(base) ➜ ~ multipass exec d1804 -- pwd
/home/ubuntu
⚠️ 实例别名后的 -- 后面要跟空格,之后再输入命令
mount命令是官方推荐的文件共享方式。
➜ ls
Photos Library.photoslibrary ishot u=60941161,499456713&fm=26&fmt=auto&gp=0.png
bizhi mail_img
img pokerking-full-logo.png
➜ multipass mount bizhi d1804
➜ multipass info d1804
Name: d1804
State: Running
IPv4: 192.168.64.2
Release: Ubuntu 18.04.6 LTS
Image hash: 5269cad5bc26 (Ubuntu 18.04 LTS)
Load: 0.06 0.09 0.03
Disk usage: 1.2G out of 9.5G
Memory usage: 119.4M out of 985.6M
Mounts: /Users/admin/Pictures/bizhi => /Users/admin/Pictures/bizhi
UID map: 501:default
GID map: 20:default
可以看出,根据本地bizhi文件夹的路径,multipass在实例里面建立了同名路径的映射,此后双方任意方对该文件夹进行变动,都会同步至另一方。
取消共享:
$ multipass umount d1804
transfer的作用就是从一端复制文件到另一端,可以是本地复制到一个实例里,也可以是从一个实例复制到另一个实例里,也可以是从实例复制到本地。
⚠️ 同步的数据,后续变动双方互不影响。
从宿主机传送到Multipass实例中:
# mac本地键入
➜ ls
pokerking-full-logo.png
➜ multipass transfer pokerking-full-logo.png d1804:/tmp
➜ multipass shell d1804
# multipass实例中键入
ubuntu@d1804:~$ ls /tmp/

从Multipass实例传送到宿主机中:
# mac本地键入
➜ ~ ls Public
Drop Box
➜ ~ multipass shell d1804
# 实例键入
ubuntu@d1804:~$ pwd
/home/ubuntu
ubuntu@d1804:~$ touch test.txt
ubuntu@d1804:~$ ls
snap test.txt
# 再切换到mac本地shell
➜ ~ multipass transfer d1804:/home/ubuntu/test.txt /Users/admin/Public
➜ ~ ls Public
Drop Box test.txt
以上命令并不是Multipass支持的所有命令,但足够覆盖日常使用的80%,更多内容可以去文章顶部的Multipass官网自行浏览!
写到这里,相信有部分人觉得Multipass的用法和Docker非常相似,也有部分Windows用户认为这和当前微软力推的WSL (Windows Subsystem for Linux) 的功能高度重叠。具体请看以下对比。
| 对比 | Multipass | Docker | WSL & WSL2 |
|---|---|---|---|
| 技术领域 | 虚拟机 | 容器技术 | 虚拟机 |
| 背书厂商 | Canonical (Ubuntu官方) | Docker官方 | 微软 |
| 开发语言 | C++ | Go | C |
| 开源及 托管状态 |
开源,托管于GitHub ? 点击直达canonical/multipass |
开源,托管于GitHub ? 点击直达Docker |
开源,托管于GitHub ? 点击直达microsoft/WSL2 |
| 适配平台 | Linux & MacOS & Windows,跨平台能力好 | Linux适配较好,MacOS & Windows适配较弱 | Windows无缝集成 |
| 可选环境 | 仅Ubuntu官方镜像 | 各种Linux版本, 选择灵活性程度高 |
Linux kernel稳定版 + 部分发行版 |
| 适用场景 | 本地开发&验证&学习玩耍 | 可在工业级生产场景中 实际应用 |
本地开发&验证&学习玩耍 |
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
我的Rails站点使用了一个确实不是很好的gem。每次我需要做一些新的事情时,我最终不得不花费与向实际Rails项目添加代码一样多的时间来为gem添加功能。但我不介意,我将我的Gemfile设置为指向我的gem的GitHub分支(我尝试提交PR,但维护者似乎已经下台)。问题是我真的没有找到一种合理的方法来测试我添加到gem的新东西。在railsc中测试它会特别好,但我能想到的唯一方法是a)更改~/.rvm/gems/.../foo。rb,这看起来不对或者b)升级版本,推送到Github,然后运行bundleup,这除了耗时之外显然是一场灾难,因为我不确定我所做的promise是否正
我希望访问我机器上的所有HTTP流量(我的Windows机器-不是服务器)。据我了解,拥有一个本地代理是所有流量路线的必经之路。我一直在谷歌搜索但未能找到任何资源(关于Ruby)来帮助我。非常感谢任何提示或链接。 最佳答案 WEBrick中有一个HTTP代理(Rubystdlib的一部分)和here's一个实现示例。如果你喜欢生活在边缘,还有em-proxy伊利亚·格里戈里克。这postIlya暗示它似乎确实需要一些调整来解决您的问题。 关于ruby-如何捕获所有HTTP流量(本地代理)
我正在尝试找出一种方法来显示来自不在RAILS_ROOT下(在RedHat或Ubuntu环境中)的已安装文件系统的图像。我不想使用符号链接(symboliclink),因为这个应用程序实际上是通过Tomcat部署的,而当我关闭Tomcat时,Tomcat会尝试跟随符号链接(symboliclink)并删除挂载中的所有图像。由于这些文件的数量和大小,将图像放在public/images下也不是一种选择。我查看了send_file,但它只会显示一张图片。我需要在一个格式良好的页面中显示6个请求的图像。由于膨胀,我宁愿不使用Base64编码,但我不知道如何将图像数据与呈现的页面一起传递下去。
我刚刚在我的Ubuntu9.10服务器上安装了TeamBox。我使用提供的服务器脚本在端口3000上启动并运行它。它的运行速度非常慢,从另一台计算机连接时每个HTTP请求最多需要30秒。我使用链接从shell加载TeamBox,一点也不花时间。然后我设置了一个SSH隧道,它再次运行得非常快。我通过此服务器上的apache以及SAMBA等运行了大约30个虚拟主机,没有任何问题。我该如何解决这个问题? 最佳答案 我的redmine(ruby,webrick)太慢了。现在我解决了这个问题:apt-getinstallmongrelruby
我刚刚在本地设置了我的第一个Jekyll项目。我已经让服务器运行,但我忘了使用自动标志。所以现在我想停止服务器并使用标志重新启动。但是,在我启动服务器后的命令行中,我没有得到新的提示,所以我无法输入任何新命令。我不太习惯命令行,所以我真的很感激知道我应该做什么!我正在使用MacOSX和terminal.app,如果有区别的话! 最佳答案 psaux|grepjekyll|awk'{print$2}'|xargskill-9 关于ruby-如何停止jekyll本地服务器,我们在StackO
我相信我对这个问题有一个很好的答案,但我想确保ruby-philes没有更好的方法来做到这一点。基本上,给定一个输入字符串,我想在适当的情况下将该字符串转换为整数,或在适当的情况下将其转换为float。否则,只返回字符串。我会在下面发布我的答案,但我想知道是否有更好的方法。例如:to_f_or_i_or_s("0523.49")#=>523.49to_f_or_i_or_s("0000029")#=>29to_f_or_i_or_s("kittens")#=>"kittens" 最佳答案 我会尽可能避免在Ruby中使用正则表达式
西安华为OD面试体验开始投简历技术面试进展工作进展开始投简历去年一整年一直在考研和工作之间纠结,感觉自己的状态好像当时的疫情一样差劲。之前刚毕业的时候投了个大厂的简历,结果一面写算法的时候太拉跨了,虽然知道时dfs但是代码熟练度不够,放在平时给足时间自己可以调试通过,但是熟练度不够那面试当时就写不出来被刷了。说真的算法学到后期我感觉最重要的是熟练度和背板子(对于我这种普通玩家来说),面试题如果一上来短时间内想不出思路就完蛋了。然后由于当时找的工作不是很理想就又想考研了。但是考研是有风险的,我自我感觉自己可能冲不上那个学校,而找工作一个没成可以继续找嘛。本着抱着试试看的态度在boss上投了简历,
Linux操作系统——网络配置与SSH远程安装完VMware与系统后,需要进行网络配置。第一个目标为进行SSH连接,可以从本机到VMware进行文件传送,首先需要进行网络配置。1.下载远程软件首先需要先下载安装一款远程软件:FinalShell或者xhell7FinalShellxhell7FinalShell下载:Windows下载http://www.hostbuf.com/downloads/finalshell_install.exemacOS下载http://www.hostbuf.com/downloads/finalshell_install.pkg2.配置CentOS网络安装好