1

开始并测试了一个多服务器seaweedFS设置,如下所示,效果很好:

./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
./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=ip2 -dataCenter=ABC -rack=B -volume.max=100
./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=ip3 -dataCenter=ABC -rack=C -volume.max=100

但是,我没有看到任何关于如何让 seaweedFS 作为守护进程运行的文档。即:目前我正在远程外壳中运行杂草。关闭外壳关闭杂草。

非常感谢任何指针

4

1 回答 1

3

通过手动滚动系统服务解决了这个问题。

对于每个节点做:(显然,用你自己的杂草特定命令替换)

# 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
于 2021-01-16T11:31:06.393 回答