Запустил и протестировал многосерверную установку seaweedFS, как показано ниже, которая отлично работает: ./weed server -dir = / VolA, / VolB -s3 -s3.config = weed.json -s3.port = 9001 -master.defaultReplication = " 010 "-...

0
Geert-Jan 13 Янв 2021 в 17:55

1 ответ

Лучший ответ

Решил это вручную, накатав сервис systemd.

Для каждого узла выполните: (очевидно, замените его собственными командами, специфичными для сорняков)

# 1. Move `weed` to some directory the startup service can access. I used `/usr/local/bin/weed/`. Include `weed` and `weed.json` in that directory (ymmv) 


mkdir /usr/local/bin/weed
mv weed /usr/local/bin/weed/weed
mv weed.json /usr/local/bin/weed/weed.json


# 2. Create a systemd service config: 

cat > /etc/systemd/system/seaweedmaster.service <<EOM

[Unit]
Description=SeaweedFS Server
After=network.target

[Service]
Type=simple
User=root
Group=root

ExecStart=/usr/local/bin/weed/weed server -dir=/VolA,/VolB -s3 -s3.config=weed.json -s3.port=9001 -master.defaultReplication="010" -master.peers=ip1:9333,ip2:9333,ip3:9333 -ip=ip1 -dataCenter=ABC -rack=A -volume.max=100
WorkingDirectory=/usr/local/bin/weed/
SyslogIdentifier=seaweedfs-master

[Install]
WantedBy=multi-user.target
EOM


# 3. Reload, enable and start 

sudo systemctl daemon-reload
sudo systemctl enable seaweedmaster
sudo systemctl start seaweedmaster



# 4. logging the output, one of many options: 

journalctl -u seaweedmaster.service -b --no-pager
1
Geert-Jan 16 Янв 2021 в 11:31