win10下vagrant+centos7 rails虚拟开发机配置流程

此文写于2017.8.21
在写本文前,笔者已经尝试了多种其他的替代方法,例如wmware虚拟机安装kylin。然而发现总是还有各种问题。经大佬指点安装了virtualbox + vagrant。于是发现配置起来如此简单。接下来笔者将详细阐述。
注:笔者自己的服务器上的配置是centos7.2 + ruby2.3.4 + mariadb + redis,自己的笔记本为win10另外,很多网上的类似文章都写于很长时间以前,很多内容现在已经不适用,甚至很多关键的环节还不讲清楚,导致笔者配置初期踩了很多的坑。所以写下此文,总结经验

配置流程

1、box镜像的选择

本文中,笔者由于网站服务器系统为centos7.2,所以理所应当的选择了centos的镜像。(镜像官网,支持搜索配置:https://app.vagrantup.com/boxes/search。 关于vagrant,此文中不再赘述,网上关于vagrant+virtualbox的资料很多,基本配置也非常简单省事)。
起初,笔者随意下载了一个下载量高的centos,结果发现内部配置有很多的问题,主要问题是很多软件的版本过于老旧且更新很麻烦,需要手动解决很多的依赖(有的甚至还解决不了,于是果断弃坑)。后来换了一个官方镜像,于是有了很大的改观。(安利一下我用的镜像:https://app.vagrantup.com/centos/boxes/7)

在选择镜像的时候要注意以下几点:
  • 如没有十足的把握,请尽量选择较新且完整版的镜像(尽量不要Minimal)
  • 如果网络条件允许(例如在中国大陆之外)的话,可以直接按照页面上的方法配置。如果网络条件不允许或者速度极慢,可以先按照上面init你的vagrant,然后得到box的下载地址,中断init。然后用迅雷下载此地址到本地再配置,可以大大节省时间。

2、安装git

作为开发机,git是必不可少的,然而一开始也被git坑了好长时间。
首先直接命令安装

yum install git

安装时务必注意版本版本最好不要低于1.8(之前另一个系统git1.7,很多网站上的repo无法正常访问)
接下来就是配置git的一些全局设置

git config --global user.name "HansBug"
git config --global user.email xxx@xxx.com
git config credential.helper 'cache --timeout=7200'

三条设置依次为用户名,用户邮箱和记住密码(本人较懒,不想配置ssh)有效时间(单位秒,例子中为2小时)

3、安装rvm

作为rails环境的搭建,rvm是很重要的一环。
首先安装rvm(如果本机没有curl或者出现其他依赖问题请先解决)

curl -L get.rvm.io | bash -s stable

安装完后如果看到如下的提示的话

  * WARNING: You have '~/.profile' file, you might want to load it,
    to do that add the following line to '/home/vagrant/.bash_profile':

      source ~/.profile

则按照他说的做就好了。

安装完毕后有一个很重要的操作——将原镜像地址换掉。原镜像地址由于某些神秘的原因(你懂得),接下来ruby下载速度奇慢,而且还不稳定。
于是果断执行命令

echo "ruby_url=https://cache.ruby-china.org/pub/ruby" > ~/.rvm/user/db

4、安装ruby

rvm配置完毕之后,下一步就是安装ruby(我使用的是2.3.4版本)

rvm install 2.3.4 

然后安装完之后设置为默认版本

rvm use 2.3.4 --default

5、修改gem source

一般来说,ruby安装完之后,gem也就有了。但是因为一些神秘的原因(你懂得),gem原本的source常常下载速度极慢。
首先看一下现有的gem source

gem source -l

反馈是

*** CURRENT SOURCES ***

https://rubygems.org/

这个是rubygem原有的镜像,在大陆访问速度比较慢。我们可以换上ruby-china提供的镜像。操作如下:

gem source -r https://rubygems.org/
gem source -a https://gems.ruby-china.org/

依次是删除原有镜像地址和创建新镜像地址。到此,gem配置完毕

6、安装rails和bundler

如果之前都配置妥善了的话,这一步其实很简单
首先(中间可能会出现部分依赖性问题,可以通过baidu和google自行解决,一般都能找到相关资料)

gem install rails

确认安装完毕后,运行

gem install bundler

7、安装mariadb和redis

其实mariadb在centos上的安装非常简单,直接 yum -y install mariadb mariadb-server mysql-devel 即可(最后一个要是不安装的话,等会bundle install时会出现依赖错误)。
然后就可以 sudo service mariadb start来启动数据库了,十分方便。(关于数据库的设置密码等问题,可以自行百度相关资料,此处不再赘述)
redis的话,在确保EPEL安装了的情况下,也可以直接yum -y install redis,系统服务也配置好了,非常方便。(EPEL的安装请看文末问题区2)
注:在正式部署项目之前,请务必按照development的方式将redis和mariadb的相关配置配置好

关于mariadb的基本初始设置,可以参照博客:http://blog.csdn.net/cenguocheng/article/details/41282663
关于mariadb的远程访问问题,可以参照博客,写的很简洁清晰(不过除了开发机以外的情况下将远程权限赋予全部ip是很不安全的):http://www.cnblogs.com/24la/p/mariadb-remoting-access.html

8、部署项目

首先在项目目录下初始化仓库并添加远程仓库(后面写上你的git地址

git init
git remote add origin *****************.git

然后

git pull origin master

将项目安置好,然后接下来就是rails项目的一般性流程了

bundle install
rails db:migrate
rails db:seed

(注:若在bundle install的过程中遇到相关依赖性问题的话,可以首先查看错误说明,很多错误说明中已经告诉了你如何操作,需要安装什么包。如果没能解决的话请百度或google
最后一步,

rails server -b 0.0.0.0

启动rails服务器,然后我们就可以直接通过3000端口访问本机的网站啦!大功告成




问题区

1、vagrant无法与主机共享文件夹

我这边之前出现过一个问题,将配置文件(Vagrantfile)里面的这行注释去掉

config.vm.synced_folder "data", "/vagrant_data"

启用文件夹共享时,出现了错误

Vagrant was unable to mount VirtualBox shared folders. This is usually
because the filesystem "vboxsf" is not available. This filesystem is
made available via the VirtualBox Guest Additions and kernel module.
Please verify that these guest additions are properly installed in the
guest. This is not a bug in Vagrant and is usually caused by a faulty
Vagrant box. For context, the command attempted was:

mount -t vboxsf -o uid=1000,gid=1000 vagrant_data /vagrant_data

The error output from the command was:

mount: unknown filesystem type 'vboxsf'

这个问题解决方案已经知道(感谢博客:http://blog.csdn.net/demon3182/article/details/51436032)。其实很简单,就是缺一个插件,装上就ok

vagrant plugin install vagrant-vbguest

然后reload,问题解决。

2、部分软件包无法找到

这种情况是由于centos7本身带的软件包并不多。所以我们需要安装EPEL(感谢百度经验:http://jingyan.baidu.com/article/9158e0003a3eaca25412280c.html)
操作如下:

yum -y install epel-release
yum repolist

依次是安装epel和刷新软件包列表。我们可以看到,软件包数量增加了很多。

3、将虚拟机映射至ip

其实这一步也很简单,将Vagrantfile里面的这一行注释去掉即可(同时也请保证局域网内ip地址没有冲突,如有冲突,请更换一个ip。另,若是冲突的话,一般在vagrant up & reload的过程中会报错

config.vm.network "private_network", ip: "192.168.33.10"

然后网站就可以通过192.168.33.10:3000访问,数据库可以用192.168.33.10链接,甚至也可以用putty通过192.168.33.10的ip地址链接,就像连接你的服务器一样。

内容概要:本文档聚焦于“博士论文复现”项目,重点围绕光伏并网逆变器的阻抗建模与扫频验证方法展开,利用Simulink进行系【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)统建模与仿真,涵盖锁相环和电流环控制环节,旨在分析并网系统的稳定性。文档不仅提供具体的技术实现路径,还强调科研过程中逻辑思维、创新意识与借助已有成果的重要性,提倡系统性学习与实践结合。此外,文中列举了多个相关科研方向的复现案例与资源链接,涵盖虚拟电厂调度、风光制氢、电力系统优化等多个前沿领域,形成一个综合性科研辅助资料集合。; 适合人群:具备电力电子、自动控制或新能源系统背景的研究生、博士生及科研人员,熟悉MATLAB/Simulink仿真环境,有志于从事并网逆变器稳定性分析或相关课题研究的人员。; 使用场景及目标:①复现博士论文中的光伏并网逆变器阻抗建模与扫频分析过程,掌握其理论基础与仿真技巧;②深入理解锁相环与电流环在并网系统稳定性中的作用;③获取相关科研项目的代码与数据资源,用于学术研究、论文撰写或工程验证。; 阅读建议:建议按照文档提供的目录顺序系统学习,优先下载并查看网盘中的完整资源,结合Simulink模型与代码进行实操演练,注重理论与仿真的对照分析,以加深对阻抗建模与稳定性判据的理解。
内容概要:本文介绍了基于粒子群优化算法【故障定位】基于粒子群优化算法的故障定位及故障区段研究【IEEE33节点】(Matlab代码实现)(PSO)在IEEE33节点系统上进行故障定位及故障区段判定的研究,采用Matlab代码实现。通过构建配电网故障定位的数学模型,利用粒子群算法的全局寻优能力,快速准确地识别故障发生的位置与范围。文中详细阐述了算法原理、适应度函数设计、约束条件处理及仿真流程,并结合IEEE33节点标准测试系统验证了方法的有效性和鲁棒性。此外,文档还列举了多个相关科研方向及Matlab/Simulink仿真实现案例,涵盖智能优化、机器学习、电力系统管理、路径规划等多个领域,展示了广泛的科研应用场景和技术支持能力。; 适合人群:具备电力系统基础知识和Matlab编程能力的研究生、科研人员及从事智能电网、故障诊断相关工作的工程技术人员。; 使用场景及目标:① 掌握基于智能优化算法的配电网故障定位方法;② 学习如何将粒子群算法应用于实际电力系统问题建模与求解;③ 借助Matlab实现算法仿真,提升科研与工程实践能力;④ 拓展对电力系统故障诊断、优化算法应用及综合能源系统仿真的理解。; 阅读建议:建议读者结合提供的Matlab代码进行实操演练,深入理解算法实现细节与参数设置,同时可参考文档中列出的其他研究方向拓展思路,适用于科研项目开发、论文复现与算法改进。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值