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

主頁 > 知識庫 > golang實現(xiàn)簡易的分布式系統(tǒng)方法

golang實現(xiàn)簡易的分布式系統(tǒng)方法

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

本文介紹了golang實現(xiàn)簡易的分布式系統(tǒng)方法,分享給大家,具體如下:

功能

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

源碼

package main

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

// 節(jié)點數(shù)據(jù)信息
type NodeInfo struct {

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

// 將節(jié)點數(shù)據(jù)信息格式化輸出
//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 + "}"
}

/* 添加一個節(jié)點到集群的一個請求或者響應的標準格式 */
type AddToClusterMessage struct {
  // 源節(jié)點
  Source NodeInfo `json:"source"`
  // 目的節(jié)點
  Dest NodeInfo `json:"dest"`
  // 兩個節(jié)點連接時發(fā)送的消息
  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() {

  // 解析命令行參數(shù)
  makeMasterOnError := flag.Bool("makeMasterOnError", false, "如果IP地址沒有連接到集群中,我們將其作為Master節(jié)點.")
  clusterip := flag.String("clusterip", "127.0.0.1:8001", "任何的節(jié)點連接都連接這個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)

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

  //fmt.Println(myid)

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

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

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

  /*
   * 監(jiān)聽其他節(jié)點將要加入到集群的請求
   */
  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)
  }

}

/*
 * 這是發(fā)送請求時格式化json包有用的工具
 * 這是非常重要的,如果不經(jīng)過數(shù)據(jù)格式化,你最終發(fā)送的將是空白消息
 */
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的相關細節(jié)信息 */
  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("連接到集群. 發(fā)送消息到節(jié)點.")
    text := "Hi nody.. 請?zhí)砑游业郊?."
    requestMessage := getAddToClusterMessage(me, dest, text)
    json.NewEncoder(connOut).Encode(requestMessage)

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

    return true
  }
  return false
}

func listenOnPort(me NodeInfo){
  /* 監(jiān)聽即將到來的消息 */
  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主節(jié)點

$ ./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.

添加節(jié)點Node2到集群

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

添加節(jié)點Node3到集群

main --myport 8004 --clusterip 127.0.0.1:8001

添加節(jié)點Node4到集群

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

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

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

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

巨人網(wǎng)絡通訊聲明:本文標題《golang實現(xiàn)簡易的分布式系統(tǒng)方法》,本文關鍵詞  golang,實現(xiàn),簡易,的,分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang實現(xiàn)簡易的分布式系統(tǒng)方法》相關的同類信息!
  • 本頁收集關于golang實現(xiàn)簡易的分布式系統(tǒng)方法的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品麻豆欧美日韩ww| 一区二区欧美国产| 中文字幕在线不卡| 欧美一级搡bbbb搡bbbb| 91网站最新地址| 高清不卡在线观看av| 另类小说一区二区三区| 亚洲尤物视频在线| 自拍av一区二区三区| 日韩欧美的一区| 3atv在线一区二区三区| 91久久国产综合久久| 国产xxx精品视频大全| 一区二区三区不卡在线观看| 中文字幕二三区不卡| 久久蜜桃香蕉精品一区二区三区| 成人综合婷婷国产精品久久蜜臀| 亚洲综合视频网| 亚洲免费资源在线播放| 亚洲日本欧美天堂| 一区二区三区在线观看国产| 亚洲欧美日韩在线播放| 亚洲欧美日韩在线播放| 亚洲男同性视频| 亚洲国产日韩a在线播放| 一区二区三区精品久久久| 亚洲日本va午夜在线影院| 亚洲色图另类专区| 亚洲欧美电影一区二区| 一区二区三区精品在线| 三级不卡在线观看| 久久国产精品72免费观看| 免费一级欧美片在线观看| 伊人婷婷欧美激情| 亚洲国产一区二区三区 | 欧美草草影院在线视频| 欧美一区二区性放荡片| 欧美群妇大交群的观看方式| 精品免费国产一区二区三区四区| 精品1区2区在线观看| 国产日韩欧美麻豆| 国产精品高潮久久久久无| 夜夜精品视频一区二区| 首页综合国产亚洲丝袜| 久久成人免费网| 粉嫩蜜臀av国产精品网站| 色吊一区二区三区| 555www色欧美视频| 国产色产综合色产在线视频| 国产性天天综合网| 国产精品萝li| 日韩精品1区2区3区| 国产伦精品一区二区三区免费| 成人网页在线观看| 欧美电影一区二区| 国产精品国产自产拍在线| 午夜欧美在线一二页| 国产麻豆精品在线| 在线观看国产日韩| 国产欧美综合在线| 亚洲在线视频网站| 国产精品综合二区| 欧美午夜精品久久久久久超碰| 欧美一级在线免费| 国产精品久久免费看| 免费欧美高清视频| 在线观看免费一区| 国产精品黄色在线观看| 久久99久国产精品黄毛片色诱| www.在线成人| 久久这里只有精品6| 亚洲v日本v欧美v久久精品| 成人高清免费观看| 欧美性一二三区| 国产精品久久久久永久免费观看| 美国精品在线观看| 欧美高清性hdvideosex| 亚洲人快播电影网| 国产宾馆实践打屁股91| 欧美日韩你懂得| 日韩理论片一区二区| 久久精品国产99| 欧美理论电影在线| 夜夜嗨av一区二区三区网页| 成人一区二区三区视频在线观看 | 久久精品欧美一区二区三区麻豆 | 国产精品美女一区二区在线观看| 日韩精品乱码av一区二区| 成人av手机在线观看| 久久免费偷拍视频| 日韩国产在线一| 色久优优欧美色久优优| 亚洲免费三区一区二区| av中文字幕不卡| 中文字幕一区二区日韩精品绯色| 国产盗摄一区二区| 国产日本亚洲高清| 大白屁股一区二区视频| 26uuu色噜噜精品一区| 久久av中文字幕片| 久久众筹精品私拍模特| 国产ts人妖一区二区| 久久免费看少妇高潮| 午夜精品在线看| 欧美sm美女调教| 懂色av一区二区三区免费看| 国产精品毛片高清在线完整版| 国产一区二区三区在线观看精品| 久久久久久久久久看片| 国产一区二区美女| 国产精品美日韩| 欧美久久免费观看| 久久成人免费网| 欧美国产日韩精品免费观看| 92国产精品观看| 亚洲一区二区欧美激情| 欧美系列日韩一区| 免费成人美女在线观看.| 精品电影一区二区| 成人a级免费电影| 午夜精品久久久久久久久久久| 欧美一二三区精品| 国产69精品久久久久777| 亚洲激情欧美激情| 26uuu欧美| 欧美日韩综合不卡| 麻豆精品一区二区三区| 欧美人xxxx| 国产91丝袜在线播放九色| 亚洲自拍另类综合| 精品国产免费视频| 91福利视频网站| 国产综合成人久久大片91| 自拍视频在线观看一区二区| 91麻豆精品国产91久久久久| 国产mv日韩mv欧美| 午夜精品一区二区三区电影天堂| 欧美国产精品v| 日韩一区二区不卡| 在线国产亚洲欧美| 国产suv精品一区二区883| 午夜免费久久看| 国产午夜亚洲精品羞羞网站| 欧美日韩国产大片| 99精品欧美一区二区蜜桃免费 | 欧美精品成人一区二区三区四区| 国产一区二区福利| 午夜在线电影亚洲一区| 国产精品久久国产精麻豆99网站| 欧美日韩中文另类| 99麻豆久久久国产精品免费优播| 精品一二三四区| 午夜精品久久久久久久蜜桃app| 久久综合久久综合久久| 欧美一区二区啪啪| 欧美挠脚心视频网站| 91蜜桃在线免费视频| 国产一区视频网站| 国产麻豆欧美日韩一区| 韩国一区二区在线观看| 成人污视频在线观看| 成人18视频在线播放| 99精品视频免费在线观看| 国产成人av电影在线播放| 国产a精品视频| 91一区二区三区在线播放| 一本一道久久a久久精品 | 欧美一级在线观看| 久久久久久久综合色一本| 成人免费在线观看入口| 亚洲成av人片观看| 国产伦精品一区二区三区免费 | 中文字幕国产精品一区二区| 国产精品久久久久久久久久久免费看| 国产精品污网站| 一区二区三区日本| 免费成人av资源网| 成人av集中营| 欧美日韩亚洲综合一区二区三区| 精品国产一二三| 18欧美乱大交hd1984| 麻豆国产精品一区二区三区| 成人免费毛片app| 在线观看91av| 国产精品进线69影院| 免费观看在线综合色| 99麻豆久久久国产精品免费| 日韩欧美亚洲一区二区| 亚洲欧洲性图库| 青青青伊人色综合久久| 99久久99久久久精品齐齐| 91精品国产免费| 亚洲卡通动漫在线| 国内成人精品2018免费看| 欧美区视频在线观看| 欧美国产欧美综合| 狠狠色丁香婷婷综合久久片| 91福利精品视频| 日本一区二区三区高清不卡| 日韩**一区毛片|