分类 默认分类 下的文章

https://github.com/NewFuture/DDNS

git clone https://github.com/NewFuture/DDNS
cd DDNS
./run.py #运行一次 生成config.json配置文件
vi config.json #修改 id 域名 token
./task.sh

然后运行命令crontab -e ,将脚本加入定时运行中

crontab -e

末尾添加一行(复制后到黑色窗口直接鼠标右键就行)

*/5 * * * * /root/DDNS/task.sh

第一步
宝塔5.9版本
wget -O install.sh http://download.bt.cn/install/install-ubuntu.sh && bash install.sh

安装完成后记着账户和密码

ip用本地ip上个视频讲过然后安装支持库
wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.13.1.tar.gz

接着解压
tar zxvf libiconv-1.13.1.tar.gz

然后输入进入文件夹
cd libiconv-1.13.1

接着输入配置libiconv
./configure -prefix=/usr/local

这个是如果出错输入!!!!!!!!!!!!!!!!!!!!
./configure -prefix=/usr/local --build arm-pc-linux 如果失败指定arm机型

随后编译安装编译安装
make

make install

接着输入创建一个文件链接到Libiconv库
ln -s /usr/local/lib/libiconv.so /usr/lib

ln -s /usr/local/lib/libiconv.so.2 /usr/lib/libiconv.so.2

以上的全部复制鼠标右键粘贴就行
如果安装Apache登录宝塔面板下重新安装Apache 2.4 mysql5.5 php7.x(不要安装5.x)不用下面的

如果要安装nginx请接着下面不要安装Apache
输入返回root目录
cd /root
输入下载提供的nginx.sh
wget https://www.feiji.work/n1/bt/nginx.sh
再输入直接安装
sh nginx.sh install
随后登录宝塔面板下重新安装nginx1.14 mysql5.5 php7.x

一、下载
花生壳下载页面,找到树莓派5.0并下载。将安装包下载到本地电脑后,可以通过WinSCP等工具将安装包传输到树莓派中。

二、安装
注意:安装花生壳前,需输入命令:sudo -s 切换到管理员权限。
1、使用cd命令进入安装包所在的文件路径,输入安装命令:dpkg -i 安装包名称。回车,等待安装完成。
如: dpkg -i phtunnel_5_0_rapi_aarch64.deb

安装成功后,将显示花生壳的SN码、默认密码(admin)及远程管理地址http://b.oray.com
三、操作功能
1、输入命令:phddns回车,可以看到扩展功能。phddns start(启动)| status(状态)| stop(停止)|restart(重启)| reset(重置)|enable(开机自启动)|disable(关闭开机自启动)|version(版本)
日志文件存放路径:/var/log/phddns

Linux最简单的安装方法:

curl -s https://install.zerotier.com/ | sudo bash

无任何报错显示:

*** Waiting for identity generation...

* Success! You are ZeroTier address [ d56f99571f ].
把zerotier服务复制到系统服务目录并激活

systemctl daemon-reload
systemctl start zerotier-one
systemctl enable zerotier-one //开机启动

察看状态:

zerotier-cli info

演示:

[root@instance-1 ~]# zerotier-cli info
200 info d56f99571f 1.2.12 ONLINE
最后加入zerotier网络:

zerotier-cli join  //你的Zeroiter网络ID

彻底卸载Zerotier-one
通过dpkg删除zerotier-one服务

sudo dpkg -P zerotier-one

删除zerotier-one文件夹,该文件夹存储了address地址,删除后再次安装会获得新的address地址

sudo rm -rf /var/lib/zerotier-one/

服务**

sudo dpkg -P zerotier-one

删除zerotier-one文件夹,该文件夹存储了address地址,删除后再次安装会获得新的address地址

sudo rm -rf /var/lib/zerotier-one/

由于我的N1在Armbian上安装了宝塔面板,并架设了NextCloud(性能低下)所以还是装了Cloudreve,利用IPv6实现外网的便捷访问。Docker使用仅仅是为了DDNS还是很浪费资源的。所以就使用宝塔的计划任务来实现吧!

01-1024x618.jpg
其中的更新时间建议每天执行,当然也可以更频繁些,例如N小时一次。

aliddnsipv6_ak="**********"
aliddnsipv6_sk="************************"
aliddnsipv6_name1='www'
aliddnsipv6_domain='xxx.com'
aliddnsipv6_ttl="600"

if [ "$aliddnsipv6_name1" = "@" ]
then
  aliddnsipv6_name=$aliddnsipv6_domain
else
  aliddnsipv6_name=$aliddnsipv6_name1.$aliddnsipv6_domain
fi

now=`date`

die () {
    echo $1
}

ipv6s=`ip addr show eth0 | grep "inet6.*global" | awk '{print $2}' | awk -F"/" '{print $1}'` || die "$ipv6"

for ipv6 in $ipv6s
do
  #ipv6 = $ipv6
  break
done

echo $ipv6

current_ipv6=`nslookup -query=AAAA $aliddnsipv6_name 2>&1`
#echo $current_ipv6

current_ipv6=`echo "$current_ipv6" | grep 'Address: ' | tail -n1 | awk '{print $NF}'`
echo $current_ipv6

if [ "$?" -eq "0" ]
then
    current_ipv6=`echo "$current_ipv6" | grep 'Address: ' | tail -n1 | awk '{print $NF}'`
    echo $current_ipv6

    if [ "$ipv6" = "$current_ipv6" ]
    then
        echo "skipping"
    fi
# fix when A record removed by manual dns is always update error
else
    unset aliddnsipv6_record_id
fi


timestamp=`date -u "+%Y-%m-%dT%H%%3A%M%%3A%SZ"`


urlencode() {
    # urlencode 
    out=""
    while read -n1 c
    do
        case $c in
            [a-zA-Z0-9._-]) out="$out$c" ;;
            *) out="$out`printf '%%%02X' "'$c"`" ;;
        esac
    done
    echo -n $out
}

enc() {
    echo -n "$1" | urlencode
}

send_request() {
    local args="AccessKeyId=$aliddnsipv6_ak&Action=$1&Format=json&$2&Version=2015-01-09"
    local hash=$(echo -n "GET&%2F&$(enc "$args")" | openssl dgst -sha1 -hmac "$aliddnsipv6_sk&" -binary | openssl base64)
    curl -s "http://alidns.aliyuncs.com/?$args&Signature=$(enc "$hash")"
}

get_recordid() {
    grep -Eo '"RecordId":"[0-9]+"' | cut -d':' -f2 | tr -d '"'
}

query_recordid() {
    send_request "DescribeSubDomainRecords" "SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&SubDomain=$aliddnsipv6_name&Timestamp=$timestamp&Type=AAAA"
}

update_record() {
    send_request "UpdateDomainRecord" "RR=$aliddnsipv6_name1&RecordId=$1&SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&TTL=$aliddnsipv6_ttl&Timestamp=$timestamp&Type=AAAA&Value=$(enc $ipv6)"
}

add_record() {
    send_request "AddDomainRecord&DomainName=$aliddnsipv6_domain" "RR=$aliddnsipv6_name1&SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&TTL=$aliddnsipv6_ttl&Timestamp=$timestamp&Type=AAAA&Value=$(enc $ipv6)"
}

#add support */%2A and @/%40 record


if [ "$aliddnsipv6_record_id" = "" ]
then
    aliddnsipv6_record_id=`query_recordid | get_recordid`
    #echo '-----------------' $aliddnsipv6_record_id
fi
if [ "$aliddnsipv6_record_id" = "" ]
then
    aliddnsipv6_record_id=`add_record | get_recordid`
    echo "added record $aliddnsipv6_record_id"
else
    update_record $aliddnsipv6_record_id
    echo "updated record $aliddnsipv6_record_id"
fi

参数说明:

AccessKey ID:
aliddnsipv6_ak="**********"

Access Key Secret
aliddnsipv6_sk="************************"

子域名:

aliddnsipv6_name1='www'

域名:

aliddnsipv6_domain='xxx.com'

TTL:

aliddnsipv6_ttl="600"

show:etho 是指定网卡获取IPv6,可通过ifconfig命令来获取网卡名
ipv6s=ip addr show eth0 | grep "inet6.*global" | awk '{print $2}' | awk -F"/" '{print $1}' || die "$ipv6"
配置好了之后保存,可以尝试执行一次看是否已经生效,如果正常就OK啦!是不是很简单?