Skip to content

Latest commit

 

History

History
160 lines (132 loc) · 3.86 KB

ansible-deploy-tool-usage.md

File metadata and controls

160 lines (132 loc) · 3.86 KB

Ansible部署工具使用

1. 安装Ansible

  • 在管理机器上安装Ansible,参照安装文档
  • 在管理机器的/etc/hosts中配置远程目标机器的IP和主机名映射关系,例如:
    # Miner
    192.168.1.11 postminer
    192.168.1.12 sealminer
    
    # Workers
    192.168.1.65 w65
    192.168.1.66 w66
    192.168.1.67 w67
    192.168.1.68 w68
    192.168.1.69 w69
    192.168.1.70 w70
    
  • 在要部署的远程目标机器上,安装Python环境及openssh-server;
    sudo apt-get install python
    sudo apt-get install openssh-server
  • 在管理机器安装openssh-client,配置到远程目标机器的SSH免密码登录;
    sudo apt-get install openssh-client
    cd   # cd到根目录下
    ssh-keygen -t rsa -P ""  # 一路回车
    ssh-copy-id xxx.xx.xx.xx  #设置你要免密登录的机器IP,输入密码即可完成 
    # 注意这种方式有一个硬性要求,即你需要远程免密的设备,用户名必须与当前管理机一致

2. 配置Ansible环境变量

根据自己的实际环境,修改管理机器的Ansible环境变量配置文件sudo vi /etc/ansible/hosts:

[public-daemon]
192.168.1.10

[window-post-miner]
192.168.1.11

[winning-post-miner]
192.168.1.12

[seal-miner]
192.168.1.13

[precommit-worker]
192.168.1.[20:50]

[commit-worker]
192.168.1.[60:80]

[all:vars]
remote_user=filguard

# fil proofs 环境变量
fil_proofs_parameter_cache=/home/filguard/disk_md0/proofs_param/v28
fil_proofs_parent_cache=/home/filguard/disk_md0/cache/parent
fil_proofs_maximize_caching=1
fil_proofs_use_gpu_column_builder=1
fil_proofs_use_gpu_tree_builder=1
fil_proofs_multicore_sdr_producers=1

# Rust环境变量
rust_log=trace
rust_backtrace=full

# Repo环境变量
lotus_path=/home/filguard/disk_md0/lotus
lotus_miner_path=/home/filguard/disk_md0/lotusminer
lotus_worker_path_0=/home/filguard/disk_md0/lotusworker0
lotus_worker_path_1=/home/filguard/disk_md0/lotusworker1
log_path=/home/filguard/disk_md0/logs
tmp_dir=/home/filguard/disk_md0/tmp
worker_port=3456
workspace=/home/filguard/workspace

# C2 优化后的环境变量
num_handles=15
num_kernels=2

# 扇区分配Miner的IP和端口
sector_counter_host=192.168.1.11
sector_counter_port=1357

# 替换为Daemon的token和listenAddress
fullnode_api_info=<token>:<address>

# 替换为Miner的token和listenAddress
seal_miner_api_info=<token>:<address>

# Miner目录备份配置
backup_host=192.168.1.60
backup_user=filguard
backup_path=/home/filguard/disk_md0/backup

3. 部署准备

3.1 设置Ansible别名

在管理机器上,将ansible和ansible-playbook分别设置anap的别名,方便快捷操作:

$ echo "alias an=/usr/bin/ansible" >> $HOME/.profile
$ echo "alias ap=/usr/bin/ansible-playbook" >> $HOME/.profile
$ source $HOME/.profile

3.2 Clone工作目录

Clone Filguard团队提供的运维脚本至$HOME/workspace目录下。

$ mkdir -p $HOME/workspace
$ cd $HOME/workspace
$ git clone https://github.com/filguard/lotus-ops.git

4. Ansible部署脚本使用说明

注意:以下所有操作都需切换到$HOME/workspace/lotus-ops/ansible目录下:

$ cd $HOME/workspace/lotus-ops/ansible

拷贝二进制文件到worker

$ ap copy-bin-to-worker.yaml -k -K
# 需要输入worker的ssh远程登录密码

启动 Deamon

$ ap 0-start-daemon.yaml

启动 Window-PoSt-Miner

$ ap 1-start-window-post-miner.yaml

启动 Winning-PoSt-Miner

$ ap 2-start-winning-post-miner.yaml

启动 Precommit Worker

$ ap 5-start-precommit-worker.yaml

启动 Commit Worker

$ ap 6-start-commit-worker.yaml

停止Worker

# 停止 precommit worker
$ ap stop-precommit-worker.yaml
# 停止 commit worker
$ ap stop-commit-worker.yaml