下載并安裝virtualbox
virtualbox官網(wǎng) https://www.virtualbox.org/wiki/Downloads
若是Linux版本(Ubuntu)下載二進(jìn)制包到本地再使用sudo dpkg -i安裝會(huì)出現(xiàn)如下錯(cuò)誤
$ sudo dpkg -i virtualbox-7.0_7.0.12-159484_Ubuntu_focal_amd64.deb
(Reading database ... 232199 files and directories currently installed.)
Preparing to unpack virtualbox-7.0_7.0.12-159484_Ubuntu_focal_amd64.deb ...
Unpacking virtualbox-7.0 (7.0.12-159484~Ubuntu~focal) ...
dpkg: dependency problems prevent configuration of virtualbox-7.0:
virtualbox-7.0 depends on libqt5help5 (>= 5.9.0); however:
Package libqt5help5 is not installed.
virtualbox-7.0 depends on libqt5xml5 (>= 5.0.2); however:
Package libqt5xml5 is not installed.
dpkg: error processing package virtualbox-7.0 (--install):
dependency problems - leaving unconfigured
Processing triggers for systemd (245.4-4ubuntu3.20) ...
Processing triggers for gnome-menus (3.36.0-1ubuntu1) ...
Processing triggers for desktop-file-utils (0.24-1ubuntu3) ...
Processing triggers for mime-support (3.64ubuntu1) ...
Processing triggers for hicolor-icon-theme (0.17-2) ...
Processing triggers for shared-mime-info (1.15-1) ...
Errors were encountered while processing:
virtualbox-7.0
使用官方教程用apt-install安裝更保險(xiǎn)
下載鏡像
需要iso格式的光盤
ubuntu https://ubuntu.com/download/server 注意下載的是光盤還是種子
新建虛擬機(jī)
點(diǎn)擊新建開始創(chuàng)建一個(gè)虛擬機(jī)

選擇內(nèi)存和磁盤大小
有一點(diǎn)要記住的是kubernetes集群里的機(jī)器需要至少2個(gè)CPU


在新建的虛擬機(jī)是關(guān)閉的狀態(tài)時(shí),點(diǎn)擊設(shè)置
選擇存儲(chǔ),選擇控制器下的光驅(qū)后,右邊分配光驅(qū)選擇第一TDR控制器主通道,點(diǎn)擊右側(cè)光盤選擇選擇虛擬盤,導(dǎo)入之前下載的ubuntu鏡像iso

選擇系統(tǒng),修改啟動(dòng)順序,去掉軟驅(qū),將硬盤移到光盤前,否則每次關(guān)機(jī)重啟后,不會(huì)讀取已經(jīng)保存在硬盤上的文件,而是會(huì)重新加載光驅(qū)安裝系統(tǒng)

如果分配的磁盤空間不夠,安裝會(huì)卡在掛載磁盤的那一步,一般4MB內(nèi)存需要掛載8G磁盤
有時(shí)候會(huì)報(bào)錯(cuò)Failed unmounted /cdrom,這種情況有時(shí)候是安裝的光盤自動(dòng)彈出了,沒有關(guān)系,有的時(shí)候需要操作一下,可能可行的操作包括:
手動(dòng)彈出光盤再繼續(xù)
關(guān)閉聲音

- 設(shè)置系統(tǒng)



Install和Install completely后的udpate階段都有可能比較慢,需要耐心等待
添加增強(qiáng)功能
增強(qiáng)功能可以幫我們添加自動(dòng)縮放虛擬機(jī)屏幕,共享剪切板,共享文件夾,拖拽等功能
核心操作是安裝VBoxGuestAdditions光盤
基本操作為關(guān)閉虛擬機(jī) -> 在設(shè)置/存儲(chǔ)中彈出控制器里的光盤 -> 啟動(dòng)虛擬機(jī) -> 選擇菜單中的安裝增強(qiáng)功能


登錄賬號(hào),首先為了防止光盤安裝失敗,需要先更新系統(tǒng)并安裝一些library
sudo apt-get update -y
sudo apt-get upgrade -y
sudo apt-get update -y
sudo apt-get install -y gcc make perl
sudo apt-get install -y dkms build-essential linux-headers-generic linux-headers-$(username -r)
# username -r 獲取當(dāng)前Linux版本
如果是桌面版虛擬機(jī),這時(shí)候要點(diǎn)擊出現(xiàn)在桌面的光盤進(jìn)行安裝。

如果是命令行,要掛載對(duì)應(yīng)的光盤,并使用root權(quán)限進(jìn)行安裝。
sudo su
mkdir -p /media/cdrom
mount /dev/cdrom /media/cdrom
cd /media/cdrom
sh VBoxLinuxAdditions.run
安裝后記得重啟再查看是否生效
sudo reboot
如果掛載不生效,我們可能想要把它卸載并重新安裝,這時(shí)候可以使用命令
cd /opt/<VirtualBoxAdditions-x.x.xx>/
sudo ./uninstall.sh
如果插入光盤安裝不生效,可以考慮直接下載library安裝
sudo apt-get install virtualbox-guest-additions-iso
# 卸載
sudo apt remove virtualbox-guest-additions-iso && sudo apt autoremove
如果還功能沒有自動(dòng)生效,還要在虛擬機(jī)里額外安裝一些library來啟用功能
sudo apt-get install virtualbox-guest-utils # 據(jù)說通用功能都包括
sudo apt-get install virtualbox-guest-dkms # 屏幕縮放
sudo apt-get install virtualbox-guest-x11 # 剪切板和共享文件
但可能會(huì)遇到報(bào)錯(cuò)Unable to locate package virtualbox-guest-dkms
[2023-01-23 Update]
有些依賴裝完后會(huì)導(dǎo)致原本無UI的ubuntu server版變成某種有藍(lán)色桌面的UI界面,完全不知道該如何使用,只能重新來過

相關(guān)鏈接1
相關(guān)鏈接2
相關(guān)鏈接3
屏幕自動(dòng)縮放
一開始的虛擬機(jī)屏幕顯示是很小的,需要放大才能工作
大部分資料的說法都是成功安裝VBox Guest Additions后窗口可以自動(dòng)變換大小或者自定義像素比例,然而就算我的文件夾和剪切板都可以使用后,自動(dòng)縮放屏幕仍然不能工作

有人說調(diào)整Display里的顯卡和3D加速可以生效,但是我試了也都沒有用

最后想到一個(gè)勉強(qiáng)能用的方法是改變窗口的百分比,就可以看得清了

共享剪切板
需要安裝了VBox Guest Additions才能使用,在設(shè)置->常規(guī)->高級(jí)里打開雙向剪切板和拖放

如果不生效,需要額外安裝virtualbox-guest-x11
sudo apt-get install -y virtualbox-guest-x11
如果不生效可以嘗試運(yùn)行sudo /usr/bin/VBoxClient --clipboard
共享文件夾
共享文件夾也需要安裝了VBox Guest Additions才能使用,也需要安裝virtualbox-guest-x11
選擇共享文件夾,填寫掛載卷軸相關(guān)的信息


在虛擬機(jī)內(nèi)sudo reboot后可以看到共享文件夾,注意文件夾的所有者為root
主機(jī)通過ssh連接虛擬機(jī)
增強(qiáng)功能硬盤安裝不成功的情況下,使用virtualbox自己的窗口還是很難受的,所以想到能不能用其他ssh工具進(jìn)入虛擬機(jī)工作
-
查看虛擬機(jī)的NAT網(wǎng)卡ip,防火墻是否開啟22端口,是否安裝ssh
NAT網(wǎng)卡ip
查看防火墻是否允許22端口的流量
sudo lsof -i -P -n | grep LISTEN
若沒有22端口則
sudo ufw allow ssh
sudo ufw status verbose
是否安裝ssh
sudo systemctl status ssh
若沒有安裝則
sudo apt install openssh-server
若沒有啟動(dòng)則
sudo systemctl enable ssh --now
- 關(guān)閉虛擬機(jī)后,打開設(shè)置 -> 網(wǎng)絡(luò) -> 高級(jí) -> 端口轉(zhuǎn)發(fā)

- 配置轉(zhuǎn)發(fā)端口

- 打開虛擬機(jī)后,使用
ssh -p 8022 <vm_username>@127.0.0.1訪問虛擬機(jī)
本來其實(shí)想使用橋接網(wǎng)絡(luò),這樣可以支持遠(yuǎn)程訪問,但不成功
國(guó)內(nèi)的博客更偏向使用橋接和Host-Only,國(guó)外的更偏向NAT
參考資料
How to SSH Into a VirtualBox Ubuntu Server
配置網(wǎng)絡(luò)
配置兩張網(wǎng)卡,網(wǎng)卡1選擇NAT,用來讓虛擬機(jī)訪問外網(wǎng);網(wǎng)卡2選擇橋接網(wǎng)絡(luò),使虛擬機(jī)擁有和主機(jī)一樣的網(wǎng)段,讓局域網(wǎng)內(nèi)的其他機(jī)器可以直接訪問虛擬機(jī)
配置NAT網(wǎng)卡首先要新建一張NAT網(wǎng)卡
選擇首頁(yè)的工具,點(diǎn)擊tab到NAT網(wǎng)絡(luò),點(diǎn)擊新建

選擇網(wǎng)絡(luò),網(wǎng)卡1選擇NAT,選擇剛才新建的NAT網(wǎng)卡

網(wǎng)卡2選擇橋接網(wǎng)絡(luò),高級(jí)選項(xiàng)里混雜模式選擇全部允許。此處的網(wǎng)卡名稱需要填寫主機(jī)上對(duì)應(yīng)到局域網(wǎng)路由IP網(wǎng)段的網(wǎng)卡,可以通過在主機(jī)上執(zhí)行ifconfig查看

將網(wǎng)卡關(guān)聯(lián)到虛擬機(jī)后,我們需要在虛擬機(jī)中配置它們??梢酝ㄟ^配置橋接網(wǎng)卡為我們的虛擬機(jī)固定靜態(tài)IP,這在搭建服務(wù)集群時(shí)常用
首先在虛擬機(jī)執(zhí)行ifconfig,可以通過inet辨認(rèn)出enp0s3為NAT網(wǎng)卡,enp0s8為橋接網(wǎng)卡
enp0s3: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.0.2.4 netmask 255.255.255.0 broadcast 10.0.2.255
inet6 fe80::a00:27ff:fe43:7d4e prefixlen 64 scopeid 0x20<link>
ether 08:00:27:43:7d:4e txqueuelen 1000 (Ethernet)
RX packets 44 bytes 13880 (13.8 KB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 53 bytes 8729 (8.7 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
enp0s8: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.8.247 netmask 255.255.255.0 broadcast 192.168.8.255
inet6 fe80::a00:27ff:fedf:9851 prefixlen 64 scopeid 0x20<link>
ether 08:00:27:df:98:51 txqueuelen 1000 (Ethernet)
RX packets 22598 bytes 2606276 (2.6 MB)
RX errors 0 dropped 54 overruns 0 frame 0
TX packets 48 bytes 3222 (3.2 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
device interrupt 16 base 0xd240
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1000 (Local Loopback)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
根據(jù)虛擬機(jī)ip配置addresses和routes,此處相當(dāng)于分給了虛擬機(jī)一個(gè)靜態(tài)IP
*注意:addresses是一個(gè)列表
*注意:此處的addresses必須與宿主機(jī)處于同一網(wǎng)段,不然無法通信。如宿主機(jī)ip為192.168.8.106/23,則虛擬機(jī)ip設(shè)置為192.168.8.2/24可以正常通信,設(shè)置為192.168.9.2/24不可正常通信【掩碼不同且主機(jī)IP不在虛擬機(jī)IP范圍中】
network:
ethernets:
enp0s3:
dhcp4: true
enp0s8:
dhcp4: no
addresses:
- 192.168.8.247/24
routes:
- to: default
via: 192.168.8.1
nameservers:
addresses: [8.8.8.8,114.114.114.114]
version: 2
啟用配置
sudo netplan apply
查看虛擬機(jī)ip

主機(jī)連接虛擬機(jī)

需要注意的是,進(jìn)入虛擬機(jī)后必須要安裝對(duì)應(yīng)的網(wǎng)絡(luò)工具才能查看本地ip,比如ubuntu必須要先運(yùn)行apt install net-tools
關(guān)閉selinux (Ubuntu默認(rèn)沒有安裝,可跳過)
sed -i 's/enforcing/disabled/' /etc/selinux/config # 永久
setenforce 0 # 臨時(shí)
關(guān)閉swap
sed -ri 's/.*swap.*/#&/' /etc/fstab # 永久
swapoff -a # 臨時(shí)
如果有需要,關(guān)閉防火墻
apt-get install iptables
ufw disable
sysctl --system
將橋接的IPv4流量傳遞到iptables的鏈
sudo touch /etc/sysctl.d/k8s.conf
sudo vim /etc/sysctl.d/k8s.conf
# 添加以下內(nèi)容并保存
# net.bridge.bridge-nf-call-ip6tables = 1
# net.bridge.bridge-nf-call-iptables = 1
# net.ipv4.ip_forward = 1
按照計(jì)劃的域名解析ip
sudo vim /etc/hosts
# 添加以下內(nèi)容并保存
# 192.168.1.111 spinq-master
# 192.168.1.112 spinq-worker1
# 192.168.1.113 spinq-worker2
sudo vim /etc/hostname
# 將值改為本機(jī)計(jì)劃的域名
# 或者直接運(yùn)行命令行 sudo hostnamectl set-hostname kubernetes-master
生效
sysctl --system
配置后測(cè)試集群機(jī)器之間ssh能否連通,以及ping www.baidu.com能否成功(保證了可以從公網(wǎng)下載資源)
克隆虛擬機(jī)
克隆后記得要為每一臺(tái)機(jī)器創(chuàng)建新的橋界網(wǎng)卡,并去/etc/netplan/00-installer-config.yaml修改靜態(tài)IP
