基于某些需求我需要将一个以太坊网络运行在自己的服务器上,因此在查阅了相关资料后,我在自己的服务器上搭建了一个私链。搭建一个以太坊私链主要有两步:①安装geth;②私链环境配置和启动。
服务器系统版本:Ubuntu Server 18.04.1 LTS 64位;geth版本:1.10.16-stable-20356e7
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钱包中依次点击“设定-网络-添加网络”进行私链网络的添加。

其中网络名称原生代币的标签根据需要可以自行设置,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文件的解析。
我正在使用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].有没有一种方法可以
我有一个在Linux服务器上运行的ruby脚本。它不使用rails或任何东西。它基本上是一个命令行ruby脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg
我使用的是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上找到一个类
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我正在玩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
之前在培训新生的时候,windows环境下配置opencv环境一直教的都是网上主流的vsstudio配置属性表,但是这个似乎对新生来说难度略高(虽然个人觉得完全是他们自己的问题),加之暑假之后对cmake实在是爱不释手,且这样配置确实十分简单(其实都不需要配置),故斗胆妄言vscode下配置CV之法。其实极为简单,图比较多所以很长。如果你看此文还配不好,你应该思考一下是不是自己的问题。闲话少说,直接开始。0.CMkae简介有的人到大二了都不知道cmake是什么,我不说是谁。CMake是一个开源免费并且跨平台的构建工具,可以用简单的语句来描述所有平台的编译过程。它能够根据当前所在平台输出对应的m
注意:本文主要掌握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配
1.1.1 YARN的介绍 为克服Hadoop1.0中HDFS和MapReduce存在的各种问题⽽提出的,针对Hadoop1.0中的MapReduce在扩展性和多框架⽀持⽅⾯的不⾜,提出了全新的资源管理框架YARN. ApacheYARN(YetanotherResourceNegotiator的缩写)是Hadoop集群的资源管理系统,负责为计算程序提供服务器计算资源,相当于⼀个分布式的操作系统平台,⽽MapReduce等计算程序则相当于运⾏于操作系统之上的应⽤程序。 YARN被引⼊Hadoop2,最初是为了改善MapReduce的实现,但是因为具有⾜够的通⽤性,同样可以⽀持其他的分布式计算模
我试图在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
我是ruby的新手,正在配置IRB。我喜欢pretty-print(需要'pp'),但总是输入pp来漂亮地打印它似乎很麻烦。我想做的是默认情况下让它漂亮地打印出来,所以如果我有一个var,比如说,'myvar',然后键入myvar,它会自动调用pretty_inspect而不是常规检查。我从哪里开始?理想情况下,我将能够向我的.irbrc文件添加一个自动调用的方法。有什么想法吗?谢谢! 最佳答案 irb中默认pretty-print对象正是hirb被迫去做。Theseposts解释hirb如何将几乎所有内容转换为ascii表。虽