91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

bytom初始化時產生了什么配置文件

發布時間:2021-12-20 17:42:44 來源:億速云 閱讀:115 作者:iii 欄目:互聯網科技

本篇內容介紹了“bytom初始化時產生了什么配置文件”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

使用以下命令將代碼切換到v1.0.1的tag,以便與本系列引用的代碼一致:

git fetch
git checkout -b v1.0.1

問題

當我們本地使用make bytomd編譯完比原后,我們可以使用下面的命令來進行初始化:

./bytomd init --chain_id testnet

這里指定了使用的chain是testnet(還有別的選項,如mainnet等等)。運行成功后,它將會在本地文件系統生成一些配置文件,供比原啟動時使用。

所以我的問題是:

比原初始化時,產生了什么樣的配置文件,放在了哪個目錄下?

下面我將結合源代碼,來回答這個問題。

目錄位置

首先比原在本地會有一個目錄專門用于放置各種數據,比如密鑰、配置文件、數據庫文件等。這個目錄對應的代碼位于config/config.go#L190-L205:

func DefaultDataDir() string {
    // Try to place the data folder in the user's home dir
    home := homeDir()
    dataDir := "./.bytom"
    if home != "" {
        switch runtime.GOOS {
        case "darwin":
            dataDir = filepath.Join(home, "Library", "Bytom")
        case "windows":
            dataDir = filepath.Join(home, "AppData", "Roaming", "Bytom")
        default:
            dataDir = filepath.Join(home, ".bytom")
        }
    }
    return dataDir
}

可以看到,在不同的操作系統上,數據目錄的位置也不同:

  1. 蘋果系統(darwin):~/Library/Bytom

  2. Windows(windows): ~/AppData/Roaming/Bytom

  3. 其它(如Linux):~/.bytom

配置文件內容

我們根據自己的操作系統打開相應的目錄(我的是~/Library/Bytom),可以看到有一個config.toml,內容大約如下:

$ cat config.toml
# This is a TOML config file.
# For more information, see https://github.com/toml-lang/toml
fast_sync = true
db_backend = "leveldb"
api_addr = "0.0.0.0:9888"
chain_id = "testnet"
[p2p]
laddr = "tcp://0.0.0.0:46656"
seeds = "47.96.42.1:46656,172.104.224.219:46656,45.118.132.164:46656"

它已經把一些基本信息告訴我們了,比如:

  • db_backend = "leveldb":說明比原內部使用了leveldb作為數據庫(用來保存塊數據、帳號、交易信息等)

  • api_addr = "0.0.0.0:9888":我們可以在瀏覽器中打開http://localhost:9888來訪問dashboard頁面,進行查看與管理

  • chain_id = "testnet":當前連接的是testnet,即測試網,里面挖出來的比原幣是不值錢的

  • laddr = "tcp://0.0.0.0:46656":本地監聽46656端口,別的節點如果想連我,就需要訪問我的46656端口

  • seeds = "47.96.42.1:46656,172.104.224.219:46656,45.118.132.164:46656":比原啟動后,會主動連接這幾個地址獲取數據

內容模板

使用不同的chain_id去初始化時,會生成不同內容的配置文件,那么這些內容來自于哪里呢?

原來在config/toml.go#L22-L45,預定義了不同的模板內容:

var defaultConfigTmpl = `# This is a TOML config file.
# For more information, see https://github.com/toml-lang/toml
fast_sync = true
db_backend = "leveldb"
api_addr = "0.0.0.0:9888"
`

var mainNetConfigTmpl = `chain_id = "mainnet"
[p2p]
laddr = "tcp://0.0.0.0:46657"
seeds = "45.79.213.28:46657,198.74.61.131:46657,212.111.41.245:46657,47.100.214.154:46657,47.100.109.199:46657,47.100.105.165:46657"
`

var testNetConfigTmpl = `chain_id = "testnet"
[p2p]
laddr = "tcp://0.0.0.0:46656"
seeds = "47.96.42.1:46656,172.104.224.219:46656,45.118.132.164:46656"
`

var soloNetConfigTmpl = `chain_id = "solonet"
[p2p]
laddr = "tcp://0.0.0.0:46658"
seeds = ""
`

可以看到,原來這些端口號和seed的地址,都是事先寫好在模板里的。

而且,通過觀察這些配置,我們可以發現,如果chain_id不同,則監聽的端口和連接的種子都不同:

  1. mainnet(連接到主網): 46657,會主動連接6個種子

  2. testnet(連接到測試網): 46656,會主動連接3個種子

  3. solonet(本地單獨節點): 46658,不會主動連接別人(也因此不會被別人連接上),適合單機研究

寫入文件

這里我們需要快速的把bytomd init的執行流程過一遍,才能清楚配置文件的寫入時機,也同時把前面的內容串在了一起。

首先,當我們運行bytomd init時,它對應的代碼入口為cmd/bytomd/main.go#L54:

func main() {
    cmd := cli.PrepareBaseCmd(commands.RootCmd, "TM", os.ExpandEnv(config.DefaultDataDir()))
    cmd.Execute()
}

其中的config.DefaultDataDir()就對應于前面提到數據目錄位置。

然后執行cmd.Execute(),將根據傳入的參數init,選擇下面的函數來執行:cmd/bytomd/commands/init.go#L25-L24

func initFiles(cmd *cobra.Command, args []string) {
    configFilePath := path.Join(config.RootDir, "config.toml")
    if _, err := os.Stat(configFilePath); !os.IsNotExist(err) {
        log.WithField("config", configFilePath).Info("Already exists config file.")
        return
    }

    if config.ChainID == "mainnet" {
        cfg.EnsureRoot(config.RootDir, "mainnet")
    } else if config.ChainID == "testnet" {
        cfg.EnsureRoot(config.RootDir, "testnet")
    } else {
        cfg.EnsureRoot(config.RootDir, "solonet")
    }

    log.WithField("config", configFilePath).Info("Initialized bytom")
}

其中的configFilePath,就是config.toml的寫入地址,即我們前面所說的數據目錄下的config.toml文件。

cfg.EnsureRoot將用來確認數據目錄是有效的,并且將根據傳入的chain_id不同,來生成不同的內容寫入到配置文件中。

它對應的代碼是config/toml.go#L10

func EnsureRoot(rootDir string, network string) {
    cmn.EnsureDir(rootDir, 0700)
    cmn.EnsureDir(rootDir+"/data", 0700)

    configFilePath := path.Join(rootDir, "config.toml")

    // Write default config file if missing.
    if !cmn.FileExists(configFilePath) {
        cmn.MustWriteFile(configFilePath, []byte(selectNetwork(network)), 0644)
    }
}

可以看到,它對數據目錄進行了權限上的確認,并且發現當配置文件存在的時候,不會做任何更改。所以如果我們需要生成新的配置文件,就需要把舊的刪除(或改名)。

其中的selectNetwork(network)函數,實現了根據chain_id的不同來組裝不同的配置文件內容,它對應于master/config/toml.go#L48:

func selectNetwork(network string) string {
    if network == "testnet" {
        return defaultConfigTmpl + testNetConfigTmpl
    } else if network == "mainnet" {
        return defaultConfigTmpl + mainNetConfigTmpl
    } else {
        return defaultConfigTmpl + soloNetConfigTmpl
    }
}

果然就是一個簡單的字符串拼接,其中的defaultConfigTmpl*NetConfgTmpl在前面已經出現,這里不重復。

最后調用第三方函數cmn.MustWriteFile(configFilePath, []byte(selectNetwork(network)), 0644),把拼接出來的配置文件內容以權限0644寫入到指定的文件地址。

“bytom初始化時產生了什么配置文件”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

普陀区| 咸宁市| 拜城县| 嘉定区| 栖霞市| 平顶山市| 宁安市| 肃宁县| 永兴县| 苏州市| 赤水市| 黑龙江省| 哈密市| 阿鲁科尔沁旗| 亚东县| 广南县| 土默特右旗| 沐川县| 雷波县| 泾阳县| 清水县| 通州区| 东台市| 陵川县| 峨边| 毕节市| 高唐县| 如皋市| 康乐县| 武胜县| 胶州市| 西丰县| 伊吾县| 泰顺县| 瓮安县| 固阳县| 天等县| 连南| 安远县| 加查县| 怀安县|