中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

docker快速安裝rabbitmq的詳細流程步驟

發布時間:2020-07-15 11:50:11 來源:億速云 閱讀:210 作者:清晨 欄目:開發技術

這篇文章將為大家詳細講解有關docker快速安裝rabbitmq的詳細流程步驟,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、獲取鏡像

#指定版本,該版本包含了web控制頁面
docker pull rabbitmq:management

二、運行鏡像

#方式一:默認guest 用戶,密碼也是 guest
docker run -d --hostname my-rabbit --name rabbit -p 15672:15672 -p 5672:5672 rabbitmq:management

#方式二:設置用戶名和密碼
docker run -d --hostname my-rabbit --name rabbit -e RABBITMQ_DEFAULT_USER=user -e RABBITMQ_DEFAULT_PASS=password -p 15672:15672 -p 5672:5672 rabbitmq:management

三、訪問ui頁面

http://localhost:15672/

docker快速安裝rabbitmq的詳細流程步驟

四、golang案例

#producer生產者代碼
package main

import (
  "fmt"

  "log"

  "github.com/streadway/amqp"
)

const (
  //AMQP URI

  uri = "amqp://guest:guest@10.0.0.11:5672/" // 10.0.0.11為主機ip

  //Durable AMQP exchange name

  exchangeName = ""

  //Durable AMQP queue name

  queueName = "test-queues"

  //Body of message

  bodyMsg string = "hello angel"
)

//如果存在錯誤,則輸出

func failOnError(err error, msg string) {

  if err != nil {

    log.Fatalf("%s: %s", msg, err)

    panic(fmt.Sprintf("%s: %s", msg, err))

  }

}

func main() {

  //調用發布消息函數

  publish(uri, exchangeName, queueName, bodyMsg)

  log.Printf("published %dB OK", len(bodyMsg))

}

//發布者的方法

//@amqpURI, amqp的地址

//@exchange, exchange的名稱

//@queue, queue的名稱

//@body, 主體內容

func publish(amqpURI string, exchange string, queue string, body string) {

  //建立連接

  log.Printf("dialing %q", amqpURI)

  connection, err := amqp.Dial(amqpURI)

  failOnError(err, "Failed to connect to RabbitMQ")

  defer connection.Close()

  //創建一個Channel

  log.Printf("got Connection, getting Channel")

  channel, err := connection.Channel()

  failOnError(err, "Failed to open a channel")

  defer channel.Close()

  log.Printf("got queue, declaring %q", queue)

  //創建一個queue

  q, err := channel.QueueDeclare(

    queueName, // name

    false, // durable

    false, // delete when unused

    false, // exclusive

    false, // no-wait

    nil, // arguments

  )

  failOnError(err, "Failed to declare a queue")

  log.Printf("declared queue, publishing %dB body (%q)", len(body), body)

  // Producer只能發送到exchange,它是不能直接發送到queue的

  // 現在我們使用默認的exchange(名字是空字符)這個默認的exchange允許我們發送給指定的queue

  // routing_key就是指定的queue名字

  err = channel.Publish(

    exchange, // exchange

    q.Name, // routing key

    false, // mandatory

    false, // immediate

    amqp.Publishing{

      Headers: amqp.Table{},

      ContentType: "text/plain",

      ContentEncoding: "",

      Body: []byte(body),
    })

  failOnError(err, "Failed to publish a message")

}

docker快速安裝rabbitmq的詳細流程步驟

五、擁有消息確認的代碼

#producer
package main

import (
  "fmt"
  "github.com/streadway/amqp"
  "log"
  "os"
  "strings"
)

const (
  //AMQP URI
  uri = "amqp://guest:guest@10.0.0.11:5672/"
  //Durable AMQP exchange name
  exchangeName = ""
  //Durable AMQP queue name
  queueName = "test-queues-acknowledgments"
)

//如果存在錯誤,則輸出
func failOnError(err error, msg string) {
  if err != nil {
    log.Fatalf("%s: %s", msg, err)
    panic(fmt.Sprintf("%s: %s", msg, err))
  }
}

func main() {
  bodyMsg := bodyFrom(os.Args)
  //調用發布消息函數
  publish(uri, exchangeName, queueName, bodyMsg)
  log.Printf("published %dB OK", len(bodyMsg))
}

func bodyFrom(args []string) string {
  var s string
  if (len(args) < 2) || os.Args[1] == "" {
    s = "hello angel"
  } else {
    s = strings.Join(args[1:], " ")
  }
  return s
}

//發布者的方法
//@amqpURI, amqp的地址
//@exchange, exchange的名稱
//@queue, queue的名稱
//@body, 主體內容
func publish(amqpURI string, exchange string, queue string, body string) {
  //建立連接
  log.Printf("dialing %q", amqpURI)
  connection, err := amqp.Dial(amqpURI)
  failOnError(err, "Failed to connect to RabbitMQ")
  defer connection.Close()

  //創建一個Channel
  log.Printf("got Connection, getting Channel")
  channel, err := connection.Channel()
  failOnError(err, "Failed to open a channel")
  defer channel.Close()

  log.Printf("got queue, declaring %q", queue)

  //創建一個queue
  q, err := channel.QueueDeclare(
    queueName, // name
    false,   // durable
    false,   // delete when unused
    false,   // exclusive
    false,   // no-wait
    nil,    // arguments
  )
  failOnError(err, "Failed to declare a queue")

  log.Printf("declared queue, publishing %dB body (%q)", len(body), body)

  // Producer只能發送到exchange,它是不能直接發送到queue的。
  // 現在我們使用默認的exchange(名字是空字符)。這個默認的exchange允許我們發送給指定的queue。
  // routing_key就是指定的queue名字。
  err = channel.Publish(
    exchange, // exchange
    q.Name,  // routing key
    false,  // mandatory
    false,  // immediate
    amqp.Publishing{
      Headers:     amqp.Table{},
      ContentType:   "text/plain",
      ContentEncoding: "",
      Body:      []byte(body),
    })
  failOnError(err, "Failed to publish a message")
}

關于docker快速安裝rabbitmq的詳細流程步驟就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

郁南县| 灯塔市| 怀远县| 兴仁县| 乌苏市| 易门县| 宜宾市| 沁阳市| 泸州市| 福清市| 望都县| 乌苏市| 双牌县| 安国市| 湖南省| 乌海市| 板桥市| 锦州市| 黄冈市| 台江县| 仲巴县| 北辰区| 鸡东县| 寿宁县| 新野县| 水城县| 子长县| 托克逊县| 汽车| 乐清市| 桦南县| 诏安县| 本溪市| 乃东县| 会泽县| 贵港市| 即墨市| 收藏| 犍为县| 仙游县| 海城市|