主頁 > 區塊鏈 > 通過Geth搭建私有以太坊網路

通過Geth搭建私有以太坊網路

2022-03-22 06:27:38 區塊鏈

前言

為了進一步了解以太坊區塊鏈網路的作業方式和運行原理,筆者通過官方軟體Geth搭建了私有以太坊網路fantasynetwork,最終實作了單機和多機節點間的相互連通:首先通過VMware Workstation創建基礎Ubuntu實驗平臺,再安裝Golang[1]、Geth[2]等依賴環境;其次使用puppeth工具生成私網的組態檔fantasynetwork.json并復制到三個節點目錄下,三個節點均使用該組態檔初始化網路;最后使用static-nodes.json的方式將三個節點設為默認接入節點,實作節點間的連通,連通后各節點中的賬戶可以互相轉賬挖礦,

單機多節點私網[3]

本試驗的專案結構為:

privateNet    
├── accounts.txt    
├── fantasynetwork.json    
├── node1    
│   ├── geth    
│   ├── keystore    
│   ├── node.sh    
│   ├── password.txt    
│   └── static-nodes.json    
├── node2    
│   ├── geth    
│   ├── keystore    
│   ├── node.sh    
│   ├── password.txt    
│   └── static-nodes.json    
└── node3    
    ├── geth    
    ├── keystore    
    ├── node.sh        
    ├── password.txt    
    └── static-nodes.json

創建作業目錄

  1. 創建私網作業目錄mkdir privateNet && cd privateNet
  2. 創建三個節點資料目錄mkdir node1 node2 node3
     privateNet/
     ├── node1
     ├── node2
     └── node3
    

創建默認用戶

  1. Node1
     [email protected]:~/privateNet$ geth --datadir node1/ account new
     Your new account is locked with a password. Please give a password. Do not forget this password.
     Password:
     Repeat password:
    
     Your new key was generated
    
     Public address of the key:   0x600d77B8ce36B829BFC8a1Cc5696Faf2218bDf75
     Path of the secret key file: node1/keystore/UTC--2021-08-11T04-51-26.533482715Z--600d77b8ce36b829bfc8a1cc5696faf2218bdf75
    
  2. Node 2
     [email protected]:~/privateNet$ geth --datadir node2/ account new
     Your new account is locked with a password. Please give a password. Do not forget this password.
     Password:
     Repeat password:
    
     Your new key was generated
    
     Public address of the key:   0x2F7fD5BD0026f7C2f0dB94b79D58AFE517BC56d2
     Path of the secret key file: node2/keystore/UTC--2021-08-11T04-53-30.820914994Z--2f7fd5bd0026f7c2f0db94b79d58afe517bc56d2
    
  3. Node3
     [email protected]:~/privateNet$ geth --datadir node3/ account new
     Your new account is locked with a password. Please give a password. Do not forget this password.
     Password:
     Repeat password:
    
     Your new key was generated
    
     Public address of the key:   0x6c1440E9c6Ca93C18B1e2A069D1D5a70e29C2363
     Path of the secret key file: node3/keystore/UTC--2021-08-11T04-54-24.244487186Z--6c1440e9c6ca93c18b1e2a069d1d5a70e29c2363
    

在此創建賬戶的密碼設定為fantasy,操作完成后會在每個節點目錄下的keystore目錄中找到賬戶密鑰檔案/錢包地址,

保存賬戶憑證

  1. 將以上賬戶的公鑰地址保存至文本檔案
     echo '0x600d77B8ce36B829BFC8a1Cc5696Faf2218bDf75' >> accounts.txt
     echo '0x2F7fD5BD0026f7C2f0dB94b79D58AFE517BC56d2' >> accounts.txt
     echo '0x6c1440E9c6Ca93C18B1e2A069D1D5a70e29C2363' >> accounts.txt
    
  2. 為了實驗方便,將賬戶對應的密碼檔案保存至對應節點目錄下
     echo 'fantasy' > node1/password.txt
     echo 'fantasy' > node2/password.txt
     echo 'fantasy' > node3/password.txt
    

創建組態檔

  1. 設定網路名稱
     [email protected]:~/privateNet$ puppeth
     Please specify a network name to administer (no spaces, hyphens or capital letters please)
     > fantasynetwork
     Sweet, you can set this via --network=fantasynetwork next time!
     INFO [08-10|22:08:31.110] Administering Ethereum network           name=fantasynetwork
     WARN [08-10|22:08:31.110] No previous configurations found         path=/home/test/.puppeth/fantasynetwork
    
  2. 選擇程式功能
     What would you like to do? (default = stats)
     1. Show network stats
     2. Configure new genesis
     3. Track new remote server
     4. Deploy network components
     > 2
    
  3. 選擇創建網路
     What would you like to do? (default = create)
     1. Create new genesis from scratch
     2. Import already existing genesis
     > 1
    
  4. 選擇共識演算法
     Which consensus engine to use? (default = clique)
     1. Ethash - proof-of-work
     2. Clique - proof-of-authority
     > 1
    
  5. 選擇默認賬號
     Which accounts should be pre-funded? (advisable at least one)
     > 0x600d77B8ce36B829BFC8a1Cc5696Faf2218bDf75
     > 0x2F7fD5BD0026f7C2f0dB94b79D58AFE517BC56d2
     > 0x6c1440E9c6Ca93C18B1e2A069D1D5a70e29C2363
     > 0x
    
  6. 設定默認單位
     Should the precompile-addresses (0x1 .. 0xff) be pre-funded with 1 wei? (advisable yes)
     > yes
    
  7. 設定網路ID
     Specify your chain/network ID if you want an explicit one (default = random)
     > 7777
     INFO [08-10|22:16:40.485] Configured new genesis block
    
  8. 匯出組態檔
     What would you like to do? (default = stats)
     1. Show network stats
     2. Manage existing genesis
     3. Track new remote server
     4. Deploy network components
     > 2
     1. Modify existing configurations
     2. Export genesis configurations
     3. Remove genesis configuration
     > 2
     Which folder to save the genesis specs into? (default = current)
     Will create fantasynetwork.json, fantasynetwork-aleth.json, fantasynetwork-harmony.json, fantasynetwork-parity.json
     >
     INFO [08-10|22:18:48.283] Saved native genesis chain spec          path=fantasynetwork.json
     INFO [08-10|22:18:48.285] Saved genesis chain spec                 client=aleth path=fantasynetwork-aleth.json
     INFO [08-10|22:18:48.286] Saved genesis chain spec                 client=parity path=fantasynetwork-parity.json
     INFO [08-10|22:18:48.287] Saved genesis chain spec                 client=harmony path=fantasynetwork-harmony.json
    
  9. 退出工具
    What would you like to do? (default = stats)
    1. Show network stats
    2. Manage existing genesis
    3. Track new remote server
    4. Deploy network components
    > ^C
    

此時可在當前目錄下看見生成的四個組態檔,在此只用到fantasynetwork.json檔案,其他檔案可刪去,

  1. 修改組態檔
    為了更容易挖到礦,將組態檔中difficulty難度值調小(其它引數含義可參考《創世區塊組態檔genesis.json的格式解讀》[4]):
    調整difficulty

初始化三個節點

每個節點必須使用相同的組態檔進行初始化:

geth --datadir node1/ init fantasynetwork.json
geth --datadir node2/ init fantasynetwork.json
geth --datadir node3/ init fantasynetwork.json

運行三個節點

進入對應的節點目錄下執行一下命令(其它引數含義可參考《以太坊客戶端Geth命令用法-引數詳解》[5]):

  1. Node1
    geth --nousb --datadir=$pwd --syncmode 'full' --port 27271 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7271 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x600d77B8ce36B829BFC8a1Cc5696Faf2218bDf75" --password password.txt 
    
    啟動節點node1
    得到節點一的enode:
    enode://0f870fa3f8085f5abf74ea7c2a12a0809a9daaece20e3b1c4c80fb6929ff65268[email protected]127.0.0.1:27271
    
  2. Node2
    geth --nousb --datadir=$pwd --syncmode 'full' --port 27272 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7272 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x2F7fD5BD0026f7C2f0dB94b79D58AFE517BC56d2" --password password.txt 
    
    得到節點二的enode:
    enode://45c2fc2bfdf0f48afe2083d82cc1cc642a96fcc2815755024a17b95b9fd1b3124[email protected]127.0.0.1:27272
    
  3. Node3
    geth --nousb --datadir=$pwd --syncmode 'full' --port 27273 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7273 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x6c1440E9c6Ca93C18B1e2A069D1D5a70e29C2363" --password password.txt 
    
    得到節點三的enode:
    enode://ae4b4e18afa6238753e14ca3e99c0858509fc76efee715dd1c8278bbb7eaa5614[email protected]127.0.0.1:27273
    

連通三個節點

Geth主要有三種方法連通其它節點:啟動前配置static-nodes.json檔案添加節點、啟動時通過--bootnodes添加節點、啟動后在控制臺通過admin.addPeer命令添加節點,在此我們使用第一種方法,

  1. 在作業目錄下創建static-nodes.json
    [       
    "enode://0f870fa3f8085f5abf74ea7c2a12a0809a9daaece20e3b1c4c80fb6929ff65268[email protected]127.0.0.1:27271",    
    "enode://45c2fc2bfdf0f48afe2083d82cc1cc642a96fcc2815755024a17b95b9fd1b3124[email protected]127.0.0.1:27272",    
    "enode://ae4b4e18afa6238753e14ca3e99c0858509fc76efee715dd1c8278bbb7eaa5614[email protected]127.0.0.1:27273"    
    ]  
    
  2. 將該檔案復制到每個節點根目錄下:
    cp static-nodes.json node1/
    cp static-nodes.json node2/
    cp static-nodes.json node3/
    
  3. 為了簡化啟動,可以創建啟動節點批處理檔案
    • node1/node.sh
      nohup geth --nousb --datadir=$pwd --syncmode 'full' --port 27271 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7271 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x600d77B8ce36B829BFC8a1Cc5696Faf2218bDf75" --password password.txt &
      echo "Geth started on node 1"
      
    • node2/node.sh
      nohup geth --nousb --datadir=$pwd --syncmode 'full' --port 27272 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7272 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x2F7fD5BD0026f7C2f0dB94b79D58AFE517BC56d2" --password password.txt &
      echo "Geth started on node 2"
      
    • node2/node.sh
      nohup geth --nousb --datadir=$pwd --syncmode 'full' --port 27273 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 'localhost' --http.port 7273 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock --unlock "0x6c1440E9c6Ca93C18B1e2A069D1D5a70e29C2363" --password password.txt &
      echo "Geth started on node 3"
      
  4. 啟動各節點
    [email protected]:~/privateNet/node1$ sh node.sh
    [email protected]:~/privateNet/node2$ sh node.sh
    [email protected]:~/privateNet/node3$ sh node.sh
    
  5. 打開三個終端,使用geth attach命令接入三個節點命令列
    [email protected]:~/privateNet/node1$ geth attach geth.ipc
    [email protected]:~/privateNet/node2$ geth attach geth.ipc
    [email protected]:~/privateNet/node3$ geth attach geth.ipc
    
    geth attach
  6. 查看已連接節點
    查看已連接節點

此時各節點已連接完成,每個節點賬戶默認為10個以太幣,各節點賬戶間可自由轉賬和挖礦,需要注意的是轉賬后必須經過挖礦操作才能被寫入區塊鏈,上方法啟動后的程式將會運行在后臺,關閉需通過ps ax | grep geth命令和kill <process id>命令,

多機多節點私網

準備

  1. 設定上節Ubuntu虛擬機網路模式為橋接,且IP設為靜態IP172.25.1.99
  2. Windows的IP設為靜態172.25.1.55

加入私網

  1. 在Windows下創建檔案夾node4,并將fantasynetwork.json復制到其中
  2. 初始化節點4
    C:\Users\Fantasy\Desktop\node4> geth --datadir . init fantasynetwork.json
    
  3. 新建賬戶
    C:\Users\Fantasy\Desktop\node4>geth -datadir . console
    > personal.newAccount("fantasy")
    WARN [08-11|16:13:32.987] Please remember your password!
    "0xbef61b5754ffaa843cc9199fb9a11aac468134f4"
    > exit
    
  4. 啟動節點4
    geth --nousb --datadir=. --syncmode "full" --port 27271 --miner.gasprice 0 --miner.gastarget 470000000000 --http --http.addr 0.0.0.0 --http.port 7271 --http.api admin,eth,miner,net,txpool,personal,web3 --mine --allow-insecure-unlock console
    
  5. 添加節點1[6]
    > net.peerCount
    0
    > admin.addPeer("enode://0f870fa3f8085f5abf74ea7c2a12a0809a9daaece20e3b1c4c80fb6929ff65268[email protected]172.25.1.99:27271")
    true
    > net.peerCount
    1
    

此時各節點已連接完成,各節點賬戶間可自由轉賬和挖礦,需要注意的是轉賬后必須經過挖礦操作才能被寫入區塊鏈

注意事項:

  • 很多教程中說不同節點啟動時不能使用相同的埠,那是因為其運行在同一個主機上,這里節點1和節點4運行在不同的埠上,故可以使用相同的埠,
  • 添加節點無效常見原因/解決辦法:
    • admin.addPeer后等一段時間才會生效
    • admin.addPeer時使用的是NAT后公網地址,而公網防火墻通常拒絕例外接入
    • admin.addPeer后開始挖礦增加同步速度
    • 簡單的方法是使用上節中的static-nodes.json方法

參考


  1. yuanlulu. golang學習1:ubuntu下安裝golang并簡單測驗. CSDN. [2021-02-21] ??

  2. shciily. Linux系統下安裝Geth客戶端. CSDN. [2020-08-29] ??

  3. Divyang Desai. Setup Your Private Ethereum Network With Geth. c-sharpcorner.com. [2020-08-04] ??

  4. soowin. 創世區塊組態檔genesis.json的格式解讀. CSDN. [2021-01-26] ??

  5. mb5fe559b5073e8. 以太坊客戶端Geth命令用法-引數詳解. CSDN. [2021-06-13] ??

  6. Someone. "admin.addPeer" is not working. Github. [2020-09-27] ??

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/445902.html

標籤:區塊鏈

上一篇:顫振圖示影片

下一篇:返回列表

標籤雲
其他(138117) Python(27848) JavaScript(17220) Java(15116) C(12266) 區塊鏈(8216) AI(7469) 基礎類(6313) MySQL(5612) 腳本語言(PerlPython)(5129) 非技術區(4971) C#(4855) 爪哇(4579) PHP(4350) Linux(4347) Android(4263) html(4240) sql(3884) 熊猫(3796) 数组(3500) R(3459) C語言(3288) C++語言(3117) 反应(3092) Java相關(2746) css(2704) 疑難問題(2699) 数据框(2646) 节点.js(2490) 單片機工控(2479) VBA(2142) json(2098) 列表(2059) 扑(2004) 安卓(1964) Web開發(1951) ASP.NET(1843) 網絡通信(1793) 打字稿(1790) 蟒蛇-3.x(1774) 數據庫相關(1767) VB基礎類(1755) iOS(1707) .NETCore(1702) 開發(1646) 系統維護與使用區(1617) C++(1603) 细绳(1582) 基礎和管理(1579) JavaEE(1566) HtmlCss(1541) 專題技術討論區(1515) Unity3D(1509) .NET技术(1494) Windows客戶端使用(1484) MongoDB(1484) 查询(1415) 循环(1403) 镖(1401) 正则表达式(1401)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • 通過Geth搭建私有以太坊網路

    為了進一步了解以太坊區塊鏈網路的作業方式和運行原理,筆者通過官方軟體Geth搭建了私有以太坊網路fantasynetwork:首先通過VMware Workstation創建基礎Ubuntu實驗平臺,再安裝Golang、Geth等依賴環境;其次使用puppeth工具生成私網的組態檔genesis.... ......

    uj5u.com 2022-03-22 06:27:38 more
  • 顫振圖示影片

    我是顫振設計的新手。所以我有一個關于圖示影片的問題。我用星號在顫振應用程式中創建了 IconButton:IconButton(color: _isFavourite ? Theme.of...

    uj5u.com 2022-03-21 20:46:08 more
  • 如何在顫動中選擇多個容器?

    現在我可以一次選擇一個專案,但我想選擇多個專案。我找到了一些用于多選的包,但想在不使用任何包的情況下實作。 int? selectedIndex; final List<String>...

    uj5u.com 2022-03-21 20:43:50 more
  • Hub是否支持MinIO、AWS和GCP的集成?如果是這樣,它是如何作業的?

    我在查看 Hub (AI 的資料集格式)并注意到 Hub 與 GCP 和 AWS 集成。我想知道它是否也支持與 MinIO 的集成。我知道 Hub 允許您直接將資料集從云存盤流式傳輸...

    uj5u.com 2022-03-21 20:08:04 more
  • 頁面型別上不存在屬性“deleteVisual”

    我有一個使用 Angular 嵌入的 powerbi 報告。我想洗掉報告的視覺效果。這是我為 deleteVisual 函式實作的代碼。deleteVisual() { // Get report con...

    uj5u.com 2022-03-21 15:07:40 more
  • AngularJSosm傳單-拒絕訪問瓷磚

    我在我的 AngularJS 應用程式和谷歌 Chrome 瀏覽器中使用 osm 我收到以下訊息所以我無法(不再)訪問瓷磚。三天前它作業得很好。如果我在 Firefox 中打開應用...

    uj5u.com 2022-03-21 15:03:53 more
  • 如何在進行http呼叫IONIC6之前獲取電容器存盤值

    我一直在尋找有關如何在 Ionic 6 中獲取我的電容器存盤中的一些值并在執行 HTTP 請求之前使用它們的教程。cart.service.ts 中的示例方法:getCart() { Stor...

    uj5u.com 2022-03-21 15:01:33 more
  • 帶有.net6.0的MicrosoftVS2022錯誤:除錯可執行檔案...除錯組態檔

    我開始學習 C# 和 .net,剛剛安裝了 Microsoft VS 2022,還安裝了 .net 6.0。我試圖運行第一個代碼,它出現了如下錯誤。我做了一些研究,但無法弄清楚出了什么問題...

    uj5u.com 2022-03-21 14:49:15 more
  • 使用.NETCore控制臺應用程式獲取當前螢屏解析度

    我在 VS 2019 中使用 .NET Core 3.1 控制臺應用程式。我正在嘗試獲取當前的螢屏解析度(Windows 顯示)。我不想獲得顯示幕的最大解析度。我有以下有效的批處理...

    uj5u.com 2022-03-21 14:47:07 more
  • 嘗試為.NETCore6實作DNTaptcha

    所以我知道如何在以前版本的 .NET Core 中實作這一點。但我在為 .NET Core 6 做這件事時遇到了麻煩。在 .Net 3.1 或 5 中,從我嘗試查看其他資源和檔案,但它...

    uj5u.com 2022-03-21 14:45:22 more