本地环境搭建Virtualbox+Vagrant
环境准备
virtualbox是免费,不必要费劲去找破解,下载就可以用。 使用virtualbox每次安装虚拟机,需要你去下载iso,然后设置虚拟机硬件配置,使用iso创建虚拟器。一系列的手工操作,如果你只创建一两个虚拟机练练手,是足够的。 如果需要创建10个虚拟机,就需要重复10次。这时候,vagrant就派上用场了。
Vagrant基于配置文件,一键创建N台设备。
1)Virtualbox
下载:https://www.virtualbox.org/wiki/Downloads
根据自己的环境选择下载不同的软件版本

下载之后的安装:

2)vagrant(官网)
下载:https://www.vagrantup.com/downloads
根据本地环境选择需要的版本进行下载
安装成功之后:

3)vagrant使用
概念:
box:虚拟机镜像
provider:虚拟服务提供者, 例如virtualbox,VMware
box获取:
在官网镜像库检索

直接配置所需要的box名称即可,当启动虚拟机时候, 会从官网镜像库下载镜像后创建虚拟机
但是一般box包默认都是走的国外的地址, 速度真的是感人,于是我们使用国内镜像
国内镜像:mirrors.ustc.edu.cn/
vagrant镜像一般在vagrant目录下的box文件,例如centos的一般路径:https://mirrors.ustc.edu.cn/centos-cloud/centos/7/vagrant/x86_64/images/
a)
box下载之后, 添加到本地的box库
vagrant box add centos7 F:/CentOS-7.box 前面的参数:是应用的名称
后面的参数:是需要使用的具体box(具体路径)
b)初始化项目
vagrant init
在目录下会初始化一个VagrantFile文件
修改配置如下:
# -*- mode: ruby -*-
# vi: set ft=ruby : # All Vagrant configuration is done below. The "2" in Vagrant.configure
# configures the configuration version (we support older styles for
# backwards compatibility). Please don't change it unless you know what
# you're doing.
Vagrant.configure("2") do |config|
# The most common configuration options are documented and commented below.
# For a complete reference, please see the online documentation at
# https://docs.vagrantup.com. # Every Vagrant development environment requires a box. You can search for
# boxes at https://vagrantcloud.com/search.
config.vm.box = "centos7" config.vm.define "web1" do |web|
web.vm.hostname = "web1"
web.vm.box = "centos7"
web.vm.network "private_network", ip: "192.168.56.10"
end config.vm.define "web2" do |web|
web.vm.hostname = "web2"
web.vm.box = "centos7"
web.vm.network "private_network", ip: "192.168.56.11"
end
end
该配置文件, 使用centos7配置了两个虚拟机,ip分别是:192.168.56.10,192.168.56.11
c)启动虚拟机
vagrant up
如果想单独启动一个服务
vagrant up web1
or
vagrant up web2
服务启动之后 初始化了root和vagrant用户, 密码都是vagrant, 默认不允许使用密码进行登录
d)进入虚拟机
vagrant ssh web1
登录之后, 默认是vagrant用户, 使用su root可切换到root用户, 密码是vagrant
当然也可以使用ssh连接工具进行链接登录, 用户名使用vagrant,publicKey的方式进行登录,可查看公钥地址
vagrant ssh-config web1
or
vagrant ssh-config web2 如果要看全部的
vagrant ssh-config
e)文件同步
默认vagrant将当前vagrant工程目录(VagrantFile文件所在目录)映射到/vagrant目录
当时这种映射并不是实时的, 在虚拟机启动的时候 会进行一次同步操作,如果要在虚拟机运行期间进行文件的同步, 需要执行命令:
vagrant rsync
最佳实践
可以使用Provision,为每一个虚拟机配置一套初始化脚本,来加强虚拟机的初始化。
VagrantFile放到开发工程中,提交到git,其他开发小伙伴也可以下载后,一键启动虚拟机环境,就可以和你拥有一样的虚拟机环境。
扩展:
1.更换yum源
cd /etc/yum.repos.d 目录下,CentOS-Base.repo为全局镜像源配置,将其进行更换
mv CentOS-Base.repo CentOS-Base.repo.bak # 查看centos版本
[root@localhost yum.repos.d]# cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core) # 配置为阿里镜像源
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo # 设置缓存
yum makecache # 更新镜像配置,可以看到阿里镜像源
[root@localhost yum.repos.d]# yum -y update
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* base: mirrors.aliyun.com
* epel: mirrors.njupt.edu.cn
* extras: mirrors.aliyun.com
* updates: mirrors.aliyun.com
2.如果想要文件同步需要进行配置
config.vm.define "web1" do |web|
web.vm.hostname = "web1"
web.vm.box = "centos7"
web.vm.network "private_network", ip: "192.168.56.10"
web.vm.synced_folder "web1", "/vagrant_data"
# web.ssh.insert_key = false
# web.ssh.username = "vagrant"
# web.ssh.password = "vagrant"
end config.vm.define "web2" do |web|
web.vm.hostname = "web2"
web.vm.box = "centos7"
web.vm.network "private_network", ip: "192.168.56.11"
web.vm.synced_folder "web2", "/vagrant_data"
# web.ssh.insert_key = false
# web.ssh.username = "vagrant"
# web.ssh.password = "vagrant"
end
synced_folder
常见问题:
1.虚拟机中出现一个命令无法使用 No package xxx available
原因:
软件包默认不在yum仓库中,因此需要配置epel仓库
1.配置阿里云网络源
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo 或者使用curl
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
配置epel源
yum install -y epel-release
说明: Centos-7.repo提供了centos7官方发行版提供的软件包, epel源提供了除了官网之外的软件包
2.无法挂载目录Vagrant挂载目录失败mount: unknown filesystem type ‘vboxsf’
可以安装插件:http://download.virtualbox.org/virtualbox/6.1.24/VBoxGuestAdditions_6.1.24.iso
使用命令安装:
vagrant plugin install vagrant-vbguest 如果太慢的话
vagrant plugin install 插件名称 --plugin-clean-sources --plugin-source https://gems.ruby-china.com/ vagrant plugin install vagrant-vbguest --plugin-clean-sources --plugin-source https://gems.ruby-china.com/
如果还是报错, 尝试使用其他版本:
config.vm.box = “centos/7” to –> config.vm.box = “generic/centos7” and uninstall the plugin using this command “vagrant plugin uninstall vagrant-vbguest” after that run command “vagrant up” vagrant plugin uninstall vagrant-vbguest
vagrant plugin install vagrant-vbguest --plugin-version 0.21
或者虚拟系统中需要安装依赖:
uname -r
yum install kernel-devel-x.x.x
yum install kernel-devel-3.10.0 centos yum install kernel-devel-xxx debian apt-get install kernel-headers-xxx
本地环境搭建Virtualbox+Vagrant的更多相关文章
- Laravel系列之环境搭建 — VirtualBox+Vagrant+Homestead
一.为啥需要搭建环境 为了解决环境不统一问题,所以要搭建这么个玩意儿 二.步骤 Laravel对环境有所要求(不使用Homestead情况下),具体参考官网 使用Homestead步骤 1. Hom ...
- Sonar本地环境搭建
一个新项目准备上线提测了,为了在提测之前做一下代码走查,同时了解项目目前的质量情况,就在本地搭建了一套sonar环境.搭建的过程中遇到了很多问题,sonar官方已不再维护Eclipse的svn插件,所 ...
- Docker下kafka学习三部曲之二:本地环境搭建
在上一章< Docker下kafka学习,三部曲之一:极速体验kafka>中我们快速体验了kafka的消息分发和订阅功能,但是对环境搭建的印象仅仅是执行了几个命令和脚本,本章我们通过实战来 ...
- Laravel本地环境搭建:Homestead开发环境的部署
Laravel框架在php开发过程是不断进行优化的,当然也包括了本地环境的开发,下面我们就来具体看看laravel框架中的Homestead 开发环境的部署内容. 首先白以下几个概念 VirtualB ...
- AngularJS2之本地环境搭建
前言:本来准备初探AngularJS2,结果成了复习git和再探node git的两个常见问题:一.github上传时出现error: src refspec master does not matc ...
- .NET Exceptionless 日志收集框架本地环境搭建
一.简介 Exceptionless 是一个开源的实时的日志收集框架,它可以应用在基于 ASP.NET,ASP.NET Core,Web Api,Web Forms,WPF,Console,MVC 等 ...
- Flink从入门到放弃(入门篇2)-本地环境搭建&构建第一个Flink应用
戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...
- 以太坊remix-ide本地环境搭建
remix-ide简介 remix-ide是一款以太坊官方solisity语言的在线IDE,可用于智能合约的编写.测试与部署,不过某些时候可能是在离线环境下工作或者受限于网速原因,使用在线remi ...
- jekyll本地环境搭建(Windows)
序:最近一直在搞Github建站,所以一直没机会写文章,那边的环境虽然搞好了,但是网站的界面却是个问题,不想用别人的,总想自己设计个,却感觉没经验吧,就一直耽搁了.所以也就没心情在那边写文章,很久没写 ...
- CC2B本地环境搭建步骤及部署问题解决
由于最近的项目是之前没接触过的netbeans+glassfish,记录一下最近在工作中搭建本地环境的步骤及遇到的一些问题解决方法: 1.配置java jdk 此过程中遇到一个问题就是在配置系统环境变 ...
随机推荐
- Vue SPA项目如何修改网站标题
直接贴 门户项目代码 // 全局router 直接挂载路由导航守卫 router.beforeEach((to, from, next) => { if (to.meta.title) { va ...
- Java怎么把多个对象的list的数据合并
1.示例一:创建几个包含Person对象的List,并将它们合并成一个新的List 在Java中,将多个对象的List合并通常涉及到遍历这些List并将它们的元素添加到一个新的List中.这里,我将给 ...
- CSS & JS Effect – Blue Tick Avatar
效果 难点 难题只有一个, 那就是如何把 blue tick image 定位当 avatar 的右下角. HTML <div class="avatar-wrapper"& ...
- CSS & JS Effect – Statistics Counter
效果 当 scroll 到那些号码的时候, 号码从 0 开始跳动, 一直到最终的值. 实现思路 1. 一开始把号码 set to 0 2. 使用 IntersectionObserver 监听号码出现 ...
- nRF24L01芯片驱动记录
nRF24L01芯片驱动记录 学习完了usb,了解了部分元器件的功能以及用途后,打算在端午假期用一天的时间完成一个小目标,不过实际上是花了一天半才成功实现,现将驱动nRF24L01芯片的整个过程记 ...
- 教你一招,测试人员如何通过AI提高工作效率!
伴随着AI技术的兴起,像OpenAI推出的ChatGPT.Microsoft发布的Microsoft 365 Copilot.阿里的通义千问.百度的文心一言.华为的盘古大模型等.很多测试人员开始担心, ...
- SQL注入演示
SQL注入演示 创建一个简易的登录系统/** tb_user 用户表 * 用户登录系统(需在数据库中创建tb_user表 ) */ @Test public void testUserLogin() ...
- Outlook无法接收发送邮件,报错超出最大空间 的解决办法
事件起因: 某客户的outlook邮箱无法接收/发送邮件,报错为:存储区已达到最大大小 解决办法: 解决思路:新建一个数据文件来接收发送邮件 具体操作: 文件-账户配置-数据文件-新建(更 ...
- docker安装及基本的镜像拉取
docker 使用存储库安装 卸载它们以及相关的依赖项. yum remove docker \ docker-client \ docker-client-latest \ docker-commo ...
- 《Vue.js 设计与实现》读书笔记 - 第11章、快速 Diff 算法
第11章.快速 Diff 算法 11.1 相同的前置元素和后置元素 快速 Diff 算法包含预处理步骤,这借鉴了纯文本 Diff 算法的思路. 先把相同的前缀后缀进行处理,然后再比较中间部分. fun ...