# 后端开发环境Homestead
启动 Homestead 之前,确保 VirtualBox 、Vagrant、Git 软件己安装。

## 安装 laravel/homestead
vagrant box add laravel/homestead
如果这个命令失败了,请确保你安装的是最新版的 Vagrant(可能被墙)。

1. 请下载 virtual.box自定义安装:
2. vagrant box add laravel/homestead ~/目录/virtualbox.box

被墙后后,请去Vagrant 官网下载:
https://vagrantcloud.com/laravel/boxes/homestead/versions/9.3.0/providers/virtualbox.box
如果执行自定义下载的文件安装,报如下错:
check your Homestead.yaml file, the path to your private key does not exist.
解决办法:

1 ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
2
3 eval "$(ssh-agent -s)"
4
5 ssh-add -K ~/.ssh/id_rsa

## 安装 Homestead

cd ~
git clone https://github.com/laravel/homestead.git ~/Homestead

这样 Homestead Box 就可以作为你的所有 Laravel 项目的主机

切到最新的稳定版本

cd ~/Homestead
# 或者期望的发行版本...
git checkout v9.4.0

在 Homestead 目录中使用 bash init.sh 命令来创建 Homestead.yaml 配置文件。 Homestead.yaml 文件将被放在 Homestead 目录中

# Mac / Linux...

bash init.sh

## 配置 Homestead
打开 ~/Homestead/Homestead.yaml

# 配置共享文件夹 (你电脑上的目录映射到虚拟机上)
folders:
- map: ~/website/bbs
to: /home/vagrant/Code/bbs # 配置 Nginx 站点
sites:
- map: bbs.test
to: /home/vagrant/code/bbs/public

## 启动 Vagrant 盒子
配置好 Homestead.yaml 文件后,在 Homestead 目录下运行 vagrant up 命令,如果你是通过先下载 Homestead Vagrant 盒子再手动添加的方式安装的话,此时先不要执行这个命令,而是需要进入 ~/.vagrant.d/boxes/laravel-VAGRANTSLASH-homestead 目录(以 MacOS 为例,Windows 对应的路径应该是 C:/Users/User/.vagrant.d/boxes/laravel-VAGRANTSLASH-homestead,其中 User 对应你的用户名),添加一个 metadata_url 文件,并初始化文件内容如下(如果已有则忽略):

https://vagrantcloud.com/laravel/homestead

接下来,将该目录下手动添加到 Vagrant 盒子目录 0 重命名此次安装盒子版本号 9.4.0(可执行命令 vagrant box list 可得laravel/homestead virtualbox版本号),再回到 Homestead 目录运行 vagrant up 命令。Vagrant 将会启动虚拟机并自动配置共享文件夹以及 Nginx 站点,初次启动需要花费一点时间进行初始化。
当然为了关闭检测自动更新,配置 Homestead/script/homestead.rb 文件。

// 新增
config.vm.box_check_update = false

## 多版本 PHP
Homestead 6 在同一个虚拟机上引入了对多个 PHP 版本的支持。你可以在你的 Homestead.yaml 文件中指定要用于给定站点的 PHP 版本

sites:
- map: homestead.test
to: /home/vagrant/code/xxx/public
php: "7.1"

## PHP版本管理工具
homestead 中自带了版本管理工具 update-alternatives

#进入 ssh
vagrant ssh #查看所有 php 版本和当前版本
update-alternatives --display php #列出当前 php 所有版本和编号,输入编号,切换到执行的版本
update-alternatives --config php

## Homestead常用命令
> 将在Homestead目录下进行
1. 更新虚拟机上的 Nginx 配置(当更改了 sites 选项)

vagrant reload --provision`
# 或者
vagrant provision && vagrant reload

2. 删除虚拟机

vagrant destroy --force

3. 启动

vagrant up

4. 进入系统

vagrant ssh  

基于 vagrant搭建移动端的开发环境的更多相关文章

  1. React-native搭建移动端ios开发环境实践笔记

    开发环境的搭建,按照 https://reactnative.cn/docs/getting-started/ 里面的步骤一步一步来,这里记录下需要注意的几点:1.初始化react-native项目的 ...

  2. Vite ❤ Electron——基于Vite搭建Electron+Vue3的开发环境【一】

    背景 目前社区两大Vue+Electron的脚手架:electron-vue和vue-cli-plugin-electron-builder, 都有这样那样的问题,且都还不支持Vue3,然而Vue3已 ...

  3. 基于全志H3芯片的ARM开发环境搭建

    基于全志H3芯片的ARM开发环境搭建 最近买了个友善之臂的NanoPi M1板子,又在网上申请了个NanoPi NEO板子,这两个都是基于全志H3芯片的Crotex-A7四核ARM开发板,两个板子可以 ...

  4. vagrant+docker搭建consul集群开发环境

    HashiCorp 公司推出的Consul是一款分布式高可用服务治理与服务配置的工具.关于其配置与使用可以参考这篇文章 consul 简介与配置说明. 一般,我们会在多台主机上安装并启动 consul ...

  5. 如何基于Jupyter notebook搭建Spark集群开发环境

    摘要:本文介绍如何基于Jupyter notebook搭建Spark集群开发环境. 本文分享自华为云社区<基于Jupyter Notebook 搭建Spark集群开发环境>,作者:apr鹏 ...

  6. 搭建 AngularJS+Ionic+Cordova 开发环境并运行一个demo

    目前的手机APP有三类:原生APP,WebAPP,HybridApp:HybridApp结合了前两类APP各自的优点,越来越流行. Cordova就是一个中间件,让我们把WebAPP打包成Hybrid ...

  7. Win7搭建nginx+php+mysql开发环境以及websocket聊天实例测试

    Win7搭建nginx+php+mysql开发环境以及websocket聊天实例测试一.下载相关安装包 1.下载nginx最新版本(nginx1.3.13版之后才支持websocket协议) 下载地址 ...

  8. 极其简单的搭建eclipse的android开发环境

    这篇博客是关于如何搭建eclipse的android开发环境, 与网上的其他博客不同,我的方法比他们简单的多,所 以推荐给大家. 搭建eclipse的android开发环境步骤: 1.配置JDK(Ja ...

  9. 基于Eclipse的Go语言可视化开发环境

    http://jingyan.baidu.com/article/d7130635032e2f13fdf475b8.html 基于Eclipse的Go语言可视化开发环境 | 浏览:2924 | 更新: ...

随机推荐

  1. Jenkins管理员密码忘记修改操作

    一.Jenkins管理员密码忘记 当jenkins忘记了管理用户的密码时,只能通过修改配置文件并重启的方式初始化设置用户名及密码,操作如下: [root@localhost jenkins]# vim ...

  2. Redis 哨兵高可用(Sentinel)

    哨兵机制是 Redis 高可用中重要的一环,其核心是 通过高可用哨兵集群,监控主从复制的健康状态,并实现自动灾备: 哨兵集群以集群的方式进行部署,这种分布式特性具有以下优点: 避免系统中存在单点,防止 ...

  3. PyQt5 问题集

    PyQt5中遇到的一些问题 1.多线程中界面异步刷新 我这里需要给界面动态添加新的控件,但是多线程中似乎并不能直接更新页面? 对于逻辑和界面分离的情况,使用自定义信号的方式进行页面控件的动态添加.注意 ...

  4. Makefile 流程控制(error,warning)等调试选项

    1.退出码 0 ok1 错误2 使用了-q 选项 且目标不需要更新 返回2 2.选项 -f --file 指定makefile脚本 -n --just-print --dry -run -- reco ...

  5. Flow All In One

    Flow All In One Flow is a static type checker for JavaScript https://github.com/facebook/flow https: ...

  6. 召回 & 召回算法

    召回 & 召回算法 recall https://developers.google.com/machine-learning/crash-course/classification/prec ...

  7. H5 APP 页面移动端适配方案

    H5 APP 页面移动端适配方案 https://segmentfault.com/a/1190000011586301 https://juejin.im/post/5cbdee71f265da03 ...

  8. Nestjs 修改dist目录

    修改tsconfig.json { "compilerOptions": { "outDir": "./server-dist", // 这 ...

  9. 什么是NGK节点?NGK的节点有什么作用?

    从2018年EOS竞选超级节点火爆整个区块链圈,节点和超级节点就成为了热议的话题,时至今日,热度依然不减.节点是项目生态发展的重要组成部分,超级节点对项目的运行.安全更是起着至关重要的作用.   什么 ...

  10. C++算法代码——n的全排列/全排列问题

    题目来自:http://218.5.5.242:9018/JudgeOnline/problem.php?id=1541 题目描述 输入一个整数n,输出的n(n<=100)的全排列. 输入 输入 ...