Ethereum-Deploy truffle project on ethereum private network

Assume that you are already familiar with the principle of Ethereum, Solidity, Web3.js and the Truffle usage. If not, you'd better do some work before continue. Today I will describe you about how to deploy the truffle project on our own Ethereum private network.

Environment

  • Truffle: v3.3.2 (core: 3.3.1)
  • Geth version: 1.6.6-stable
  • OS: ubuntu 16.04 x86-64

Details

step1

Open a terminal and cd into the directory where you gonna to work. First, we need a truffe project by running:

$ truffle init

Now, execute command ls you can see several new files and folders were created.

Figure 1

To understand what they means you can browse truffle tutorials website. Next let's compile the truffle project, add option --reset tell truffle recompile all the .sol source file under the directory contracts.

$ truffle compile --reset

Here is what you would see on terminal:

Figure 2

step2

Since now we can use truffle migrate to deploy our contract on testrpc(a well known local Ethereum network for development), but here we do not use the testrpc, so the next steps is to build our own ethereum private network.
First we need a genesis.json file used to initalize our network. Execute command touch genesis.json and copy the genesis block context at here into genesis.json. Your genesis.json file should look like below:

Figure 3

Then, we need customize gnensis.json to build our own private network, and with some small modifications the file now should look like below:

Figure 4

difficulty: decrease difficulty value or it's hard to create new block with our laptop. After decrease to 20, about 2 or 3 blocks will be created per second on my laptop.
gasLimit: it's important to increase the gasLimit if your contract code is a bit huge.
alloc: optional, the alloc section pre-funds accounts. I removed the accounts here and created accounts manually later.

More details about genesis.json and ethereum private network description can be found here.

step3

It's time to create our own network now. Execute the command below to config our network. Option --datadir config the location of our network data, --networkid config the network id which will be used by RPC service.(1 is the network id of Ethereum public network.)

$ geth --datadir ./ --networkid 11 init genesis.json

The output of your terminal should like below:

Figure 5

step4

Execute the command below to startup our new network. Here you can see many external options which let the geth turn on the specific APIs.

$ geth --datadir ./ --networkid 11 --rpc --rpcapi eth,web3,net,personal,ssh,db,debug

step5

Open another terminal and cd into the work directory. Here you can see:

Figure 6

As you can see, more files and directories were created. Execute command below to attach the geth client and you will come to the geth console.

$ geth attach geth.ipc

step6

I delete the pre-funds accounts in file genesis.json, so there is no account existing in our network. Before we start the miner, we must create at least one account and set it as ether base. Thus the ether that the miner got will be deliverd to this account automatic.

  • create account:
$ personal.newAccount(“your account passwd”)

Execute eth.accounts you should see the output like below:

Figure 7
  • set miner etherbase
$ miner.setEtherbase(eth.accounts[0])

accounts[0] is the account we created just now. Or you could execute eth.coinbase that also return accounts[0]. The console should return you a "true".

step7

By default, the account was locked since created. So we need unlock the account to make the miner work properly. Execute command below to unlock the account with the given address, password and an optional duration (in seconds). If password is not given you will be prompted for it.

$ personal.unlockAccount(eth.accounts[0], "you account passwd", 15000)

The console should return you a "true".

step8

Everything should be fine, so let's start mining.

$ miner.start()

On your first terminal, you should see its output like below:

Figure 8

You can execute eth.blockNumber to see how many blocks were created since starting mining.

Figure 9

step9

We have done almost all of the work, the final step is to config the truffle network and deploy the truffle project onto our private network.

  • config truffle network
    Open the third terminal and cd into your work directory. Edit truffle.js and add the following block:
privatenetwork: {
  host: 'localhost',
  port: 8545,
  network_id: 11
}

The port number 8545 is the default listen port of ethereum RPC service. network_id must be set correctly which was given when we created our private network at step3. Now your truffle.js should like below:

Figure 10
  • deploy truffle project onto network
    Run command:
truffle migrate --network privatenetwork

Here the output should like below:


Figure 11

All work done! We have successfully deployed a sample truffle project onto our Ethereum private network.

Trouble Shooting

i. Error: exceeds block gas limit

Increase the gas limit in file genesis.json.
Attention that block gas limit isn't down to your personal funds, it's a property of the network.

ii. Error: authentication needed: password or unlock
personal.unlockAccount(eth.coinbase)

Do not forget unlock your accounts before making them accept ether.

iii. Error: truffle Invalid JSON RPC response:

Tell the geth turn on RPC APIs.

$ geth --datadir ./ --networkid 11 --rpc --rpcapi eth,web3,net,personal,ssh,db,debug
iv. Error: insufficient funds for gas * price + value

Your balance isn't enough to deploy a contract, try start mining to earn more ether.

miner.start()
v. After running truffle migrate privatenetwork, the output message blocking at "Deploying Migrations…."

Run minner.start() if you have stopped mining. Deloy contract is a transaction request, so we need the minner commit the new block to our network.


版權(quán)所有,轉(zhuǎn)載請注明出處。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 黃磊教育孩子一定是有方法的,你看再爸爸去哪兒2中,多多來到了小朋友的宿舍,那里很簡陋,多多哭了,但是不知道為什么。...
    琪寶長大閱讀 262評論 0 0
  • 一不小心愛上你 沉醉入迷 你無聲無息 融入了我心底 待繁華落盡 憶往昔濃郁 愛上了你 忘不了 褪不去的記憶 只希望...
    曉曉老師Y閱讀 163評論 0 2
  • 今天似乎并沒有干什么事情,在學(xué)習(xí)室呆了基本一天,忙著修改材料。跟著機(jī)關(guān)幾個老師一句一句地讀,一句一句的改,倒...
    隱姓埋名的Harvey閱讀 242評論 0 0
  • 任你風(fēng)花雪月也好,我只想和你過那安穩(wěn)一生,這些事,隱秘于這,我覺得安全 我已經(jīng)超過七年沒有寫過什么東西了,我可能不...
    shirinyao閱讀 296評論 0 2
  • 看這部影片之前,精美的海報、截取幾個浪漫片段構(gòu)成的電影預(yù)告還有各種宣傳給出的信息都讓我以為這是一個童話故事般的歌舞...
    永恆之光閱讀 544評論 0 0