go-fastfds部署心得

我是windows系统安装 Docker Desktop部署  

docker run --name go-fastdfs(任意的一个名称) --privileged=true -t -p 3666:8080 -v /data/fasttdfs_data:/data -e GO_FASTDFS_DIR=/data sjqzhang/go-fastdfs:lastest

docker run:该命令用于运行一个新的Docker容器。

--name go-fastdfs:指定新容器的名称,在本例中,它设置为go-fastdfs。

--privileged=true:向容器授予扩展权限。这对于需要提升权限的某些操作通常是必要的。

-t:为容器分配一个伪 TTY(终端)。这通常用于与容器的外壳进行交互。

-p 3666:8080:将主机上的3666端口映射到容器上的8080端口。这意味着您可以从主机的端口 3666 访问容器内端口 8080 上运行的服务。

-v /data/fasttdfs_data:/data:将/data/fasttdfs_data宿主机的目录挂载到/data容器内的目录。这用于卷映射,允许数据保留在容器外部。

-e GO_FASTDFS_DIR=/data:在容器内设置一个环境变量,GO_FASTDFS_DIR其值为/data。该环境变量可能被sjqzhang/go-fastdfs图像使用。

sjqzhang/go-fastdfs:指定创建容器时使用的Docker镜像。sjqzhang在本例中,它是为应用程序创建的图像go-fastdfs。

输出“Listen on :8080”表示容器内的应用程序正在侦听端口 8080 上的传入连接。这时候可以能够通过在http://localhost:3666Web 浏览器中访问主机上的服务。

如果只用文件上传接口  到这里已经结束了

下面的配置项是与其他三个接口有密切联系

/group1/get_file_info文件详情接口

/group1/delete文件删除接口

/group1/list_dir文件列表接口

这三个接口都会报这样的一个错误:Can only be called by the cluster ip or 127.0.0.1 or admin_ips(cfg.json),current ip:172.17.0.1

出现这个错误  要修改两个地方   

一、1.docker ps  或者docker images打开你的镜像列表

2. 接着进入镜像内部  docker exec -it go-fastdfs sh(与安装时你起的任意名称对应) 

3. vi  /data/conf/cfg.json  此操作和linux系统的vi、vim类似 所谓的编辑器模式

4. 找到peers字段    peers参数会自动生成一个本地主机ip,但还是需要配置增加一个内网ip

不然使用api时会报:

Can only be called by the cluster ip or 127.0.0.1 or admin_ips(cfg.json),current ip:172.17.0.1

data文件夹下是四个子文件夹

files文件夹:是图片上传以后保存的路径,默认是按日期划分,也可以指定路径。 
log文件夹:是上传信息和运行的日志信息。 
static文件夹:是放置一些前端静态页面xml文件。 
data文件夹:里面是一些上传的后的图片信息记录保存在ldb格式文件,如文件的md5值,上传后的路径,时间戳,Szie大小等.
到这里问题多数情况就解决了 

5. 步骤4操作完不行的话 修改   "admin_ips": ["127.0.0.1", "192.168.12.35"],

"admin_ips"字段类似于白名单的作用

步骤5操作完毕   还不行的话   就要看下面的docker操作了  修改docker网关

若不想通过小黑框操作  可以在外面修改  然后粘贴进容器

docker cp C:\Users\zhouchanghao\Desktop\gofile\conf\cfg.json go-fastdfs:/data/conf/cfg.json

docker   cp   [OPTIONS]   SRC_PATH   CONTAINER:DEST_PATH

  • SRC_PATH:是主机上的文件或目录的路径,这里是 C:\Users\zhouchanghao\Desktop\gofile\conf\cfg.json
  • CONTAINER:是目标容器的名称或 ID,这里是 go-fastdfs
  • DEST_PATH:是容器内目标路径,这里是 /data/conf/cfg.json

OPTIONS 是用于指定一些额外参数的部分。在这个命令中,docker cp 并没有太多的额外选项需要设置,所以 OPTIONS 这一部分通常是省略的。

如果有需要,可以在 docker cp 命令中使用一些选项。例如,常见的选项包括:

  • -L, --follow-link:如果源是符号链接,则会复制链接指向的内容而不是链接本身。
  • --help:显示帮助信息,列出所有可用的选项。
  • -a, --archive:归档模式,保留所有文件的元数据。

在这里命令中,由于没有使用额外的选项,所以 OPTIONS 部分为空。

所以,这个命令的作用是将主机上的 cfg.json 文件复制到运行中的 go-fastdfs 容器的 /data/conf/ 目录下。这样做可以更新容器内的配置文件,使得容器在运行时使用新的配置。

二、修改docker网关

Docker容器启动后,默认会在主机上分配一个网卡,该网卡对应一个网络命名空间,并在这个网络命名空间下随机分配一个IP地址

小黑框操作命令:docker network inspect bridge   或  docker inspect bridge

找到里面 "Config": [
                {
                    "Subnet": "172.17.0.0/16",
                    "Gateway": "172.17.0.1"
                }
            ]

可以看到Subnet和Gateway了

可视化面板如下操作添加即可

{
  "builder": {
    "gc": {
      "defaultKeepStorage": "20GB",
      "enabled": true
    }
  },
  "experimental": false,
  "default-address-pools": [
    {
      "base": "你的新的IP地址/掩码",
      "size": 24
    }
  ]
}

docker restart go-fastdfs 重启镜像  完美运行

Windows系统部署

一、将放入随便的路径下

二、 Win+R命令提示符进入上一步存放路径内    执行命令  文件名称 server  如图:

三、

出现此提示代表运行成功  8080为默认端口号  可更改

若被拒绝访问   则以管理员身份重新运行命令提示符重复上面流程

四、返回最初路径  此时多了五个文件夹

files文件夹:是图片上传以后保存的路径,默认是按日期划分,也可以指定路径。 
log文件夹:是上传信息和运行的日志信息。 
static文件夹:是放置一些前端静态页面xml文件。 
data文件夹:里面是一些上传的后的图片信息记录保存在ldb格式文件,如文件的md5值,上传后的路径,时间戳,Szie大小等.

若想修改运行端口  则进入conf文件夹 编辑cfg.json文件

编辑保存即可  其他配置项若自己需要更改则请谨慎操作   (建议不更改)  

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Go-Streams 是一个分布式流式数据处理库,可以在多台主机上部署并协同工作。要跨主机部署 Go-Streams,需要使用 Go-Streams 提供的网络连接器和数据传输器。 网络连接器负责建立分布式处理流之间的网络连接,以便它们可以相互通信和协调工作。数据传输器负责将数据流从一个主机传输到另一个主机,以便实现分布式流式处理。 下面是一个简单的跨主机部署示例: 1. 在主机 A 上启动 Go-Streams 流: ```go package main import ( "github.com/reugn/go-streams/stream" "github.com/reugn/go-streams/connector" "github.com/reugn/go-streams/transport" ) func main() { // 创建输入流 inputStream := stream.NewStream() // ... // 创建网络连接器 connector := connector.NewDefaultConnector() // 在本地主机上启动连接器 connector.Start() // 创建数据传输器 transporter := transport.NewDefaultTransporter(connector) // 将输入流发送到主机 B transporter.Send("localhost:9000", inputStream) } ``` 2. 在主机 B 上启动 Go-Streams 流: ```go package main import ( "github.com/reugn/go-streams/stream" "github.com/reugn/go-streams/connector" "github.com/reugn/go-streams/transport" ) func main() { // 创建网络连接器 connector := connector.NewDefaultConnector() // 在本地主机上启动连接器 connector.Start() // 创建数据传输器 transporter := transport.NewDefaultTransporter(connector) // 从主机 A 接收输入流 inputStream := transporter.Receive("localhost:9000") // ... // 创建输出流 outputStream := stream.NewStream() // ... // 将输出流发送到主机 A transporter.Send("localhost:8000", outputStream) } ``` 3. 在主机 A 上接收输出流: ```go package main import ( "github.com/reugn/go-streams/stream" "github.com/reugn/go-streams/connector" "github.com/reugn/go-streams/transport" ) func main() { // 创建输出流 outputStream := stream.NewStream() // ... // 创建网络连接器 connector := connector.NewDefaultConnector() // 在本地主机上启动连接器 connector.Start() // 创建数据传输器 transporter := transport.NewDefaultTransporter(connector) // 从主机 B 接收输出流 transporter.Receive("localhost:8000", outputStream) // ... } ``` 在此示例中,主机 A 和主机 B 分别运行一个 Go-Streams 流,并通过网络连接器和数据传输器协调工作。主机 A 将输入流发送到主机 B,并从主机 B 接收输出流。主机 B 接收主机 A 发送的输入流,并将输出流发送回主机 A。 注意:在生产环境中,需要考虑更多的因素,如网络延迟、数据丢失、流量控制等,以确保分布式流式处理的稳定性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一分半心动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值