首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何配置Vagrant,使主机能够与运行在VM上的kafka-docker通信?

如何配置Vagrant,使主机能够与运行在VM上的kafka-docker通信?
EN

Stack Overflow用户
提问于 2018-05-06 21:26:58
回答 1查看 907关注 0票数 1

我让卡夫卡-码头运行在一个上。我可以使用运行在VM上的NodeJs程序生成和使用消息给它。

但是,我无法使用Windows主机上相同的NodeJs程序,程序似乎可以到达,但没有收到任何答复。

这是我的docker-compose.yml文件:

代码语言:javascript
复制
 version: '2'
 services:
   zookeeper:
     image: "wurstmeister/zookeeper:latest"
     network_mode: "host"
     ports:
       - "2181:2181"
   kafka:
     image: "wurstmeister/kafka:latest"
     network_mode: "host"
     ports:
       - 9092:9092
     environment:
       KAFKA_LISTENERS: PLAINTEXT://:9092
       KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://172.17.0.1:9092
       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
       KAFKA_CREATE_TOPICS: "BertTopic:3:1"

这是我的Vagrantfile文件:

代码语言:javascript
复制
SRCMOUNT = "/hyperledger"
LOCALDEV = "/local-dev"

$script = <<SCRIPT
set -x

echo "127.0.0.1 couchdb" | tee -a /etc/hosts

cd #{SRCMOUNT}/fabric/devenv
./setup.sh

SCRIPT

Vagrant.require_version ">= 1.7.4"
Vagrant.configure('2') do |config|
  config.vm.box = "ubuntu/xenial64"
  config.vm.network :forwarded_port, guest: 2181, host: 2181, id: "zookeeper", host_ip: "localhost", auto_correct: true # zookeeper 
  config.vm.network :forwarded_port, guest: 9092, host: 9092, id: "kafka", host_ip: "localhost", auto_correct: true # kafka
  config.vm.network :forwarded_port, guest: 7050, host: 7050, id: "orderer", host_ip: "localhost", auto_correct: true # fabric orderer service
  config.vm.network :forwarded_port, guest: 7051, host: 7051, id: "peer", host_ip: "localhost", auto_correct: true # fabric peer service
  config.vm.network :forwarded_port, guest: 7053, host: 7053, id: "peer_event", host_ip: "localhost", auto_correct: true # fabric peer event service
  config.vm.network :forwarded_port, guest: 7054, host: 7054, id: "ca", host_ip: "localhost", auto_correct: true # fabric-ca service
  config.vm.network :forwarded_port, guest: 5984, host: 15984, id: "couchdb", host_ip: "localhost", auto_correct: true # CouchDB service
  config.vm.synced_folder "../..", "#{SRCMOUNT}"
  config.vm.synced_folder "../..", "/opt/gopath/src/github.com/hyperledger"
  config.vm.synced_folder ENV.fetch('LOCALDEVDIR', "../.."), "#{LOCALDEV}"
  config.vm.provider :virtualbox do |vb|
    vb.name = "kafkadocker"
    vb.customize ['modifyvm', :id, '--memory', '4096']
    vb.cpus = 2

    storage_backend = ENV['DOCKER_STORAGE_BACKEND']
    case storage_backend
    when nil,"","aufs","AUFS"
      # No extra work to be done
    when "btrfs","BTRFS"
      # Add a second disk for the btrfs volume
      IO.popen("VBoxManage list systemproperties") { |f|

        success = false
        while line = f.gets do
          # Find the directory where the machine images are stored
          machine_folder = line.sub(/^Default machine folder:\s*/,"")

          if line != machine_folder
            btrfs_disk = File.join(machine_folder, vb.name, 'btrfs.vdi')

            unless File.exist?(btrfs_disk)
              # Create the disk if it doesn't already exist
              vb.customize ['createhd', '--filename', btrfs_disk, '--format', 'VDI', '--size', 20 * 1024]
            end

            # Add the disk to the VM
            vb.customize ['storageattach', :id, '--storagectl', 'SATA Controller', '--port', 1, '--device', 0, '--type', 'hdd', '--medium', btrfs_disk]
            success = true

            break
          end
        end
        raise Vagrant::Errors::VagrantError.new, "Could not provision btrfs disk" if !success
      }
    else
      raise Vagrant::Errors::VagrantError.new, "Unknown storage backend type: #{storage_backend}"
    end

  end

  config.vm.provision :shell, inline: $script
end

我在Linux上的ifconfig显示:

代码语言:javascript
复制
docker0   Link encap:Ethernet  HWaddr 02:42:11:89:57:c8
          inet addr:172.17.0.1  Bcast:172.17.255.255  Mask:255.255.0.0

下面是我在Ubuntu上的/etc/host文件:

代码语言:javascript
复制
127.0.0.1       localhost
127.0.0.1               zookeeper
127.0.0.1               kafkadocker

任何帮助都非常感谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-10 16:32:20

最后,当我看到Windows连接中的nodejs程序时,我想出了如何克服"Error: connecting“的问题,但失败了。

这是简单的食谱。

首先,在Vagrantfile中,除了上面列出的转发端口行之外,还为Oracle Virtualbox vm提供一个带有行的正确名称:

代码语言:javascript
复制
# after line: config.vm.provider :virtualbox do |vb|
    vb.name = "kafkadocker"

使用以下内容启动vm:

代码语言:javascript
复制
vagrant up

接下来,在Windows命令提示符中,执行以下操作:

代码语言:javascript
复制
ipconfig

注意Oracle Virtualbox vm的IP地址,对我来说重要的行是:

代码语言:javascript
复制
Ethernet adapter VirtualBox Host-Only Network:

   Connection-specific DNS Suffix  . :
   Link-local IPv6 Address . . . . . : fe80::9900:a662:107f:3420%11
   IPv4 Address. . . . . . . . . . . : 192.168.56.1

接下来,我们需要配置Windows,以便了解当有人告诉它连接到服务器"kafkadocker“时,它需要转到IP地址192.168.56.1,因此打开Notepad++作为管理员,并将下面的行添加到文件C:\Windows\System32 32\drivers\etc\host:

代码语言:javascript
复制
192.168.56.1    kafkadocker

接下来,在vm中,编辑docker-compose.yml并将其更改为:

代码语言:javascript
复制
version: '2'
services:
  zookeeper:
    image: "wurstmeister/zookeeper:latest"
    network_mode: "host"
    ports:
      - "2181:2181"
  kafka:
    image: "wurstmeister/kafka:latest"
    network_mode: "host"
    ports:
      - 9092
    environment:
      KAFKA_LISTENERS: PLAINTEXT://:9092
      KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafkadocker:9092
      KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
      KAFKA_CREATE_TOPICS: "BertTopic:3:1"

最重要的是KAFKA_ADVERTISED_LISTENERS。在连接上,Kafka会告诉Windows上的客户端将密码转到服务器"kafkadocker“。现在,由于Windows主机文件,节点程序将知道要转到哪个IP。

现在使用以下内容启动VM中的kafka-docker:

代码语言:javascript
复制
 docker-compose up -d

在Windows打开Visual代码中的下一步:

代码语言:javascript
复制
cd c:\nodecode
code .

运行nodejs程序。制片人:

代码语言:javascript
复制
var kafka = require('kafka-node'),
    Producer = kafka.Producer,
    KeyedMessage = kafka.KeyedMessage,
    client = new kafka.Client(),
    producer = new Producer(client),
    km = new KeyedMessage('key', 'message'),
    payloads = [
        { topic: 'BertTopic', messages: 'first message', partition: 0 },
        { topic: 'BertTopic', messages: 'second message', partition: 0 },
        { topic: 'BertTopic', messages: 'third message', partition: 0 }
    ];
producer.on('ready', function () {
    producer.send(payloads, function (err, data) {
        console.log(data);
        process.exit(0);
    });
});

producer.on('error', function (err) {
console.log('ERROR: ' + err.toString());
});

对于使用者(从一开始就读取所有消息):

代码语言:javascript
复制
var kafka = require('kafka-node'),
    Consumer = kafka.Consumer,
    client = new kafka.Client(),
    consumer = new Consumer(
        client,
        [
              { topic: 'BertTopic', partition: 0, offset: 0 }
        ],
        { fromOffset: true }         
    );

consumer.on('message', function (message) 
{
    console.log(message);
});

consumer.on('error', function (err) 
{
    console.log('ERROR ' + err.toString());
});

希望这能帮上忙。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50204667

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档