avatar

黄金月河3.1

浴火重生

  • 首页
  • Linux基础
  • 运维
  • Github
  • Python
  • 网络安全
  • 软路由
  • 时光手札
  • 关于
Home 用docker运行webdav
文章

用docker运行webdav

Posted 2024-04-1 Updated 2024-04- 2
By 奈幽
9~12 min read

在Centos7手动部署WebDav服务

服务器操作系统:Centos7.8

Github 项目地址:https://github.com/hacdias/webdav 当前最新版本为 4.2.0

1.下载配置WebDav

在 /data/webdav-app下新建webdav目录,下载webdav并解压到目录

mkdir /data/webdav-appcd /data/webdav-app
cd /data/webdav-app
wget https://github.com/hacdias/webdav/releases/download/v4.2.0/linux-amd64-webdav.tar.gz
tar -xvzf linux-amd64-webdav.tar.gz

2. 创建配置文件

在/data/webdav-app/目录下新建配置文件config.yaml

vim /data/webdav-app/config.yaml

address: 0.0.0.0
port: 15108
auth: true
tls: false
cert: cert.pem
key: key.pem

scope: .
modify: true
rules: []

users:
  - username: user
    password: 123456
    scope: /data/webdav-data

对外服务的端口号为15108,需要在安全组或防火墙里放开。

目录/data/webdav-data用于存储user的文件,需要手动创建。

如果有多个用户,则遵循yaml的文件规范,按user1的格式添加到下面即可。

3. 创建启动脚本

在/usr/lib/systemd/system/下新建文件webdav.service,内容如下

vim /usr/lib/systemd/system/webdav.service

[Unit]
Description=WebDAV server
After=network.target

[Service]
Type=simple
User=root
ExecStart=/data/webdav-app/webdav --config /data/webdav-app/config.yaml
Restart=on-failure

[Install]
WantedBy=multi-user.target

4. 启动WebDav服务

systemctl daemon-reload
systemctl enable webdav
systemctl start webdav

查看服务状态

systemctl status webdav

输出类似如下

webdav.service - WebDAV server
   Loaded: loaded (/usr/lib/systemd/system/webdav.service; enabled; vendor preset: disabled)
   Active: active (running) since Thu 2022-10-13 10:27:13 CST; 6h ago
 Main PID: 16679 (webdav)
    Tasks: 8
   Memory: 350.2M
   CGroup: /system.slice/webdav.service
           └─16679 /data/webdav-app/webdav --config /data/webdav-app/config.yaml

5. 开放防火墙端口

# iptables
iptables -A INPUT -p tcp --dport 15108 -j ACCEPT
service iptables save
systemctl restart iptables

# firewall-cmd
firewall-cmd --zone=public --add-port=15108/tcp --permanent
firewall-cmd --reload

使用Docker部署WebDAV服务

1、创建持久化目录

mkdir -p /home/webdav/data
mkdir -p /home/webdav/config

2、创建配置文件config.yaml

# 监听任意网卡,多网卡可指定对应ip
address: 0.0.0.0
port: 8088
auth: true
prefix: /
modify: true
rules: []

# 跨域设置
cors:
enabled: true
credentials: true
allowed_headers:
  - Depth
allowed_hosts:
  - http://localhost:8088
allowed_methods:
  - GET
exposed_headers:
  - Content-Length
  - Content-Range

# 用户信息,如果 auth 为 true 生效
users:
- username: your_user
  password: your_password
  # 配置自己的 webdav 访问范围,此例为 /data 内所有文件
  scope: /data

3、运行 WebDAV 容器

docker run --name webdav --restart always -v /home/webdav/data:/data -v /home/webdav/config:/config -p 8088:8088  -d hacdias/webdav:latest --config /config/config.yaml

配置nginx反向代理

还有一个问题能不能使用nginx的443的代理,是不是更加安全呢

    server {
        listen 443 ssl;
        server_name webdav.nerubian.cn;
        client_max_body_size 1000M;

        access_log  /usr/local/nginx/logs/nginx.webdav.log;
        error_log   /usr/local/nginx/logs/error.webdav.log;

        ssl_certificate /etc/nginx/ssl/webdav/webdav.nerubian.cn_nginx/webdav.nerubian.cn_bundle.crt;
        ssl_certificate_key /etc/nginx/ssl/webdav/webdav.nerubian.cn_nginx/webdav.nerubian.cn.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
        ssl_prefer_server_ciphers on;

                location / {
            proxy_pass  http://127.0.0.1:8088;
            proxy_redirect off;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
    server {
        listen  80;
        server_name  webdav.nerubian.cn;
        return 301 https://$host$request_uri;
    }

容器
docker webdav
License:  CC BY 4.0
Share

Further Reading

Apr 8, 2025

rhel9 安装docker和docker-compose

1、rhel9 安装docker 1.1、yum安装 1.1.1、添加镜像源 sudo bash -c "cat > /etc/yum.repos.d/docker-ce.repo"<< EOF [docker-ce-stable] name = docker-ce-stable baseurl

Feb 20, 2025

【BASH】Docker容器映射目录检测脚本

#!/bin/bash # check_docker_permissions.sh - 容器权限检测工具 # 配置参数 LOG_DIR="./docker_check" # 定义日志目录的路径 TS=$(date +%Y%m%d_%H%M%S) # 获取当前时间戳,格式为 YYYYMMDD_H

Feb 19, 2025

Docker容器内进程是否有持久化目录访问权限的检测脚本

操作示例: # 检查单个容器 $ ./check_docker_permissions.sh ​ # 检查多个容器 $ ./check_docker_permissions.sh 1,3,nginx ​ # 检查所有容器 $ ./check_docker_permissions.sh all 脚本内

OLDER

Google chrome 浏览器设置收集

NEWER

Portainer 轻量级Docker管理工具

Recently Updated

  • 奈幽的渗透测试总结-红队
  • 基于Docker的虚拟 Chrome 浏览器
  • Metasploit Framework (MSF) 使用指南
  • rhel9 安装docker和docker-compose
  • 内网穿透工具:zrok

Trending Tags

Halo elasticsearch debian openwrt KeepassXC 必看精选 webdav 热门文章 docker Linux

Contents

©2025 黄金月河3.1. Some rights reserved.

Using the Halo theme Chirpy