VirtualBox+vagrant搭建root权限,免密登陆的多节点centos虚拟机

作为一个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

步骤二:准备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,就会很快了。


    box地址.png
  • 下面这个地方需要选择网络,选择1


    选择网络.png
  • 安装完毕,virtualBox会多出一个虚拟机,如果你配置了3个,结果只出现了一个,就control+z,停掉,再次运行vagrant up


    virtualBox中出现一个虚拟机.png

步骤四:使用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
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容