Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/real-zony/aliddnsnet
使用 C# + .NET Core 开发的开源 DDNS 工具,基于阿里云的 DNS API 接口。
https://github.com/real-zony/aliddnsnet
alicloud csharp ddns ddns-client dotnet-core dotnetcore linux synology-nas
Last synced: 5 days ago
JSON representation
使用 C# + .NET Core 开发的开源 DDNS 工具,基于阿里云的 DNS API 接口。
- Host: GitHub
- URL: https://github.com/real-zony/aliddnsnet
- Owner: real-zony
- License: mit
- Created: 2018-07-21T16:56:34.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-07-09T01:26:25.000Z (6 months ago)
- Last Synced: 2024-12-09T20:41:39.284Z (13 days ago)
- Topics: alicloud, csharp, ddns, ddns-client, dotnet-core, dotnetcore, linux, synology-nas
- Language: C#
- Homepage:
- Size: 905 KB
- Stars: 118
- Watchers: 6
- Forks: 39
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## 0.简要介绍
AliCloudDynamicDNS 是基于 .NET Core 开发的动态 DNS 解析工具,借助于阿里云的 DNS API 来实现域名与动态 IP 的绑定功能。这样你随时就可以通过域名来访问你的设备,而不需要担心 IP 变动的问题。
## 1.使用说明
使用本工具的时候,请详细阅读使用说明。
### 1.1 配置说明
通过更改 ```settings.json.example``` 的内容来实现 DDNS 更新,其文件内部各个选项的说明如下:
```json
{
// 阿里云的 Access Id。
"AccessId": "AccessId",
// 阿里云的 Access Key。
"AccessKey": "AccessKey",
// 主域名。
"MainDomain": "example.com",
// 公网 IP 获取服务器地址。
"PublicIpServer": "https://api.myzony.com/get-ip",
// 需要批量变更的子域名记录集合。
"SubDomains": [
{
// 子域名记录类型。
"Type": "A",
// 子域名记录前缀。
"SubDomain": "sub1",
// TTL 时间。
"Interval": 600
},
{
"Type": "A",
"SubDomain": "sub2",
"Interval": 600
}
]
}
```其中 ```Access Id``` 与 ```Access Key``` 可以登录阿里云之后在右上角可以得到。
### 1.2 命令参数说明
在运行程序的时候,请建立一个新的 ```settings.json``` 文件,在里面填入配置内容,然后执行以下命令:
```shell
./AliCloudDynamicDNS
```效果图:
![1203160-20180722111356778-841949657.png](./READMEPIC/Snipaste_2019-12-12_17-36-21.png)当然如果你有其他的配置文件也可以通过指定 ```-f``` 参数来制定配置文件路径。例如:
```shell
./AliCloudDynamicDNS -f ./settings.json
```![](./READMEPIC/Snipaste_2019-12-12_17-38-09.png)
如果你需要启动自动周期检测的话,请通过 `-i` 参数指定执行周期,单位是秒。
```shell
./AliCloudDynamicDNS -f ./settings.json -i 3600
```![](./READMEPIC/Snipaste_2019-12-12_17-38-53.png)
> **注意:**
>
> **当你通过 -i 指定了周期之后,请在最末尾使用 & 符号,使应用程序在后台运行。使用群晖的同学,就不要指定 -i 参数了。**## 2. 如何安装
### 2.1 基于 Docker 运行
本程序已经打包了 x64 的 Linux Docker 镜像,基于 X86 的机器可以直接执行以下命令拉取并快速执行命令。
```
docker run -d -ti -v <你的配置文件路径(完整)>:/app/settings.json --name=aliyun-ddns myzony/ali-cloud-dynamic-dns:latest
```下面是一个 Docker-Compose 的示例:
*docker-compose.yaml*
```yaml
version: '3'
services:
ddns:
container_name: aliyun-ddns
image: myzony/ali-cloud-dynamic-dns:latest
volume:
- <你的配置文件路径(完整)>:/app/settings.json
restart: always
```### 2.2 基于群晖 Docker
TODO
### 2.3 基于任务计划
**以下方法不再建议使用,优先考虑 Docker 模式**
~~群晖使用本工具的话推荐下载 [Release](https://github.com/GameBelial/AliDDNSNet/releases) 页面的 Linux 版本压缩包,将其通过 WinSCP 传输到群晖 NAS 上面,然后解压之后即可。~~
~~例如我这里将其解压到了 ```/var/services/homes/myzony/newDns/``` 这个目录之下,同时我们也将建立一个新的 `settings.json` 文件,并按照下方配置说明进行设置。~~
~~最后我们来到群晖的 DSM 管理面,打开 **控制面板 -> 任务计划**,添加一个新的任务,例如下图:~~
![群晖设置图1](./READMEPIC/Snipaste_2019-12-12_17-42-28.png)
![群晖设置图2](./READMEPIC/Snipaste_2019-12-12_17-43-54.png)
![](./READMEPIC/Snipaste_2019-12-12_17-46-01.png)
## 3.下载地址
程序打包了 Linux_x64、Linux_arm64、Windows_x64 的二进制可执行文件,你可以直接下载对应的压缩包解压到你的路由器或者 NAS 里面进行运行。
**[下载地址在这儿](https://github.com/GameBelial/AliDDNSNet/releases)**