- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章如何使用 docker-compose 搭建 fastDFS文件服务器由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
上篇文章给大家介绍了使用docker compose安装FastDfs文件服务器的实例详解 。
今天给大家介绍如何使用 docker compose 搭建 fastDFS文件服务器,内容详情如下所示:
平台 :Mac M1 。
备注:关于 IP Address 。
关于 docker 的网络模式,上述文中提到了 docker 的 Host 模式:
如果启动容器的时候使用host模式,那么这个容器将不会获得一个独立的Network Namespace,而是和宿主机共用一个 Network Namespace。容器将不会虚拟出自己的网卡,配置自己的 IP 等,而是使用宿主机的 IP 和端口。但是,容器的其他方面,如文件系统、进程列表等还是和宿主机隔离的.
问题在于:使用宿主机的 IP 和端口的话,配置文件中 IP 填写 localhost的话按理说能访问到容器,然而事实上却不行。个人理解(如果理解有问题的话烦请指正)的 IP Address填写方法如下:
启动 tracker 时控制台输出:
192.168.64.2的网络为:
192.168.65.4的网络为:
文件目录 。
1
2
3
4
5
6
7
8
9
|
├── docker-compose.yaml
├── nginx
│ └── nginx.conf
├── storage
│ └── data
└── tracker
│ └── conf
│ └── client.conf
└── store_path
|
./docker-compose.yaml 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
version:
"2"
services:
fastdfs-tracker:
hostname
: fastdfs-tracker
container_name: fastdfs-tracker
image: season
/fastdfs
:1.2
network_mode:
"host"
command
: tracker
volumes:
- .
/tracker/data
:
/fastdfs/tracker/data
- .
/tracker/conf
:
/etc/fdfs
fastdfs-storage:
hostname
: fastdfs-storage
container_name: fastdfs-storage
image: season
/fastdfs
:1.2
network_mode:
"host"
volumes:
- .
/storage/data
:
/fastdfs/storage/data
- .
/store_path
:
/fastdfs/store_path
environment:
- TRACKER_SERVER=192.168.64.2:22122
command
: storage
depends_on:
- fastdfs-tracker
fastdfs-nginx:
hostname
: fastdfs-nginx
container_name: fastdfs-nginx
image: season
/fastdfs
:1.2
network_mode:
"host"
volumes:
- .
/nginx/nginx
.conf:
/etc/nginx/conf/nginx
.conf
- .
/store_path
:
/fastdfs/store_path
environment:
- TRACKER_SERVER=192.168.64.2:22122
command
: nginx
|
./tracker/conf/client.conf 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
# connect timeout in seconds
# default value is 30s
connect_timeout=30
# network timeout in seconds
# default value is 30s
network_timeout=60
# the base path to store log files
base_path=
/fastdfs/client
# tracker_server can ocur more than once, and tracker_server format is
# "host:port", host can be hostname or ip address
# 需要修改此处 ip
tracker_server=192.168.64.2:22122
#standard log level as syslog, case insensitive, value list:
### emerg for emergency
### alert
### crit for critical
### error
### warn for warning
### notice
### info
### debug
log_level=info
# if use connection pool
# default value is false
# since V4.05
use_connection_pool =
false
# connections whose the idle time exceeds this time will be closed
# unit: second
# default value is 3600
# since V4.05
connection_pool_max_idle_time = 3600
# if load FastDFS parameters from tracker server
# since V4.05
# default value is false
load_fdfs_parameters_from_tracker=
false
# if use storage ID instead of IP address
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# default value is false
# since V4.05
use_storage_id =
false
# specify storage ids filename, can use relative or absolute path
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# since V4.05
storage_ids_filename = storage_ids.conf
#HTTP settings
http.tracker_server_port=80
#use "#include" directive to include HTTP other settiongs
##include http.conf
|
./nginx/nginx.conf 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application
/octet-stream
;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 9800;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
# 修改部分
location / {
root
/fastdfs/store_path/data
;
ngx_fastdfs_module;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504
/50x
.html;
location =
/50x
.html {
root html;
}
}
}
|
SpringBoot 集成 fastDFS 。
添加依赖 。
1
2
3
4
5
|
<dependency>
<groupId>com.github.tobato</groupId>
<artifactId>fastdfs-client</artifactId>
<version>
1.27
.
2
</version>
</dependency>
|
。
applicaiton.yaml 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
# 分布式文件系统配置
fdfs:
#根据自己的ip进行更改
ip:
192.168
.
64.2
#socket连接超时时长
soTimeout:
1500
connectTimeout:
600
#支持多个
trackerList:
- ${fdfs.ip}:
22122
# fastDFS 中的 nginx 的 ip 和 port
# IDEA 提示使用 https,
# nginx 配置 SSL 请移步:
web-server-url: http:
//${fdfs.ip}:9800/
|
FastDFSConfig.java 。
1
2
3
4
5
6
7
|
@Configuration
// 导入FastDFS-Client组件
@Import
(FdfsClientConfig.
class
)
// 解决jmx重复注册bean的问题
@EnableMBeanExport
(registration = RegistrationPolicy.IGNORE_EXISTING)
public
aspect FastDFSConfig {
}
|
FastDFSUtil.java 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
@Component
public
class
FastDFSUtil {
@Resource
private
FastFileStorageClient fastFileStorageClient;
@Resource
private
FdfsWebServer fdfsWebServer;
public
String uploadFile(MultipartFile file)
throws
IOException {
StorePath storePath = fastFileStorageClient.uploadFile(file.getInputStream(), file.getSize(), FilenameUtils.getExtension(file.getOriginalFilename()),
null
);
String fullPath = storePath.getFullPath();
getResAccessUrl(fullPath);
return
fullPath;
}
public
String uploadFile(File file) {
try
{
FileInputStream inputStream =
new
FileInputStream(file);
StorePath storePath = fastFileStorageClient.uploadFile(inputStream, file.length(), FilenameUtils.getExtension(file.getName()),
null
);
return
storePath.getFullPath();
}
catch
(Exception e) {
e.printStackTrace();
return
null
;
}
}
public
byte
[] downloadFile(String filePath) {
StorePath storePath = StorePath.parseFromUrl(filePath);
return
fastFileStorageClient.downloadFile(storePath.getGroup(), storePath.getPath(),
new
DownloadByteArray());
}
public
Boolean deleteFile(String filePath) {
if
(StringUtils.isEmpty(filePath)) {
return
false
;
}
try
{
StorePath storePath = StorePath.parseFromUrl(filePath);
fastFileStorageClient.deleteFile(storePath.getGroup(), storePath.getPath());
}
catch
(Exception e) {
e.printStackTrace();
return
false
;
}
return
true
;
}
/**
* 封装文件完整 URL 地址
*
* @param path
* @return
*/
public
String getResAccessUrl(String path) {
return
fdfsWebServer.getWebServerUrl() + path;
}
}
|
FastDFSController.java 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
@RestController
@RequestMapping
(
"/fast-dfs"
)
public
class
FastDFSController {
/**
* @param file
* @return
* @throws IOException
*/
@PostMapping
(
""
)
@Transactional
public
void
uploadFile(MultipartFile file, String cuisineId)
throws
IOException {
String s = fastDfsUtil.uploadFile(file);
String resAccessUrl = fastDfsUtil.getResAccessUrl(s);
}
/**
* @param response
* @throws IOException
*/
@GetMapping
(
""
)
public
void
downloadFile(String filePath, HttpServletResponse response)
throws
IOException {
byte
[] bytes = fastDfsUtil.downloadFile(filePath);
String[] split = filePath.split(
"/"
);
String fileName = split[split.length -
1
];
// 设置强制下载不打开
response.setContentType(
"application/force-download"
);
fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8);
response.setHeader(
"Content-Disposition"
,
"attachment;filename="
+ fileName);
IOUtils.write(bytes, response.getOutputStream());
}
/**
* 流媒体的方式播放视频,只能从头看到尾,不能手动点击重新看已经看过的内容
* @param filePath
* @param response
* @throws IOException
*/
@GetMapping
(
"/play"
)
public
void
streamMedia(String filePath, HttpServletResponse response)
throws
IOException {
byte
[] bytes = fastDfsUtil.downloadFile(filePath);
IOUtils.copy(
new
ByteArrayInputStream(bytes), response.getOutputStream());
response.flushBuffer();
}
}
|
到此这篇关于如何使用 docker compose 搭建 fastDFS文件服务器的文章就介绍到这了,更多相关docker compose 搭建 fastDFS内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/edoclin/p/14648832.html 。
最后此篇关于如何使用 docker-compose 搭建 fastDFS文件服务器的文章就讲到这里了,如果你想了解更多关于如何使用 docker-compose 搭建 fastDFS文件服务器的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!