Build your own private cloud disk using VirtualBox & CentOS7 & SSH & Seafile & ngrok Part1
这个是个人的一篇经验总结,或者说花样踩坑集锦
先说下最终完成的效果:宿主机为Mac,在VirtualBox中安装CentOS7 minimal做为服务器,通过SSH由宿主机连接到CentOS7并在其中构建Seafile服务,通过外网或内网访问Seafile服务以完成同步或共享文件的功能,达到拥有私有云盘的目的
在VirtualBox中配置用于安装CentOS7的虚拟机
VirtualBox是一款Mac上很好用的虚拟机软件,之所以选择VirtualBox而不是其他的虚拟机软件,是因为我司项目开发就用的VirtualBox,所以我最初做这个项目的目的之一就是用来练手加强对VirtualBox的理解的
CentOS7是RedHat之下的一款社区版Linux,目前最高级版本为7, 可以在这里下载。在下载页面会看到有DVD ISO
,Everything ISO
,Minimal ISO
三个选项,一般来说,如果需要GUI页面,选择DVD ISO
,如果只需要最小安装尤其是作为服务器操作系统时,选择Minimal ISO
,而Everything ISO
对一般用户来说很少选择,其包含了以上两种ISO文件所有的内容,并额外包括开发CentOS功能所需要的内容
下面开始比较通用的在VirtualBox中安装虚拟机的步骤,这个步骤理论上是适合于创建任何系统虚拟机的,毕竟只是打造一台"裸机"
- 命名虚拟机及指定操作系统,命名随意,Type选Linux,Version选Red Hat
- 指定虚拟机内存空间,随意更改,我采用了默认设置
- 虚拟硬盘文件格式,随意更改,我采用了默认设置
- 虚拟硬盘文件存储位置及大小,随意更改,我采用了默认设置
- 虚拟硬盘文件是否可动态增长,随意更改,我采用了默认设置
- 裸机搞定
在虚拟机中安装CentOS7操作系统
- 载入操作系统镜像 CentOS7 Minimal ISO
启动刚刚设置成功的裸机,会要求安装系统,在系统文件加载的地方指定到之前下载的CentOS7 Minimal ISO后点击start即可
进入CentOS系统安装页面后,鼠标被VirtualBox的虚拟机窗口捕获后会提示是否允许捕获,当然选是,然后虚拟机中按cmd + 鼠标左键
的方式可以退出捕获,让鼠标回归宿主机
- 安装CentOS7
进入安装选择界面,键盘方向键上下调节选项,Enter
键选中选项,这里选择最简单的安装方式即可,即执行Install CentOS Linux 7
选项
安装时需要注意,不要随便调节窗口大小,一般VirtualBox会自动缩放窗口以让用户能最明显和方便的点击各个按钮,如果你像我一样手贱的缩放了窗口,那么记得上下左右滚动窗口以找到各种下一步的按钮,不要像我一样轻易以为VirtualBox傻缺
选择系统语言,推荐英语,没啥可说的
系统安装设定,这个我们不需用在CentOS安装时设定,因为我们之前在裸机设置时已经搞定了,这里点开这个设定窗口后直接左上角done
即可
点击Begin Installation
即可,喝水
开始安装后,在读条的过程中,会发现有两个设定需要完成,这里不用着急,着急也没用,进度图跑完前没法点击这两个按钮,安心喝水
读条结束后,开始设置两个黄色感叹号内容
root用户的密码设定,很重要,不用我多说
注意看图,知识点又来了,设置的root密码强度差不说,还居然包含了root用户名,被系统吐槽,而且这样的密码需要点两次左上角的Done
才能设置成功
这里主要是在本地虚拟环境,不想设置太复杂的密码,会忘 -_-#
接下来设置一个登陆用户,在你设置完root密码后,这个设定已经变成可选了,但是还是推荐在这里设置好
我这里直接给自己的登陆用户作为管理员了,以后的操作都会使用该用户<strike>为了加深印象我又把密码设置的很差劲让系统提醒一次 [doge] </strike>
OK,这里设置完毕后,左上角Done
*2,系统就开始启动了,在VirtualBox中安装CentOS7的操作就完成了
通过SSH由Mac宿主机访问CentOS7虚拟机
- 登陆虚拟机,查看网络配置
在CentOS7启动后,会停留在localhost login:
处等待,这里使用管理员kenshin
的账密登入
图中重点,ip addr
查看CentOS7的网络配置,注意2: enp0s3:
,这里指示的是虚拟机的internet连接,能够发现,没有ip地址
这是因为CentOS7的网络服务并不是默认开机启动的,需要手动配置
首先进入到CentOS7的网络配置文件所在目录
cd /etc/sysconfig/network-scripts/
然后打开ifcfg-enp0s3
文件,这里需要sudo
权限来编辑该文件
sudo vi ifcfg-enp0s3
将ONBOOT
设置为yes
后wq
保存并退出
- 关闭虚拟机,配置网卡
经过上面的操作,理论上是只需要重启网络服务就可以了,但是我们需要退出来为虚拟机额外添加网卡,所以索性先关机
而更实际上,我们在创建裸机的时候就可以添加好这个额外的网卡的,但是我忘了
其实真实情况是,这里我浪费了很多时间来处理网卡的事情,最初我并没有想到VirtualBox默认的NAT网卡不能完成我后面需要的SSH连接的功能,后来还搞了一阵Bridged Adapter的作用,所以这里是已经折腾了很多东西之后才发现的事情,但是既然是记录步骤,就不说那些错误和解决错误的详情了,最后再统一总结下就好了
另外,关于NAT,Host-only,Bridged的Adapter的区别,后面会提到
总之,现在把虚拟机关机,回到VirtualBox界面后,为虚拟机添加一个Host-only Adapter
- 启动虚拟机,再次查看网络信息
网卡添加完毕后,启动虚拟机,登入管理员账户,执行ip addr
命令查看网络信息
重点来了,图上我们有了两个internet的ip地址
图中2: enp0s3 .... inet 10.0.2.15
是由NAT Adapter提供的,其可以ping通外界网络,也就是外界网络对其来说可见,但是外界不能ping通10.0.2.15
,也就是其对外界网络来说不可见,包括宿主机也不能ping通 10.0.2.15
图中3: enp0s8 ... inet 192.168.99.101
是由Host-onlyAdapter提供的,其可以ping通外界网络,也就是外界网络对其来说可见,但是外界不能直接ping通192.168.99.101
,也就是其对外界网络来说不可见,但是宿主机可以ping通 192.168.99.101
这就是为什么需要额外添加一张Host-onlyAdapter的原因,如果宿主机都不能ping通虚拟机,那么SSH毛毛啊
- 宿主机SSH连接虚拟机
在虚拟机中执行service sshd start
命令来开启SSH服务,默认会运行在22端口
在虚拟机中执行systemctl status sshd
命令来查看SSH服务状态
Loaded: ...enabled...
表示SSH服务开启了开机自启动,这正是我们需要的
Active: active(running)...
表示SSH服务当前正在运行
现在,想建立SSH连接就只剩下最后一步,设置端口
在NAT Adatper中配置端口转发信息,为什么不在Host-only Adapter中配置呢,因为不能
Tips, 配置端口转发不需要重启虚拟机的
打开虚拟机的网络配置界面,在NAT Adapter中选择Port Forwarding
Port Forwarding
配置端口转发信息
这里做了两个端口转发
Guest Port 22
是用来做SSH连接的,默认情况下,服务器22端口用于SSH,Guest IP
和Host IP
都正常设置,Host Port
随意,不要冲突了就好
Guest Port 8000
是用来做服务转发的,后面会用到,我会把虚拟机8000端口的服务转发到宿主机,然后宿主机可以用来搞点事情,这里Guest IP
和Host IP
也是正常设置,Host Port
同样随意,不冲突就行
保存信息之后,在CentOS7中使用sudo systemctl restart network
命令重启下网络服务或者直接reboot
命令重启机器
在宿主机SSH连接虚拟机,-p
指定端口,后面再跟要登入的用户及服务器地址,我们已经做了端口和地址转发,因此这里的命令如下
Bingo!!!
搞定,我们现在可以在Mac宿主机终端经由SSH操作CentOS7虚拟机了,也就是我们的服务器(下面我也会除非万不得已,不然均称呼我们的CentOS7君为服务器),接下来我们就开始在服务器配置Seafile,不过现在内容太多了,尤其是很多图片,所以写在第二部分
最后欢迎访问我的个人博客~