# 家庭服务器打通最后一公里


<!--more-->
## 家庭服务器

这半个多月来，用闲置的电脑和已有的家庭宽带，从wsl折腾到vmware，安装了Ubuntu系统，折腾搭建家庭服务器，安装一系列软件，折腾了无数个日夜，遇到了很多问题，并逐步解决，今天终于打通最后一公里，Nginx带端口反向代理完成，开放一个端口，其他服务通过对应不同二级或三级域名来访问，打通网络最后一公里，算是圆满了。先mark一下，接下来安排时间再细化记录。

## 折腾过程

### vmware安装ubuntu

### 终端工具

### docker

### portainer

### 青龙面板

### ddns-go

### nginx proxy manager 

Nginx Proxy Manager (NPM) 默认监听80和443端口，但如果你想修改为其他端口，如8000和9000，你需要更改NPM的配置。请按照以下步骤操作：

1.  首先，停止运行的Nginx Proxy Manager Docker容器：
    
    Copy
    
    ```
    docker-compose down
    ```
    或者

```
    docker stop <container_id>
```

1.  打开`docker-compose.yml`文件（如果你使用Docker Compose），或者查找启动Docker容器的命令行参数。你需要找到映射到Nginx Proxy Manager容器内的端口。
    
    对于`docker-compose.yml`文件，它可能是这样的：
    
    yaml
    
    Copy
    
    ````
    services:
      app:
        image: 'jc21/nginx-proxy-manager:2.10.3'
        ports:
          - '80:80'
          - '443:443'
          - '81:81'
    ```
    
    如果你是通过命令行启动容器，它可能类似于:
    
    ````
    
    docker run -d --name nginx-proxy-manager -p 80:80 -p 443:443 -p 81:81 jc21/nginx-proxy-manager:2.10.3
    
    Copy
    
3.  修改端口映射。将`80:80`更改为`8000:80`，将`443:443`更改为`9000:443`。对于`docker-compose.yml`文件，修改后的内容应该是这样的：
    
    yaml
    
    Copy
    
    ````
    services:
      app:
        image: 'jc21/nginx-proxy-manager:2.10.3'
        ports:
          - '8000:80'
          - '9000:443'
          - '81:81'
    ```
    
    如果你是通过命令行启动容器，修改后的命令应该是：
    
    ````
    
    docker run -d --name nginx-proxy-manager -p 8000:80 -p 9000:443 -p 81:81 jc21/nginx-proxy-manager:2.10.3
    
    Copy
    
4.  重新启动Nginx Proxy Manager容器：
    
    Copy
    
    ````
    docker-compose up -d
    ```
    
    或者
    
    ````
    
    docker start <container_id>
    
    Copy
    

现在，你的Nginx Proxy Manager应该已经在8000和9000端口上监听了。请注意，由于更改了默认端口，你需要在访问NPM的管理界面时指定新的端口。例如，如果你的服务器IP是`example.com`，请使用`http://example.com:8000`访问HTTP网站，使用`https://example.com:9000`访问HTTPS网站。

另外，当你在NPM中添加新的代理主机时，确保将“Scheme”设置为“HTTP”或“HTTPS”，根据需要将“Forward Hostname/IP”设置为目标服务器的地址，并将“Forward Port”设置为目标服务器的端口。然后，在“Custom Locations”部分，可以根据需要添加自定义重写规则、访问控制等。


### cloudflare tunnel


### 光猫和路由器


桥接/开启IPV6

### alist


### 导航站homepage/tools


### zerorier和tailscale


### vaultwarden


个人云盘

博客

vscode ssh remote

wireguard

minio
rclone webdav 服务,局域网看片真爽  
navidrome 听歌  
  
uptime-kuma 监控(网络延迟 /ssl 证书)  
nocodb 快速生成 restapi  
nsqd 轻量消息队列  
stackedit markdown 编辑器  
gogs 代码托管  
portainer docker 管理  
speedtest 局域网测速  
miniflux Rss  
vaultwarden 开源 bitwarden 密码服务  
dendrite && element-web 局域网 IM  
代理服务器用的 traefik 再也不用手写 nginx 配置了

Homarr  
bitwardenrs  
homeassistant  
nextcloud  
OnlyOffice  
urbackup  
chinesesubfinder  
NocoDB  
Gitea  
RustDeskServer-Relay  
RustDeskServer-Server  
  
照片展示的：  
hexo-blog  
PhotoPrism  
PhotoStructure  
  
自动下片的：  
Plex  
EmbyServer  
qbittorrent  
overseerr  
prowlarr  
radarr  
sonarr  
tautulli
局域网文件传输：windows 用 Raidrive 通过 SFTP 挂载一块 16T 硬盘；外网访问通过端口映射；  
其他服务大部分都是 docker 部署的：  
Docker 容器管理：portainer  
Nginx 反向代理：Nginx Proxy Manager  
相册：PhotoPrism  
浏览器端文件下载：WebDav

Bitwarden - 密码管理器；  
Alist - 网盘；  
Linkding - 跨平台网络书签；  
E5-Renew - E5 自动调用 API 续期；  
Wiznote - 为知笔记私有部署；  
kms - 你懂得；  
Bark - 推送；  
Qiandao - 一个自动签到模板；  
IPSec - 翻回家里；  
Genshinhelper - 一个原神社区的自动签到；  
Rustdesk - 远程控制；  
Synology Photos - 群晖的相册服务；  
Synology Drive - 群晖的私有网盘；  
Synology Calendar - 群晖日历服务，每天定时发送通知到邮箱通知女朋友吃药。

seafile ，文件同步，最近感觉比群晖 Drive 好用  
MT photos ，同步照片，感觉比较轻量，快捷，比 PhotoPrism 占用少

jellyfin媒体中心

https://zhuanlan.zhihu.com/p/595775684

---

> 作者: Kingpo  
> URL: https://hugo.111520.xyz/posts/2023-05-22-home-server/  

