Docker Compose 是一个功能强大且易于使用的工具,可以极大地简化容器化应用程序的部署和管理过程。通过定义一个简单的 YAML 文件,用户可以轻松地描述应用程序的架构和依赖关系,并使用一条命令即可启动、停止或重新构建整个应用程序。

1、memos

1.1、创建文件夹

1
mkdir -p ~/.docker/memos/data

1.2、编辑 docker-compose.yml

1
cd ~/.docker/memos
1
vim docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
services:
memos:
image: neosmemo/memos:stable
container_name: memos
restart: unless-stopped
volumes:
- ./data:/var/opt/memos # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 data 目录,用于存放数据,如果不存在的话,会自动创建
ports:
- 5230:5230 # 可以把冒号左边的 5230 端口修改成你服务器上没有被占用的端口
networks:
memos_network:
networks:
memos_network:

1.3、启动 memos

1
docker compose up -d

1.4、升级

1
docker compose pull
1
docker compose up -d

2、shaarli

2.1、创建文件夹

1
mkdir -p ~/.docker/shaarli

2.2、编辑 docker-compose.yml

1
cd ~/.docker/shaarli
1
vim docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
services:
shaarli:
image: shaarli/shaarli:latest
container_name: shaarli
restart: unless-stopped
volumes:
- ./shaarli-data:/var/www/shaarli/data # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 shaarli-data 目录,用于存放数据,如果不存在的话,会自动创建
- ./shaarli-cache:/var/www/shaarli/cache # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 shaarli-cache 目录,用于存放数据,如果不存在的话,会自动创建
ports:
- 8000:80 # 可以把冒号左边的 8000 端口修改成你服务器上没有被占用的端口
networks:
shaarli_network:
networks:
shaarli_network:

2.3、启动 shaarli

1
docker compose up -d

访问网页时报错,调整文件夹权限,强制刷新网页

1
2
docker exec -it shaarli chown -R nginx:nginx /var/www/shaarli/data
docker exec -it shaarli chown -R nginx:nginx /var/www/shaarli/cache

2.4、升级

1
docker compose pull
1
docker compose up -d

3、freshrss

3.1、创建文件夹

1
mkdir -p ~/.docker/freshrss

3.2、编辑 docker-compose.yml

1
cd ~/.docker/freshrss
1
vim docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
services:
freshrss:
image: freshrss/freshrss:latest
container_name: freshrss
restart: unless-stopped
volumes:
- ./freshrss_data:/var/www/FreshRSS/data # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 freshrss_data 目录,用于存放数据,如果不存在的话,会自动创建
- ./freshrss_extensions:/var/www/FreshRSS/extensions # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 freshrss_extensions 目录,用于存放数据,如果不存在的话,会自动创建
ports:
- 8008:80 # 可以把冒号左边的 8008 端口修改成你服务器上没有被占用的端口
environment:
TZ: Asia/Shanghai
# Cron job to refresh feeds at specified minutes
CRON_MIN: '2,16,32,45,58'
# 'development' for additional logs; default is 'production'
FRESHRSS_ENV: development
networks:
freshrss_network:
networks:
freshrss_network:

3.3、启动 freshrss

1
docker compose up -d

3.4、升级

1
docker compose pull
1
docker compose up -d

4、alist

4.1、创建文件夹

1
mkdir -p ~/.docker/alist/data

4.2、编辑 docker-compose.yml

1
cd ~/.docker/alist
1
vim docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
services:
alist:
image: xhofe/alist:latest
container_name: alist
restart: unless-stopped
volumes:
- ./data:/opt/alist/data # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 data 目录,用于存放数据,如果不存在的话,会自动创建
ports:
- 5255:5244 # 可以把冒号左边的 5255 端口修改成你服务器上没有被占用的端口
environment:
- PUID=0
- PGID=0
- UMASK=022
networks:
alist_network:
networks:
alist_network:

4.3、启动 alist

1
docker compose up -d

4.4、升级

1
docker compose pull
1
docker compose up -d

4.5、修改密码

1
docker exec -it alist bash
1
./alist admin random

5、xiaoya

5.1、创建文件夹

1
mkdir -p ~/.docker/xiaoya/config
  • 设置 mymytoken
1
vim ~/.docker/xiaoya/config/mytoken.txt
  • 设置 myopentoken.txt
1
vim ~/.docker/xiaoya/config/myopentoken.txt
  • 设置 temp_transfer_folder_id
1
vim ~/.docker/xiaoya/config/temp_transfer_folder_id.txt

5.2、编辑 docker-compose.yml

1
cd ~/.docker/xiaoya
1
vim docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
services:
xiaoya:
image: xiaoyaliu/alist:latest
container_name: xiaoya
restart: unless-stopped
volumes:
- ./config:/data # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个 config 目录,用于存放配置,如果不存在的话,会自动创建
- ./config/data:/www/data # 点号表示当前文件夹,冒号左边的意思是在当前文件夹下创建一个二级 data 目录,用于存放数据,如果不存在的话,会自动创建
ports:
- 5678:80 # 可以把冒号左边的 5678 端口修改成你服务器上没有被占用的端口
- 2345:2345
- 2346:2346
networks:
xiaoya_network:
networks:
xiaoya_network:

5.3、启动 xiaoya

1
docker compose up -d

5.4、升级

1
docker compose pull
1
docker compose up -d

5.5、定时重启同步数据

1
crontab -e
1
0 6 * * * docker restart xiaoya