美文网首页
VirtualBox+vagrant搭建root权限,免密登陆的

VirtualBox+vagrant搭建root权限,免密登陆的

作者: coder爱唱歌 | 来源:发表于2020-03-22 14:52 被阅读0次

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

    相关文章

      网友评论

          本文标题:VirtualBox+vagrant搭建root权限,免密登陆的

          本文链接:https://www.haomeiwen.com/subject/gzwmyhtx.html