Skip to content

Commit

Permalink
Merge pull request #319 from liujuanjuan1984/main
Browse files Browse the repository at this point in the history
update readme to fix howto start fullnode
  • Loading branch information
huo-ju authored Feb 26, 2024
2 parents 97eefc9 + 5075bf2 commit 75f766f
Show file tree
Hide file tree
Showing 6 changed files with 88 additions and 22 deletions.
62 changes: 49 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,23 +112,33 @@ Try [rum-app](https://rumsystem.net/apps), a cross platform RUM GUI application.
Run the [quorum binary](#build_quorum):

```sh
./quorum fullnode --peername peer --listen /ip4/0.0.0.0/tcp/7000 --listen /ip4/0.0.0.0/tcp/9000/ws --apiport 8000 --peer /ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u --configdir rum/peerConfig --datadir rum/peerData --keystoredir rum/keystore --loglevel debug
./quorum fullnode \
--listen=/ip4/0.0.0.0/tcp/7000 \
--listen=/ip4/0.0.0.0/tcp/9000/ws \
--apiport=8000 \
--peer=/ip4/94.23.17.189/tcp/62777/p2p/16Uiu2HAm5waftP3s4oE1EzGF2SyWeK726P5B8BSgFJqSiz6xScGz \
--configdir=rum/config \
--datadir=rum/data \
--keystoredir=rum/keystore \
--keystorepwd=yourpassword \
--loglevel=debug \
--enabledevnetwork=false
```

OPTIONS:

```sh
--peername default:`peer`, used in and same with `configdir` and `datadir`
--listen a multiaddress for the peer service listening
--apihost http api listening host, a domain or a public ip address
--apiport http api listening port
--peer a bootstrap peer multiaddress. Any online peer could be used for bootstrap, you can use the RUM testing bootstrap server for testing.
--configdir a directory for config files. The `peer` of `peerConfig` must same as peername `peer`, eg: if `mypeer2Config`, peername must be `mypeer2`.
--datadir all data storage location. The `peer` of `peerData` must same as peername `peer`, eg: if `mypeer2Data`, peername must be `mypeer2`.
--keystoredir a directory to store private keys. All key files are password protected, and it\'s very important to keep backups of all your keys.
--debug enable logging level to debug or not
--listen required. a multiaddress for the peer service listening
--apihost required. http api listening host, a domain or a public ip address
--peer required. a bootstrap peer multiaddress. Any online peer could be used for bootstrap, you can use the RUM testing bootstrap server for testing.
--configdir optional. a directory for config files. The `peer` of `peerConfig` must same as peername `peer`, eg: if `mypeer2Config`, peername must be `mypeer2`.
--datadir optional. all data storage location. The `peer` of `peerData` must same as peername `peer`, eg: if `mypeer2Data`, peername must be `mypeer2`.
--keystoredir optional. a directory to store private keys. All key files are password protected, and it\'s very important to keep backups of all your keys.
--keystorepwd optional. password for all keystores. Or using the system environment variable `RUM_KSPASSWD`.
```
See more by running ```./quorum help``` and ```./quorum fullnode --help```.
*or*
Run RUM inside Docker:
Expand All @@ -148,7 +158,7 @@ docker run --user 1001 \
-p 8000:8000 \
-p 8001:8001 \
-e RUM_KSPASSWD='myverysecretpassword' \
quorum fullnode --listen /ip4/0.0.0.0/tcp/8000 --listen /ip4/0.0.0.0/tcp/8001/ws --apiport 8002 --peer /ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u,/ip4/132.145.109.63/tcp/10666/p2p/16Uiu2HAmTovb8kAJiYK8saskzz7cRQhb45NRK5AsbtdmYsLfD3RM
quorum fullnode --listen /ip4/0.0.0.0/tcp/8000 --listen /ip4/0.0.0.0/tcp/8001/ws --apiport 8002 --peer /ip4/94.23.17.189/tcp/62777/p2p/16Uiu2HAm5waftP3s4oE1EzGF2SyWeK726P5B8BSgFJqSiz6xScGz
```
### Example: a private decentralized forum
Expand Down Expand Up @@ -315,12 +325,38 @@ Add more producers to prevent outages.
1. Build the quorum binary by running the command: `make linux` or `make buildall`. You can find the binary file in the `dist` dir.
2. Add a shell script to run the peer:
Using the system environment variable `RUM_KSPASSWD` or add the param `keystorepwd`.
```sh
export RUM_KSPASSWD=your_very_secret_password
```
```bash
RUM_KSPASSWD=your_very_secret_password ./dist/linux_amd64/quorum fullnode --peername your_peer_name --listen /ip4/0.0.0.0/tcp/7002 --listen /ip4/0.0.0.0/tcp/7100/ws --apiport 8002 --peer /ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u --configdir /var/data/your_peer_nameConfig --datadir /var/data/your_peer_nameData --keystoredir /var/data/keystore --loglevel debug
# run fullnode of quorum
peername=my_first_peer
./quorum fullnode \
--keystorepwd=your_very_secret_password \
--keystoredir=keystore/$peername \
--configdir=config/$peername \
--datadir=data/$peername \
--peer=/ip4/101.42.141.118/tcp/62777/p2p/16Uiu2HAm9uziCEHprbzJoBdG9uktUQSYuFY58eW7o5Dz7rKhRn2j \
--listen=/ip4/0.0.0.0/tcp/60137 \
--listen=/ip4/0.0.0.0/tcp/60135/ws \
--apiport=60136 \
--log-compress=true \
--log-max-age=7 \
--log-max-backups=100 \
--log-max-size=10 \
--logfile=logs/$peername/quorum.log \
--loglevel=debug \
--enabledevnetwork=false
```
[view OPTIONS](#run_a_peer)
3. Run the shell script.
Tips: You can use our public bootstrap peer ```/ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u``` or any other online peers as bootstrap.
Tips: You can use our public bootstrap peer ```/ip4/94.23.17.189/tcp/62777/p2p/16Uiu2HAm5waftP3s4oE1EzGF2SyWeK726P5B8BSgFJqSiz6xScGz``` or any other online peers as bootstrap.
You can also run a bootstrapnode by using the following command: `./quorum bootstrapnode --help`.
30 changes: 30 additions & 0 deletions Tutorial.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,36 @@

<span id="top"></span>

## 概述:

Quorum 核心的是 fullnode(全节点),大量的 fullnode 在少量 bootstrap node 的协助下构建为分布式网络。

每个 fullnode 都能自主选择是否开放 api 给 lightnode(轻节点)调用来收发数据。

在 quorum 这个分布式网络中,数据以 trx 的形式被归集在指定的 group 中。

每个 fullnode 可以创建或加入多个 groups,每个 group 以顺序区块的方式(区块链)保存这些 trxs,也就是说,每个 rum group 都是一条独立的区块链。用户可以选择创建或加入(订阅)指定的 groups。

fullnode 与 lightnode 的最大区别在于,是否需要在本地同步和保存区块链的完整数据。—— 如果用户创建/加入多个 groups,那么就有多条相应的 group 级别的区块链。fullnode 在本地同步和保管指定区块链的完整数据,lightnode 通常只需要通过 fullnode 提供的 api 筛选和保存自己所需的数据。

Quorum 生态内的 apps/servers 可以是基于 fullnode 的,也可以是基于 lightnode 的。一般用户想要快速体验,推荐前往官网选择感兴趣的应用:https://rumsystem.net/apps

任选一个方式,都可启动一个 fullnode:

1、采用 [rum app(全节点应用)](https://rumsystem.net/apps ),包含 quorum 主程序和图形界面的桌面应用。

2、开发者友好:只需要 quorum 主程序,通过 curl 或相应语言的 sdk 使用 api 来与主程序交互。

在 main 分支通过 `make linux` 编译,在 `README.md` 查看启动指令,或直接 `./quorum help` 查看完整的指令和参数帮助。

还可以通过 `quorum jwt` 命令或 [api: CreateToken](https://rumsystem.github.io/quorum-api/#/Apps/post_app_api_v1_token) 来生成 role 为 chain 级的 jwt token。这类 token 掌握对 fullnode 的所有权限。本地可通过 ip:host 和 jwt 使用 api 访问和管理 fullnode。—— 连接远程节点的功能,也已经被 [rum app(全节点应用)](https://rumsystem.net/apps) 所支持。

通过 `quorum jwt` 命令或 [api: CreateToken](https://rumsystem.github.io/quorum-api/#/Apps/post_app_api_v1_token) 来生成 role 为 node 级的 jwt token。这类 token 掌握对相应 group 的部分权限,比如获取 group 的所有数据,以及往链上推送数据。

所有完整 api 可查阅:https://github.com/rumsystem/quorum-api

也许你需要[封装好的 sdk](https://github.com/okdaodine/awesome-quorum?tab=readme-ov-file#sdk)

## Menu

Start:
Expand Down
12 changes: 6 additions & 6 deletions howtotest.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ check the version and get help:
./quorum bootstrapnode \
--keystoredir=mynodes/bootstrapnode/keystore \
--keystorename=default \
--keystorepass=myboot123 \
--keystorepwd=myboot123 \
--configdir=mynodes/bootstrapnode/config \
--datadir=mynodes/bootstrapnode/data \
--listen=/ip4/0.0.0.0/tcp/50510 \
Expand Down Expand Up @@ -68,7 +68,7 @@ so, your bootstrap peer is `/ip4/127.0.0.1/tcp/50510/p2p/16Uiu2HAkxfXvruFGQUAURi
--peername=peer \
--keystoredir=mynodes/fullnode_owner/keystore \
--keystorename=default \
--keystorepass=myowner456 \
--keystorepwd=myowner456 \
--configdir=mynodes/fullnode_owner/config \
--datadir=mynodes/fullnode_owner/data \
--certdir=mynodes/fullnode_owner/certs \
Expand All @@ -93,7 +93,7 @@ so, your bootstrap peer is `/ip4/127.0.0.1/tcp/50510/p2p/16Uiu2HAkxfXvruFGQUAURi
--peername=peer \
--keystoredir=mynodes/fullnode_user/keystore \
--keystorename=default \
--keystorepass=myuser456 \
--keystorepwd=myuser456 \
--configdir=mynodes/fullnode_user/config \
--datadir=mynodes/fullnode_user/data \
--certdir=mynodes/fullnode_user/certs \
Expand All @@ -118,7 +118,7 @@ so, your bootstrap peer is `/ip4/127.0.0.1/tcp/50510/p2p/16Uiu2HAkxfXvruFGQUAURi
--peername=peer \
--keystoredir=mynodes/producernode1/keystore \
--keystorename=default \
--keystorepass=myproducer111 \
--keystorepwd=myproducer111 \
--configdir=mynodes/producernode1/config \
--datadir=mynodes/producernode1/data \
--certdir=mynodes/producernode1/certs \
Expand All @@ -142,7 +142,7 @@ so, your bootstrap peer is `/ip4/127.0.0.1/tcp/50510/p2p/16Uiu2HAkxfXvruFGQUAURi
--peername=peer \
--keystoredir=mynodes/producernode2/keystore \
--keystorename=default \
--keystorepass=myproducer222 \
--keystorepwd=myproducer222 \
--configdir=mynodes/producernode2/config \
--datadir=mynodes/producernode2/data \
--certdir=mynodes/producernode2/certs \
Expand All @@ -165,7 +165,7 @@ so, your bootstrap peer is `/ip4/127.0.0.1/tcp/50510/p2p/16Uiu2HAkxfXvruFGQUAURi
--peername=peer \
--keystoredir=mynodes/producernode2/keystore \
--keystorename=default \
--keystorepass=myproducer333 \
--keystorepwd=myproducer333 \
--configdir=mynodes/producernode3/config \
--datadir=mynodes/producernode3/data \
--certdir=mynodes/producernode3/certs \
Expand Down
2 changes: 1 addition & 1 deletion pkg/chainapi/api/addpeers_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ func addPeers(api string, payload handlers.AddPeerParam) (*handlers.AddPeerResul
func TestAddPeers(t *testing.T) {
t.Parallel()

payload := handlers.AddPeerParam{"/ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u"}
payload := handlers.AddPeerParam{"/ip4/192.99.101.35/tcp/10666/p2p/16Uiu2HAm8FNWrm1Zqe29Xe4EoHTzKG5UnVD2gCDB7D4b3SM5AvGi"}

if _, err := addPeers(peerapi, payload); err != nil {
t.Errorf("addPeers failed: %s, payload: %+v", err, payload)
Expand Down
2 changes: 1 addition & 1 deletion pkg/chainapi/handlers/addpeers.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import (
)

// AddPeerParam list of multiaddr
type AddPeerParam []string // Example: ["/ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u", "/ip4/132.145.109.63/tcp/10666/p2p/16Uiu2HAmTovb8kAJiYK8saskzz7cRQhb45NRK5AsbtdmYsLfD3RM"]
type AddPeerParam []string // Example: ["/ip4/94.23.17.189/tcp/62777/p2p/16Uiu2HAm5waftP3s4oE1EzGF2SyWeK726P5B8BSgFJqSiz6xScGz", "/ip4/132.145.109.63/tcp/10666/p2p/16Uiu2HAmTovb8kAJiYK8saskzz7cRQhb45NRK5AsbtdmYsLfD3RM"]

type AddPeerResult struct {
SuccCount int `json:"succ_count" example:"100"`
Expand Down
2 changes: 1 addition & 1 deletion systemd/quorum.service.sample
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ User=rum
Group=rum
RuntimeMaxSec=24h
Environment="RUM_KSPASSWD=YOUR_PASSWORD"
ExecStart=/usr/local/bin/quorum_linux fullnode --peername peer0 --listen /ip4/0.0.0.0/tcp/27002 --listen /ip4/0.0.0.0/tcp/27003/ws --apiport 28002 --apihost 127.0.0.1 --peer /ip4/94.23.17.189/tcp/10666/p2p/16Uiu2HAmGTcDnhj3KVQUwVx8SGLyKBXQwfAxNayJdEwfsnUYKK4u,/ip4/132.145.109.63/tcp/10666/p2p/16Uiu2HAmTovb8kAJiYK8saskzz7cRQhb45NRK5AsbtdmYsLfD3RM --configdir /var/data/peer0data/config --datadir /var/data/peer0data/peerdata --keystoredir /var/data/peer0data/keystore
ExecStart=/usr/local/bin/quorum_linux fullnode --peername peer0 --listen /ip4/0.0.0.0/tcp/27002 --listen /ip4/0.0.0.0/tcp/27003/ws --apiport 28002 --apihost 127.0.0.1 --peer /ip4/94.23.17.189/tcp/62777/p2p/16Uiu2HAm5waftP3s4oE1EzGF2SyWeK726P5B8BSgFJqSiz6xScGz,/ip4/132.145.109.63/tcp/10666/p2p/16Uiu2HAmTovb8kAJiYK8saskzz7cRQhb45NRK5AsbtdmYsLfD3RM --configdir /var/data/peer0data/config --datadir /var/data/peer0data/peerdata --keystoredir /var/data/peer0data/keystore
TimeoutStopSec=10s
LimitNOFILE=1048576
LimitNPROC=512
Expand Down

0 comments on commit 75f766f

Please sign in to comment.