已启动并测试多服务器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作为守护进程运行的文档。也就是说:目前我在一个远程shell中运行weed。关闭外壳关闭杂草。
非常感谢您的任何指点
发布于 2021-01-16 19:31:06
通过手动滚动一个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-pagerhttps://stackoverflow.com/questions/65704384
复制相似问题