婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang實現簡易的分布式系統方法

golang實現簡易的分布式系統方法

熱門標簽:西部云谷一期地圖標注 地圖標注的汽車標 學海導航地圖標注 高德地圖標注口訣 南通如皋申請開通400電話 中國地圖標注省會高清 浙江高速公路地圖標注 廣州呼叫中心外呼系統 江西轉化率高的羿智云外呼系統

本文介紹了golang實現簡易的分布式系統方法,分享給大家,具體如下:

功能

  • 能夠發送/接收請求和響應
  • 能夠連接到集群
  • 如果無法連接到群集(如果它是第一個節點),則可以作為主節點啟動節點
  • 每個節點有唯一的標識
  • 能夠在節點之間交換json數據包
  • 接受命令行參數中的所有信息(將來在我們系統升級時將會很有用)

源碼

package main

import (
  "fmt"
  "strconv"
  "time"
  "math/rand"
  "net"
  "flag"
  "strings"
  "encoding/json"
)

// 節點數據信息
type NodeInfo struct {

  // 節點ID,通過隨機數生成
  NodeId int `json:"nodeId"`
  // 節點IP地址
  NodeIpAddr string `json:"nodeIpAddr"`
  // 節點端口
  Port string `json: "port"`
}

// 將節點數據信息格式化輸出
//NodeInfo:{nodeId: 89423,nodeIpAddr: 127.0.0.1/8,port: 8001}
func (node *NodeInfo) String() string {

  return "NodeInfo:{ nodeId:" + strconv.Itoa(node.NodeId) + ",nodeIpAddr:" + node.NodeIpAddr + ",port:" + node.Port + "}"
}

/* 添加一個節點到集群的一個請求或者響應的標準格式 */
type AddToClusterMessage struct {
  // 源節點
  Source NodeInfo `json:"source"`
  // 目的節點
  Dest NodeInfo `json:"dest"`
  // 兩個節點連接時發送的消息
  Message string `json:"message"`
}

/* Request/Response 信息格式化輸出 */
func (req AddToClusterMessage) String() string {
  return "AddToClusterMessage:{\n source:" + req.Source.String() + ",\n dest: " + req.Dest.String() + ",\n message:" + req.Message + " }"
}

// cat vi go
// rm

func main() {

  // 解析命令行參數
  makeMasterOnError := flag.Bool("makeMasterOnError", false, "如果IP地址沒有連接到集群中,我們將其作為Master節點.")
  clusterip := flag.String("clusterip", "127.0.0.1:8001", "任何的節點連接都連接這個IP")
  myport := flag.String("myport", "8001", "ip address to run this node on. default is 8001.")
  flag.Parse() //解析

  fmt.Println(*makeMasterOnError)
  fmt.Println(*clusterip)
  fmt.Println(*myport)

  /* 為節點生成ID */
  rand.Seed(time.Now().UTC().UnixNano()) //種子
  myid := rand.Intn(99999999) // 隨機

  //fmt.Println(myid)

  // 獲取IP地址
  myIp,_ := net.InterfaceAddrs()
  fmt.Println(myIp[0])

  // 創建NodeInfo結構體對象
  me := NodeInfo{NodeId: myid, NodeIpAddr: myIp[0].String(), Port: *myport}
  // 輸出結構體數據信息
  fmt.Println(me.String())
  dest := NodeInfo{ NodeId: -1, NodeIpAddr: strings.Split(*clusterip, ":")[0], Port: strings.Split(*clusterip, ":")[1]}

  /* 嘗試連接到集群,在已連接的情況下并且向集群發送請求 */
  ableToConnect := connectToCluster(me, dest)

  /*
   * 監聽其他節點將要加入到集群的請求
   */
  if ableToConnect || (!ableToConnect  *makeMasterOnError) {
    if *makeMasterOnError {fmt.Println("Will start this node as master.")}
    listenOnPort(me)
  } else {
    fmt.Println("Quitting system. Set makeMasterOnError flag to make the node master.", myid)
  }

}

/*
 * 這是發送請求時格式化json包有用的工具
 * 這是非常重要的,如果不經過數據格式化,你最終發送的將是空白消息
 */
func getAddToClusterMessage(source NodeInfo, dest NodeInfo, message string) (AddToClusterMessage){
  return AddToClusterMessage{
    Source: NodeInfo{
      NodeId: source.NodeId,
      NodeIpAddr: source.NodeIpAddr,
      Port: source.Port,
    },
    Dest: NodeInfo{
      NodeId: dest.NodeId,
      NodeIpAddr: dest.NodeIpAddr,
      Port: dest.Port,
    },
    Message: message,
  }
}

func connectToCluster(me NodeInfo, dest NodeInfo) (bool){
  /* 連接到socket的相關細節信息 */
  connOut, err := net.DialTimeout("tcp", dest.NodeIpAddr + ":" + dest.Port, time.Duration(10) * time.Second)
  if err != nil {
    if _, ok := err.(net.Error); ok {
      fmt.Println("未連接到集群.", me.NodeId)
      return false
    }
  } else {
    fmt.Println("連接到集群. 發送消息到節點.")
    text := "Hi nody.. 請添加我到集群.."
    requestMessage := getAddToClusterMessage(me, dest, text)
    json.NewEncoder(connOut).Encode(requestMessage)

    decoder := json.NewDecoder(connOut)
    var responseMessage AddToClusterMessage
    decoder.Decode(responseMessage)
    fmt.Println("得到數據響應:\n" + responseMessage.String())

    return true
  }
  return false
}

func listenOnPort(me NodeInfo){
  /* 監聽即將到來的消息 */
  ln, _ := net.Listen("tcp", fmt.Sprint(":" + me.Port))
  /* 接受連接 */
  for {
    connIn, err := ln.Accept()
    if err != nil {
      if _, ok := err.(net.Error); ok {
        fmt.Println("Error received while listening.", me.NodeId)
      }
    } else {
      var requestMessage AddToClusterMessage
      json.NewDecoder(connIn).Decode(requestMessage)
      fmt.Println("Got request:\n" + requestMessage.String())

      text := "Sure buddy.. too easy.."
      responseMessage := getAddToClusterMessage(me, requestMessage.Source, text)
      json.NewEncoder(connIn).Encode(responseMessage)
      connIn.Close()
    }
  }
}

運行程序

/Users/liyuechun/go
liyuechun:go yuechunli$ go install main
liyuechun:go yuechunli$ main
My details: NodeInfo:{ nodeId:53163002, nodeIpAddr:127.0.0.1/8, port:8001 }
不能連接到集群. 53163002
Quitting system. Set makeMasterOnError flag to make the node master. 53163002
liyuechun:go yuechunli$

獲取相關幫助信息

$ ./bin/main -h
liyuechun:go yuechunli$ ./bin/main -h
Usage of ./bin/main:
 -clusterip string
    ip address of any node to connnect (default "127.0.0.1:8001")
 -makeMasterOnError
    make this node master if unable to connect to the cluster ip provided.
 -myport string
    ip address to run this node on. default is 8001. (default "8001")
liyuechun:go yuechunli$

啟動Node1主節點

$ ./bin/main --makeMasterOnError
liyuechun:go yuechunli$ ./bin/main --makeMasterOnError
My details: NodeInfo:{ nodeId:82381143, nodeIpAddr:127.0.0.1/8, port:8001 }
未連接到集群. 82381143
Will start this node as master.

添加節點Node2到集群

$ ./bin/main --myport 8002 --clusterip 127.0.0.1:8001

添加節點Node3到集群

main --myport 8004 --clusterip 127.0.0.1:8001

添加節點Node4到集群

$ main --myport 8003 --clusterip 127.0.0.1:8002

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • GO語言實現簡單的目錄復制功能
  • Go語言實現互斥鎖、隨機數、time、List
  • Golang獲取當前時間代碼
  • Golang字符串的拼接方法匯總
  • Go語言中 Channel 詳解
  • go語言中strings包的用法匯總
  • Golang中的變量學習小結
  • Golang中的自定義函數詳解
  • 在Go中復制文件最流行的3種方法

標簽:貴州 東營 德宏 許昌 吐魯番 保定 曲靖 常州

巨人網絡通訊聲明:本文標題《golang實現簡易的分布式系統方法》,本文關鍵詞  golang,實現,簡易,的,分布式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang實現簡易的分布式系統方法》相關的同類信息!
  • 本頁收集關于golang實現簡易的分布式系統方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    色婷婷激情综合| 欧美韩日一区二区三区| 久久综合色婷婷| 极品美女销魂一区二区三区| 日韩欧美国产精品| 中文字幕不卡三区| 欧美一区二区三区视频| 欧美性受xxxx| 欧美三级韩国三级日本一级| 色八戒一区二区三区| 99久久精品国产精品久久| 国产传媒一区在线| 国产美女在线观看一区| 精品一区二区影视| 激情综合网激情| 精品一二线国产| 极品少妇xxxx偷拍精品少妇| 黄页视频在线91| 九一久久久久久| 国产精品一区二区久激情瑜伽 | 成人一区在线看| 国产九色sp调教91| 成人激情免费电影网址| av电影在线不卡| 日韩三区在线观看| 97精品国产露脸对白| 国产精品99久久久久久久vr| 国产乱码字幕精品高清av| 国产精品综合在线视频| 国产成人免费视频网站| va亚洲va日韩不卡在线观看| 99国产精品久久久久| 在线一区二区三区四区五区 | 国产欧美日韩在线| 国产精品乱码妇女bbbb| 成人免费一区二区三区在线观看| 亚洲欧美精品午睡沙发| 亚洲成人免费在线观看| 久久不见久久见免费视频7 | 国内一区二区视频| 国产成人在线电影| 99国产一区二区三精品乱码| 一本大道av一区二区在线播放| 欧美精品黑人性xxxx| 久久久综合精品| 亚洲男人的天堂av| 午夜精品久久久久久久久久| 国产一区二区三区精品视频| 国产精品免费免费| 久久综合狠狠综合久久综合88| 欧美日韩夫妻久久| 欧美视频在线观看一区二区| 国产精品18久久久久久久久 | 麻豆国产精品777777在线| 国产一区二区三区av电影| 91啪在线观看| 精品区一区二区| 亚洲综合网站在线观看| 国产精品一二三区| 欧美精品自拍偷拍| 中文字幕人成不卡一区| 久久精品国产在热久久| 欧美图区在线视频| 国产精品美女久久久久久久 | 亚洲国产精品传媒在线观看| 亚洲国产精品一区二区久久| 国产成人aaaa| 欧美一区欧美二区| 日本不卡视频一二三区| 图片区小说区国产精品视频| 日本成人在线看| 国产在线看一区| 国产99久久久国产精品潘金| 国产成人av一区二区| 国产欧美精品一区aⅴ影院| 激情另类小说区图片区视频区| 欧美一级一区二区| 亚洲成人激情av| 91国偷自产一区二区三区观看| 亚洲综合色区另类av| 亚洲你懂的在线视频| 亚洲一区在线观看免费观看电影高清| 亚洲va国产天堂va久久en| 蜜桃视频一区二区三区在线观看| 国产专区欧美精品| a美女胸又www黄视频久久| 在线观看一区不卡| 日韩免费性生活视频播放| 国产日韩欧美a| 亚洲男同1069视频| 久久精品国产澳门| av网站免费线看精品| 欧美日韩国产首页| 国产亚洲短视频| 亚洲国产精品久久不卡毛片| 国产剧情一区在线| 欧美三区在线视频| 国产欧美精品日韩区二区麻豆天美| 日韩伦理av电影| 精品一区二区三区欧美| 色悠久久久久综合欧美99| 26uuu亚洲综合色| 国产成人午夜电影网| 中文字幕在线观看不卡| 欧美大片一区二区| 久久久久久久久97黄色工厂| 亚洲第一综合色| 91丝袜美女网| 日本一区二区免费在线观看视频| 午夜精品在线看| 99精品久久只有精品| 国产一区二区在线影院| av中文字幕在线不卡| 91精品一区二区三区久久久久久| 奇米888四色在线精品| 精品久久久久香蕉网| 成人免费精品视频| 亚洲一区二区三区三| 91精品国产综合久久久久久漫画 | 色综合咪咪久久| 欧美一级黄色录像| 国内精品久久久久影院薰衣草 | 国产网红主播福利一区二区| 高清av一区二区| 亚洲激情成人在线| 91精品国产综合久久久久久久久久 | 亚洲成人精品影院| 欧美日韩精品综合在线| 亚洲大片免费看| 欧美tickling网站挠脚心| 秋霞电影一区二区| 久久99久久精品| 久久欧美一区二区| 婷婷六月综合网| 中文字幕欧美激情| 欧美在线|欧美| 国产精品自拍三区| 亚洲国产日韩a在线播放性色| 精品99999| 精品视频色一区| 丁香另类激情小说| 丝袜美腿亚洲色图| 综合婷婷亚洲小说| 久久久久久久综合色一本| 色综合久久天天| 久久av资源站| 一区二区三区四区不卡视频| 亚洲精品一线二线三线| 欧美在线制服丝袜| 粉嫩绯色av一区二区在线观看| 日韩精品成人一区二区在线| 亚洲日本欧美天堂| 国产女主播一区| 欧美岛国在线观看| 在线成人av网站| 一本大道综合伊人精品热热| 国产91高潮流白浆在线麻豆| 精品一区二区三区免费毛片爱| 午夜伦理一区二区| 亚洲无线码一区二区三区| 国产精品自拍网站| 精品噜噜噜噜久久久久久久久试看 | 夜夜嗨av一区二区三区| 欧美欧美欧美欧美| 久久99精品国产91久久来源| 欧美激情在线免费观看| 色呦呦网站一区| 久久国产生活片100| 久久精品视频在线看| 亚洲欧洲日韩av| 欧美日韩一区二区在线观看| 成人精品鲁一区一区二区| 国产一区二区三区| 国产成人亚洲综合色影视| 久久国产生活片100| 精品综合久久久久久8888| 亚洲第一久久影院| 亚洲国产日韩综合久久精品| 亚洲国产成人va在线观看天堂| 亚洲一二三四久久| 亚洲国产欧美日韩另类综合| 日韩高清在线不卡| 免费一级欧美片在线观看| 秋霞午夜av一区二区三区| 狠狠色丁香久久婷婷综合丁香| 国产成人综合在线| 成人国产在线观看| 北条麻妃一区二区三区| 91丨九色丨蝌蚪丨老版| 欧美色欧美亚洲另类二区| 日韩亚洲电影在线| 国产亚洲美州欧州综合国| 日韩美女视频一区二区| 午夜一区二区三区在线观看| 日产精品久久久久久久性色| 久久精品国产亚洲aⅴ| 国产不卡高清在线观看视频| 99久久精品国产网站| 日韩黄色一级片| 亚洲精品一区二区三区香蕉|