草庐IT

以太坊私链搭建(一)——环境配置和metamask连接

llsForest 2024-04-29 原文

        基于某些需求我需要将一个以太坊网络运行在自己的服务器上,因此在查阅了相关资料后,我在自己的服务器上搭建了一个私链。搭建一个以太坊私链主要有两步:①安装geth;②私链环境配置和启动。

服务器系统版本:Ubuntu Server 18.04.1 LTS 64位;geth版本:1.10.16-stable-20356e7

一、安装geth

        geth(go-ethereum)是以太坊官方社区开发的开源客户端,我们可以通过geth命令搭建以太坊私链或者通过geth客户端的控制台与以太坊网络进行交互。geth的安装方式有很多,但是ubuntu下安装geth还是比较方便的,不需要翻墙,在终端执行下面的命令即可(需要root权限,需要登陆root账户或在每个命令前面+sudo)。

apt-get install software-properties-common
add-apt-repository -y ppa:ethereum/ethereum
apt-get update
apt-get install ethereum

        安装完后可以输入geth -h查看命令帮助,能正常显示则安装完成。

二、环境配置

        首先第一步我们需要创建一个文件夹用来存放我们的私链项目。

mkdir /home/lls/FangChain
mkdir /home/lls/Fangchain/data

        项目目录的名称和位置根据需要自行变更,但是需要注意在对私链进行初始化的时候需要指定数据存储位置,能对应上即可,data目录用于存储私链数据,包括账本信息、用户私钥等。

        接着我们需要创建一个私链配置json文件用于配置区块链的“创世”状态,这一步的目的是根据需求对私链的状态进行初始化。

cd /home/lls/FangChain/

        跳转到项目目录下,创建配置文件genesis.json。

vi genesis.json

        编辑文件内容,这里用以太坊官网给的例子,输入内容如下:

{
  "config": {
    "chainId": 15,    //私链的ID,每条私链的ID应该是唯一的
    "homesteadBlock": 0,
    "eip150Block": 0,
    "eip155Block": 0,
    "eip158Block": 0,
    "byzantiumBlock": 0,
    "constantinopleBlock": 0,
    "petersburgBlock": 0,
    "ethash": {}
  },
  "difficulty": "1",    //出块难度,数值越大,矿工挖矿出块的难度越大
  "gasLimit": "8000000",    //每个区块最大的gas消耗
  "alloc": {    //资产配置初始化,提前定义哪些地址所拥有的原生代币的数量,单位是wei
    "7df9a875a174b3bc565e6424a0050ebc1b2d1d82": { "balance": "300000" },
    "f41c74c9ae680c1aa78f42e5647a62f353b7bdde": { "balance": "400000" }
  }
}

        一般来说,在上述文件中需要我们进行配置的是链ID、出块难度和初始资产。这里记得将genesis.json文件内的注释删除,json不允许添加注释,否则在下面执行配置初始化命令会出错。文件保存后执行私链配置初始化命令。

geth init --datadir data genesis.json

        其中--datadir字段用于配置私链数据的存储位置,这里存在data文件夹。输入命令后等待片刻,看到“Successfully wrote genesis state”的日志则表示配置完成。

        当配置完私链的初始状态后就可以通过geth命令启动私链了,执行以下命令。

geth --datadir data --networkid 15 --http --http.addr 0.0.0.0 --http.port 8545 --http.corsdomain "*" --port 30305 --allow-insecure-unlock console 2>>geth.log

        --datadir字段用于指示私链数据的存储位置,即工作目录;

        --networkid字段用于配置私链id,需要与genesis.json文件内预定义的一致;

        --http字段用于启用HTTP-RPC服务,主要应用于与前端页面的交互;

        --http.addr字段表示节点接受的http连接的地址,0.0.0.0表示可以接受所有ip地址的http请求;

        --http.port字段用于指定监听端口,默认是8545;

        --http.corsdomain字段表示允许跨域请求的域名列表,“*”表示允许所有的跨域请求,不开启的话metamask钱包可能无法连接上搭建的私链;

        --port字段用于指定节点之间通信的端口,默认是30303;

        --allow-insecure-unlock表示允许不安全的账户解锁行为,开启这个选项后通过http连接到私链的钱包才能解锁账户进行转账操作;

        console表示在运行私链节点的同时开启控制台,这样就可以在监控私链节点状态的同时对节点进行操作。因为geth命令运行完后会不断弹出监控日志影响到控制台的使用,因此在命令最后添加2>>geth.log就可以让监控日志输入到当前目录的geth.log文件中而不影响控制台的使用,然后在新开一个终端用tail -f geth.log的命令实时监控节点的日志即可。(如果不愿意这么麻烦可以把2>>geth.log删除)

三、用MetaMask钱包连接私链

        若要用metamask钱包连接私链节点,则需要在metamask钱包中依次点击“设定-网络-添加网络”进行私链网络的添加。

        其中网络名称原生代币的标签根据需要可以自行设置,RPC URL的格式为http://服务器地址:http端口号(如http://81.72.166.130:8545),链ID即为networkid中定义的id。当添加完私链网络后,我们就可以通过metamask钱包操作我们在私链上的账户,并可以通过remix将智能合约部署到私链上。

        需要注意的是,如果你使用的是云服务器,则需要在云服务器的服务器管理界面开启上述配置中的对应的端口,尤其是http.port对应的端口,否则metamask钱包无法通过该端口连接上私链节点。

踩坑点

        --http,--http.addr,--http.port和--http.corsdomain是较新版本的geth才启用的字段,老版本对应的字段分别为--rpc,--rpcaddr,--rpcport和rpccorsdomain,根据实际版本进行替换即可。而在新版本中如果你用的是websocket协议与节点交互,则对应的字段是--ws,--wsaddr,--ws.port和--ws.origins,具体命令详情可以在geth控制台中使用geth -h命令进行查看。

--port端口最好自行指定一个别的端口,因为8545端口为默认端口,在使用默认端口,且启动私链时允许所有ip地址的http请求和所有跨域请求的情况下,容易被机器人攻击,如下图所示。

可以看到在使用默认端口地情况下节点被高频率地访问,而修改端口可以有效避免这种情况。

参考资料

Private Networks | Go Ethereum

https://gist.github.com/0mkara/b953cc2585b18ee098cd

第一个为geth官网,第二个为genesis.json文件的解析。

有关以太坊私链搭建(一)——环境配置和metamask连接的更多相关文章

  1. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  2. ruby-on-rails - 独立 ruby​​ 脚本的配置文件 - 2

    我有一个在Linux服务器上运行的ruby​​脚本。它不使用rails或任何东西。它基本上是一个命令行ruby​​脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg

  3. ruby - 无法在 60 秒内获得稳定的 Firefox 连接 (127.0.0.1 :7055) - 2

    我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类

  4. Ruby Sinatra 配置用于生产和开发 - 2

    我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm

  5. ruby-on-rails - 在 Rails 开发环境中为 .ogv 文件设置 Mime 类型 - 2

    我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain

  6. Vscode+Cmake配置并运行opencv环境(Windows和Ubuntu大同小异) - 2

    之前在培训新生的时候,windows环境下配置opencv环境一直教的都是网上主流的vsstudio配置属性表,但是这个似乎对新生来说难度略高(虽然个人觉得完全是他们自己的问题),加之暑假之后对cmake实在是爱不释手,且这样配置确实十分简单(其实都不需要配置),故斗胆妄言vscode下配置CV之法。其实极为简单,图比较多所以很长。如果你看此文还配不好,你应该思考一下是不是自己的问题。闲话少说,直接开始。0.CMkae简介有的人到大二了都不知道cmake是什么,我不说是谁。CMake是一个开源免费并且跨平台的构建工具,可以用简单的语句来描述所有平台的编译过程。它能够根据当前所在平台输出对应的m

  7. 神州数码无线产品(AC+AP)配置 - 2

    注意:本文主要掌握DCN自研无线产品的基本配置方法和注意事项,能够进行一般的项目实施、调试与运维AP基本配置命令AP登录用户名和密码均为:adminAP默认IP地址为:192.168.1.10AP默认情况下DHCP开启AP静态地址配置:setmanagementstatic-ip192.168.10.1AP开启/关闭DHCP功能:setmanagementdhcp-statusup/downAP设置默认网关:setstatic-ip-routegeteway192.168.10.254查看AP基本信息:getsystemgetmanagementgetmanaged-apgetrouteAP配

  8. hadoop安装之保姆级教程(二)之YARN的配置 - 2

    1.1.1 YARN的介绍 为克服Hadoop1.0中HDFS和MapReduce存在的各种问题⽽提出的,针对Hadoop1.0中的MapReduce在扩展性和多框架⽀持⽅⾯的不⾜,提出了全新的资源管理框架YARN. ApacheYARN(YetanotherResourceNegotiator的缩写)是Hadoop集群的资源管理系统,负责为计算程序提供服务器计算资源,相当于⼀个分布式的操作系统平台,⽽MapReduce等计算程序则相当于运⾏于操作系统之上的应⽤程序。 YARN被引⼊Hadoop2,最初是为了改善MapReduce的实现,但是因为具有⾜够的通⽤性,同样可以⽀持其他的分布式计算模

  9. ruby-on-rails - ruby gem如何在rails环境下工作 - 2

    我试图在rails中了解rubygems是如何变得可以自动使用的,而不是在使用required的文件中gem? 最佳答案 这是通过bundler/setup完成的:http://bundler.io/v1.3/bundler_setup.html.它在您的config/boot.rb文件中是必需的。简而言之,它首先将环境变量设置为指向您的Gemfile:ENV['BUNDLE_GEMFILE']||=File.expand_path('../../Gemfile',__FILE__)然后它通过要求bundler/setup将所有ge

  10. Ruby 默认将 IRB 配置为 Pretty_Inspect - 2

    我是ruby​​的新手,正在配置IRB。我喜欢pretty-print(需要'pp'),但总是输入pp来漂亮地打印它似乎很麻烦。我想做的是默认情况下让它漂亮地打印出来,所以如果我有一个var,比如说,'myvar',然后键入myvar,它会自动调用pretty_inspect而不是常规检查。我从哪里开始?理想情况下,我将能够向我的.irbrc文件添加一个自动调用的方法。有什么想法吗?谢谢! 最佳答案 irb中默认pretty-print对象正是hirb被迫去做。Theseposts解释hirb如何将几乎所有内容转换为ascii表。虽

随机推荐