PuPHPet, Vagrant dan SSH - SSH Timeout Connection


2

Saya membangun kotak gelandangan CentOS 6.5 baru dan setelah penyediaan, koneksi SSH terus waktu. Saya sudah mencoba langkah-langkahnya Vagrant ssh gagal dengan VirtualBox tapi saya menerima kesalahan (lihat di bawah). Saya awalnya berpikir bahwa itu mungkin masalah dengan / etc / hosts saya, tetapi setelah mengomentari potensi konflik saya masih memiliki masalah yang sama; jadi, saya membuat kotak gelandangan Ubuntu 14.04 dan mesin itu boot dengan sempurna. Vagrantfiles / config.yaml kedua mesin dibuat menggunakan PuPHPet.com.

Detail tuan rumah:

Host OS: Kubuntu 14.04 (3.13.0-29-generic)
Virtualbox: 4.3.12 r93733
Vagrant: 1.6.0
Basebox: puphpet/centos65-x64   (virtualbox, 1.0.1)

Setelah mengedit Vagrantfile saya untuk memasukkan arahan untuk mengaktifkan GUI dan mengatur max retries ke 150 (per utas di atas), saya menerima pesan kesalahan berikut:

$ vagrant up
Bringing machine 'default' up with 'virtualbox' provider...
There are errors in the configuration of this machine. Please fix
the following errors and try again:

SSH:
* The following settings shouldn't exist: max_tries

vm:
* The following settings shouldn't exist: boot_mode

Jadi, saya telah menghapusnya. Saya mem-boot mesin dengan VirtualBox, dan itu muncul dengan lancar.

IP Ditugaskan: 192.168.56.101

/ Etc / sysconfig / network-scripts / ifcfg-eth1 memiliki set konfigurasi berikut:

DEVICE="eth1"
BOOTPROTO="none"
IPV6INIT="yes"
MTU="1500"
NM_CONTROLLER="yes"
ONBOOT="yes"
TYPE="Ethernet"
#VAGRANT-BEGIN
NM_CONTROLLER=no
BOOTPROTO=none
ONBOOT=yes
IPADDR=192.168.56.101
NETMASK=255.255.255.0
DEVICE=eth1
PEERDNS=no
#VAGRANT-END

[Ke samping] Ketika saya mengetik itu (saya tidak bisa menyalin / menempel dari VM CLI sayangnya), saya perhatikan bahwa ada deklarasi kedua untuk NM_CONTROLLED, jadi saya akan berkomentar NM_CONTROLLED="yes" sekarang hanya untuk membersihkannya. [/Ke samping]

Bergerak ke kanan ... Saya bisa mem-ping tamu dari tuan rumah; dan, saya sudah mencoba ssh menggunakan cara standar (ssh vagrant@192.168.56.101) tetapi menerima pesan kesalahan yang menyatakan No route to host.

$ ping 192.168.56.101
PING 192.168.56.101 (192.168.56.101) 56(84) bytes of data.
64 bytes from 192.168.56.101: icmp_seq=1 ttl=64 time=1.94 ms
64 bytes from 192.168.56.101: icmp_seq=2 ttl=64 time=0.430 ms
^C
--- 192.168.56.101 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 0.430/1.187/1.945/0.758 ms

[03:03 PM]-[josej@josej-desktop]-[~/Projects/CentOS-6.5]
$ ssh vagrant@192.168.56.101
ssh: connect to host 192.168.56.101 port 22: No route to host

Jelas, ada rute ke host yang saya bisa ping itu;). Jadi, saya pikir sshd tidak berjalan tetapi seperti yang bisa kita lihat di bawah, itu adalah:

[vagrant@localhost ~]$ ps aux | grep sshd
root    1321    0.0    0.1    66608    1200 ?        Ss    20:02    0:00 /usr/sbin/sshd

Saya mengharapkannya untuk menolak koneksi karena saya tidak memasukkan kunci SSH, tetapi karena itu tidak terjadi dan sshd berjalan

Jadi, selanjutnya saya menguji apakah tamu bisa ping Google, yang gagal. Jadi, periksa route kami melihat:

[vagrant@localhost ~]$ route
Kernel IP routing table
Destination    Gateway    Genmask         ... Iface
10.0.2.0       *          255.255.255.0   ... eth0
192.168.56.0   *          255.255.255.0   ... eth1

Jadi, tebakan terbaik saya adalah ada masalah jaringan di suatu tempat. Karena tuan rumah dapat melakukan ping tamu, dan tamu dapat melakukan ping tuan rumah ( ping 192.168.56.1 berfungsi), file rute imo terlihat bagus, dan konfigurasi jaringan benar, tetapi tamu tidak dapat mencapai tujuan di luar gateway ... Saya cukup bingung pada saat ini.

Saya akan melihat-lihat iptables dan menonaktifkan SELinux untuk saat ini. Semoga itu akan membantu menyelesaikan masalah. Bagaimanapun, saya terbuka untuk saran apa pun karena saya telah berjuang dengan ini selama dua hari sekarang dan hanya berputar-putar.

Dan, akhirnya, inilah Vagrantfile dan puphpet / config.yaml:

require 'yaml'

dir = File.dirname(File.expand_path(__FILE__))

configValues = YAML.load_file("#{dir}/puphpet/config.yaml")
data = configValues['vagrantfile-local']

Vagrant.configure("2") do |config|
  config.vm.box = "#{data['vm']['box']}"
  config.vm.box_url = "#{data['vm']['box_url']}"

  if data['vm']['hostname'].to_s.strip.length != 0
    config.vm.hostname = "#{data['vm']['hostname']}"
  end

  if data['vm']['network']['private_network'].to_s != ''
    config.vm.network "private_network", ip: "#{data['vm']['network']['private_network']}"
  end

  data['vm']['network']['forwarded_port'].each do |i, port|
    if port['guest'] != '' && port['host'] != ''
      config.vm.network :forwarded_port, guest: port['guest'].to_i, host: port['host'].to_i
    end
  end

  data['vm']['synced_folder'].each do |i, folder|
    if folder['source'] != '' && folder['target'] != ''
      nfs = (folder['nfs'] == "true") ? "nfs" : nil
      if nfs == "nfs"
        config.vm.synced_folder "#{folder['source']}", "#{folder['target']}", id: "#{i}", type: nfs
      else
        config.vm.synced_folder "#{folder['source']}", "#{folder['target']}", id: "#{i}", type: nfs,
          group: 'www-data', owner: 'www-data', mount_options: ["dmode=775", "fmode=764"]
      end
    end
  end

  config.vm.usable_port_range = (10200..10500)

  if data['vm']['chosen_provider'].empty? || data['vm']['chosen_provider'] == "virtualbox"
    ENV['VAGRANT_DEFAULT_PROVIDER'] = 'virtualbox'

    config.vm.provider :virtualbox do |virtualbox|
      data['vm']['provider']['virtualbox']['modifyvm'].each do |key, value|
        if key == "memory"
          next
        end

        if key == "natdnshostresolver1"
          value = value ? "on" : "off"
        end

        virtualbox.customize ["modifyvm", :id, "--#{key}", "#{value}"]
      end

      virtualbox.customize ["modifyvm", :id, "--memory", "#{data['vm']['memory']}"]

      if data['vm']['hostname'].to_s.strip.length != 0
        virtualbox.customize ["modifyvm", :id, "--name", config.vm.hostname]
      end
    end
  end

  if data['vm']['chosen_provider'] == "vmware_fusion" || data['vm']['chosen_provider'] == "vmware_workstation"
    ENV['VAGRANT_DEFAULT_PROVIDER'] = (data['vm']['chosen_provider'] == "vmware_fusion") ? "vmware_fusion" : "vmware_workstation"

    config.vm.provider "vmware_fusion" do |v|
      data['vm']['provider']['vmware'].each do |key, value|
        if key == "memsize"
          next
        end

        v.vmx["#{key}"] = "#{value}"
      end

      v.vmx["memsize"] = "#{data['vm']['memory']}"

      if data['vm']['hostname'].to_s.strip.length != 0
        v.vmx["displayName"] = config.vm.hostname
      end
    end
  end

  if data['vm']['chosen_provider'] == "parallels"
    ENV['VAGRANT_DEFAULT_PROVIDER'] = "parallels"

    config.vm.provider "parallels" do |v|
      data['vm']['provider']['parallels'].each do |key, value|
        if key == "memsize"
          next
        end

        v.customize ["set", :id, "--#{key}", "#{value}"]
      end

      v.memory = "#{data['vm']['memory']}"

      if data['vm']['hostname'].to_s.strip.length != 0
        v.name = config.vm.hostname
      end
    end
  end

  ssh_username = !data['ssh']['username'].nil? ? data['ssh']['username'] : "vagrant"

  config.vm.provision "shell" do |s|
    s.path = "puphpet/shell/initial-setup.sh"
    s.args = "/vagrant/puphpet"
  end
  config.vm.provision "shell" do |kg|
    kg.path = "puphpet/shell/ssh-keygen.sh"
    kg.args = "#{ssh_username}"
  end
  config.vm.provision :shell, :path => "puphpet/shell/update-puppet.sh"

  config.vm.provision :puppet do |puppet|
    puppet.facter = {
      "ssh_username"     => "#{ssh_username}",
      "provisioner_type" => ENV['VAGRANT_DEFAULT_PROVIDER'],
      "vm_target_key"    => 'vagrantfile-local',
    }
    puppet.manifests_path = "#{data['vm']['provision']['puppet']['manifests_path']}"
    puppet.manifest_file = "#{data['vm']['provision']['puppet']['manifest_file']}"
    puppet.module_path = "#{data['vm']['provision']['puppet']['module_path']}"

    if !data['vm']['provision']['puppet']['options'].empty?
      puppet.options = data['vm']['provision']['puppet']['options']
    end
  end

  config.vm.provision :shell do |s|
    s.path = "puphpet/shell/execute-files.sh"
    s.args = ["exec-once", "exec-always"]
  end
  config.vm.provision :shell, run: "always" do |s|
    s.path = "puphpet/shell/execute-files.sh"
    s.args = ["startup-once", "startup-always"]
  end
  config.vm.provision :shell, :path => "puphpet/shell/important-notices.sh"

  if File.file?("#{dir}/puphpet/files/dot/ssh/id_rsa")
    config.ssh.private_key_path = [
      "#{dir}/puphpet/files/dot/ssh/id_rsa",
      "#{dir}/puphpet/files/dot/ssh/insecure_private_key"
    ]
  end

  if !data['ssh']['host'].nil?
    config.ssh.host = "#{data['ssh']['host']}"
  end
  if !data['ssh']['port'].nil?
    config.ssh.port = "#{data['ssh']['port']}"
  end
  if !data['ssh']['username'].nil?
    config.ssh.username = "#{data['ssh']['username']}"
  end
  if !data['ssh']['guest_port'].nil?
    config.ssh.guest_port = data['ssh']['guest_port']
  end
  if !data['ssh']['shell'].nil?
    config.ssh.shell = "#{data['ssh']['shell']}"
  end
  if !data['ssh']['keep_alive'].nil?
    config.ssh.keep_alive = data['ssh']['keep_alive']
  end
  if !data['ssh']['forward_agent'].nil?
    config.ssh.forward_agent = data['ssh']['forward_agent']
  end
  if !data['ssh']['forward_x11'].nil?
    config.ssh.forward_x11 = data['ssh']['forward_x11']
  end
  if !data['vagrant']['host'].nil?
    config.vagrant.host = data['vagrant']['host'].gsub(":", "").intern
  end
end

Config.yaml

---
vagrantfile-local:
    vm:
        box: puphpet/centos65-x64
        box_url: puphpet/centos65-x64
        hostname: null
        memory: '1024'
        chosen_provider: virtualbox
        network:
            private_network: 192.168.56.101
            forwarded_port:
                RVPy8vdfEyb4:
                    host: '5329'
                    guest: '22'
        provider:
            virtualbox:
                modifyvm:
                    natdnshostresolver1: on
                setextradata:
                    VBoxInternal2/SharedFoldersEnableSymlinksCreate/v-root: 1
            vmware:
                numvcpus: 1
            parallels:
                cpus: 1
        provision:
            puppet:
                manifests_path: puphpet/puppet
                manifest_file: manifest.pp
                module_path: puphpet/puppet/modules
                options:
                    - '--verbose'
                    - '--hiera_config /vagrant/puphpet/puppet/hiera.yaml'
                    - '--parser future'
        synced_folder:
            Fmuml1NNvztV:
                source: ./
                target: /var/www
                nfs: 'true'
        usable_port_range: 2200..2250
    ssh:
        host: null
        port: null
        private_key_path: null
        username: vagrant
        guest_port: null
        keep_alive: true
        forward_agent: false
        forward_x11: false
        shell: 'bash -l'
    vagrant:
        host: detect
server:
    packages:
        - vim-common
    dot_files:
        -
            bash_aliases: null
    _prevent_empty: ''
mailcatcher:
    install: '1'
    settings:
        smtp_ip: 0.0.0.0
        smtp_port: 1025
        http_ip: 0.0.0.0
        http_port: '1080'
        mailcatcher_path: /usr/local/bin
        log_path: /var/log/mailcatcher/mailcatcher.log
firewall:
    install: '1'
    rules:
        IzA1MvHnvQ4g:
            port: '10000'
            priority: '100'
            proto: tcp
            action: accept
apache:
    install: '1'
    settings:
        user: www-data
        group: www-data
        default_vhost: true
        manage_user: false
        manage_group: false
        sendfile: 0
    modules:
        - php
        - rewrite
    vhosts:
        jeFgLNotkCuO:
            servername: awesome.dev
            serveraliases:
                - www.awesome.dev
            docroot: /var/www/awesome
            port: '80'
            setenv:
                - 'APP_ENV dev'
            override:
                - All
            options:
                - Indexes
                - FollowSymLinks
                - MultiViews
            custom_fragment: ''
            ssl_cert: ''
            ssl_key: ''
            ssl_chain: ''
            ssl_certs_dir: ''
    mod_pagespeed: 0
    mod_spdy: 0
nginx:
    install: 0
    vhosts:
        ejsUD06Uwceq:
            server_name: awesome.dev
            server_aliases:
                - www.awesome.dev
            www_root: /var/www/awesome.dev
            listen_port: '80'
            index_files:
                - index.html
                - index.htm
                - index.php
            envvars:
                - 'APP_ENV dev'
            ssl_cert: ''
            ssl_key: ''
php:
    install: '1'
    version: '55'
    composer: '1'
    composer_home: ''
    modules:
        php:
            - cli
            - intl
            - mcrypt
        pear: {  }
        pecl:
            - pecl_http
    ini:
        display_errors: On
        error_reporting: '-1'
        session.save_path: /var/lib/php/session
    timezone: America/Chicago
xdebug:
    install: '1'
    settings:
        xdebug.default_enable: '1'
        xdebug.remote_autostart: '0'
        xdebug.remote_connect_back: '1'
        xdebug.remote_enable: '1'
        xdebug.remote_handler: dbgp
        xdebug.remote_port: '9000'
drush:
    install: 0
    settings:
        drush.tag_branch: 6.x
mysql:
    install: '1'
    root_password: '123'
    adminer: 0
    databases:
        JibsW5qqEtvE:
            grant:
                - ALL
            name: REDACTED
            host: localhost
            user: REDACTED
            password: '123'
            sql_file: ''
        TUQ8E8xUDyFi:
            grant:
                - ALL
            name: REDACTED
            host: localhost
            user: REDACTED
            password: '123'
            sql_file: ''
postgresql:
    install: '1'
    settings:
        root_password: '123'
        user_group: postgres
        encoding: UTF8
        version: '9.3'
    databases: {  }
    adminer: 0
mariadb:
    install: 0
    root_password: '123'
    adminer: 0
    databases: {  }
    version: '10.0'
mongodb:
    install: '1'
    settings:
        auth: 1
        port: '27017'
    databases: {  }
redis:
    install: '1'
    settings:
        conf_port: '6379'
beanstalkd:
    install: '1'
    settings:
        listenaddress: 0.0.0.0
        listenport: '13000'
        maxjobsize: '65535'
        maxconnections: '1024'
        binlogdir: /var/lib/beanstalkd/binlog
        binlogfsync: null
        binlogsize: '10485760'
    beanstalk_console: '1'
    binlogdir: /var/lib/beanstalkd/binlog
rabbitmq:
    install: 0
    settings:
        port: '5672'
elastic_search:
    install: '1'
    settings:
        java_install: true
        autoupgrade: true

SELinux dinonaktifkan dan saya memodifikasi iptables saya untuk menerima tcp ke dport 22. Setelah memulai kembali layanan, saya sekarang dapat ssh vagrant@192.168.56.101 tetapi gelandangan masih belum waktunya. Saya cukup bingung pada saat ini ...
DroBuddy

Nah, setelah lari sudo service iptables off Saya sekarang dapat menjangkau google, yum repos, dll. Jadi itu akan menjadi masalah iptables dan bukan masalah jaringan. Sekarang, bagian yang menyenangkan, menambahkan semua aturan iptables yang diperlukan. Argh, ini digunakan untuk pra-konfigurasi kotak gelandangan yang dibangun menggunakan alat PuPHPet. Ternyata ini bukan lagi masalahnya.
DroBuddy

Ah, saya lupa alat kesayangan saya: system-config-firewall-tui. Penghemat waktu yang luar biasa. Saya sangat merekomendasikan ini kepada siapa pun yang kebetulan mengalami masalah ini.
DroBuddy

Situs ini berfungsi paling baik ketika ada pertanyaan dan satu atau lebih jawaban. Anda didorong untuk menambahkan jawaban untuk pertanyaan Anda sendiri.
Brian Adkins

Poin bagus. Saya akan melakukannya. ;)
DroBuddy

Jawaban:


4

Masalahnya adalah bahwa kotak gelandangan CentOS PuPHPet.com tidak lagi datang dengan seperangkat aturan firewall standar. Jadi, untuk menyelesaikan ini, boot VM menggunakan VirtualBox (atau hypervisor mana pun yang Anda gunakan), lalu modifikasi dan simpan /etc/sysconfig/ptables untuk memungkinkan layanan yang Anda inginkan.

Menurut pendapat pribadi saya, cara terbaik untuk mengedit aturan iptables Anda adalah dengan menggunakan alat CLI yang dapat dengan mudah diinstal dengan yum: sudo yum install -y system-config-frewall-tui. Antarmuka pengguna berbasis teks ini memungkinkan Anda untuk dengan mudah mengaktifkan / menonaktifkan layanan standar (httpd, bind, postfix, nfs, dll) menggunakan wizard, serta, membuat aturan khusus untuk port / layanan non-standar (seperti port Webmin 10000 ). Alat ini adalah penghemat waktu sejati.

Jika ini tidak menyelesaikan masalah konektivitas Anda, untuk mengesampingkan apakah itu firewall yang berjalan sudo service iptables off pada tamu dan coba akses SSH dari tuan rumah ( ssh vagrant@my-host-name-or-ip ).

Jika Anda memiliki akses SSH sekarang, maka masalahnya akan menjadi masalah FW dan Anda perlu memeriksa ulang iptables Anda ( apakah Anda menyimpan perubahan Anda? ). Jika Anda masih tidak dapat memperoleh akses SSH, maka kemungkinan besar itu adalah masalah jaringan dan harus dipecahkan masalah tersebut (periksa ifconfig, route, ping dari host ke tamu dan sebaliknya, dll).

HTH.

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.