作为一个coder,在学习技术过程中,经常需要搭建各种开发环境,以及模拟服务器操作,所以,这个时候最好需要搭建好虚拟机来完成各种模拟操作。这里我就选择使用VMware和VirtualBox等搭建虚拟机后,我最后选择使用VirtualBox+vagrant来完成这个操作,因为这个两者都是免费的,而且支持很方便的命令行操作,虚拟机也很稳定。
我的环境是mac,但是此方法window和mac都是通用的,window需要下载一个bash命令行工具会好操作一些。
下面分为以下几个步骤
- 1、下载virtualBox和vagrant
- 2、准备vagrantFile
- 3、使用vagrant命令搭建好centos虚拟机
- 4、使用root登陆
- 5、免密登陆
- 6、安装docker
步骤一:下载virtualBox和vagrant
- virtualBox下载地址:https://www.virtualbox.org/wiki/Downloads
- vagrant下载地址:https://www.vagrantup.com/downloads.html
步骤二:准备vagrantFile
- 在一个文件新建一个VagrantFile文件,把下面内容复制到VagrantFile内
- 这里是两节点,如果需要多个节点,在boxes配置数组里面多添加几个就好了
boxes = [
{
:name => "centos01",
:eth1 => "192.168.5.41" ,
:mem => "1024" ,
:cpu => "1"
},
{
:name => "centos02",
:eth1 => "192.168.5.42" ,
:mem => "1024" ,
:cpu => "1"
}
]
Vagrant.configure(2) do |config|
config.vm.box = "centos/7"
boxes.each do |opts|
config.vm.define opts[:name] do |config|
config.vm.hostname = opts[:name]
config.vm.provider "vmware_fusion" do |v|
v.vmx["memsize"] = opts[:mem]
v.vmx["numvcpus"] = opts[:cpu]
end
config.vm.provider "virtualbox" do |v|
v.customize ["modifyvm" , :id , "--memory" , opts[:mem]]
v.customize ["modifyvm" , :id , "--cpus" , opts[:cpu]]
end
config.vm.network:public_network,ip:opts[:eth1]
end
end
end
步骤三:使用vagrant命令搭建好centos虚拟机
- 进入放置vagrantFile的,使用vagrant up命令
- mac可以直接只用terminal,window可以安装bash工具
注意:
-
可能vagrant up会很慢,因为需要下载centos的box镜像,如果出现卡着不动的情况,可以去下面提示的地址去手动下载box,然后使用vagrant add box的指令,添加到本地,然后,就会使用刚添加的box,就会很快了。
-
下面这个地方需要选择网络,选择1
-
安装完毕,virtualBox会多出一个虚拟机,如果你配置了3个,结果只出现了一个,就control+z,停掉,再次运行vagrant up
步骤四:使用root登陆
由于vagrant默认是限定了不允许root用户登陆,而且只能vagrant up登陆,很多操作都有权限限制,例如vi /etc/ssh/sshd_config。这就导致了对这个虚拟机没有100%掌控力的感觉,这就不能忍了。所以接下来我要获取root权限,自己想怎么登陆就怎么登陆。
步骤如下:
- cd 到刚才那个vagrant目录,然后使用vagrant up去登陆,这个时候就能用vagrant这个用户登陆进了虚拟机。
- 使用
sudo chmod 777 /etc/ssg/sshd_confg
,给这个文件添加上可修改的权限 - 使用
vi /etc/ssg/sshd_confg
修改这个文件以下几个配置- port 22 -- 开启登陆端口
- PermitRootLogin yes -- 允许root登陆
- passwordAuthentication yes -- 允许密码登陆
- 修改完后保存重启sshd让配置生效:
service sshd restart
- 需要输入
root
的密码,密码是vagrant
- 到这里已经可以使用root账号登陆了,退出虚拟机,使用账号
root
,密码vagrant
登陆 - 指令:
ssh root@192.168.5.66
,输入密码vagrant
,这个192的ip可以在虚拟机中使用ip addr
查看 - 登陆成功,现在已经是root账户了。
步骤五:免密登陆
每次主机登陆虚拟器都需要免密挺麻烦的,这个时候一般做法都是使用免密登陆了,步骤如下:
- 创建ssh key :
ssh-keygen -t rsa
,一路回车就好 - 在
/root/.ssh
目录下添创建文件touch authorized_keys
- 宿主机需要免密登陆,就把宿主机的public key添加到authorized_keys中。
- 添加成功后直接使用:
ssh root@192.168.5.66
就好了,不再输密码,然后就可以使用secureCRT等工具去连就好了。
步骤六:安装docker
docker是开发学习的一个很重要的工具,所以我这里就装一下,参考官网的教程
删除之前的版本
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
安装前置工具
sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
# 官方源,网速太慢yum断连,不建议
$ sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
# 阿里源,国内速度快 (本文设置这个源,安装成功)
$ sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
//安装容器
sudo yum install docker-ce docker-ce-cli containerd.io
//启动docker
sudo systemctl start docker
//查看docker版本
sudo docker version
按上面的步骤安装完毕后,如果pull image的时候如果很慢,可以使用中科大的镜像源
- vim /etc/docker/daemon.json
{
"registry-mirrors" : ["https://docker.mirrors.ustc.edu.cn"]
}
- 然后重启docker :
service docker restart