本文参考:
1、《使用Zerotier实现免费内网穿透》https://coffeemilk.blog.csdn.net/article/details/119360712
2、《解决群晖 docker 安装 zerotier 后重启失效问题》https://post.smzdm.com/p/a4do0e6x/
问题:
最近没事,折腾之前买的一个群晖NAS DS918+,使用zerotier部署可在外网访问的个人局域网。zerotier 在docker部署完成后,刚建立的时候可以正常连通。但是使用中发现一个问题,zerotier重启后无法访问,表现为zerotier管理页面显示群晖docker 状态online,docker里通过zerotier-cli listnetworks 查询也可以看到分配的ip,状态ok,但是外网电脑无法访问NAS的IP地址。
解决方案
问题根因是因为缺少一条关键的路由,需要通过命令增加路由:
route add -net 192.168.XXX.0/24 dev ztwdjclgcv
其中 192.168.XXX.0/24 需要修改为zerotier网站上设置的本局域网的IP地址:

ztwdjclgcv则需要修改为启动docker后的设备序号,按如下方法查询:
启动docker后,在telnet终端上输入命令 ip a, 出来的最后一条信息序号后的字符串即为设备号:

输入该命令,没有出现异常,那么就可以了。
通过在PC上ping 服务器地址,试试是否可以ping通。
以上只是手动解决了该问题。每次启动NAS后还要手动执行挺麻烦的。我们可以将命令编辑为脚本,并通过群晖的计划任务来运行脚本。
该脚本在NAS启动的时候触发启动,并每60秒检测一次docker是否启动,在docker启动后,自动增加路由后退出。
1、制作脚本:
脚本文本如下,注意以下绿色部分的设备号,和橙色部分的IP,需要根据实际进行修改。
| #!/bin/bash echo `date -d today +"%Y-%m-%d %T.%N"` " Add route start......" #判断docker是否启动,标志是通过ip a命令查看特有设备标志zt7abcd2sa,各个机器不同。 dkstart=`ip a |grep zt7abcd2sa` while [$dkstart -eq ""] do #如果不存在,那么就等待60秒后再判断。 echo `date -d today +"%Y-%m-%d %T.%N"` " Docker is not exist, waiting 60s." sleep 60 dkstart=`ip a |grep zt7abcd2sa` done #循环出来,说明docker已经启动。判断路由是否存在。 resultstr=`route -n |grep zt7abcd2sa` blankstr="" if [$resultstr -eq $blankstr] then echo `date -d today +"%Y-%m-%d %T.%N"` " Route is not exist, we will add route!" #增加路由命令 route add -net 10.147.88.0/24 dev zt7abcd2sa sleep 3 #等待3秒后判断是否增加成功 resultstr=`route -n |grep zt7abcd2sa` if [$resultstr -eq $blankstr] then echo `date -d today +"%Y-%m-%d %T.%N"` " Add route failed!" else echo `date -d today +"%Y-%m-%d %T.%N"` " Add route success! The route info is: "$resultstr fi else echo `date -d today +"%Y-%m-%d %T.%N"` " Route is exist. The route info is: "$resultstr fi echo `date -d today +"%Y-%m-%d %T.%N"` " Add route end!" |
可以通过telnet将登录NAS服务器,将脚本放到 /usr/local/路径下。
通过vim命令增加addroute.sh脚本

进入vim编辑界面后,按“i”键,然后拷贝以上脚本,然后按鼠标右键,自动粘贴脚本到编辑器中,然后按“ESC”键,再按“:wq!”保存脚本。

生成的脚本需要增加执行权限,通过命令修改:chmod +x addroute.sh ,修改后脚本为绿色。

2、在docker创建zerotier实例时,主要要将“启用自动重新启动”选上。

3、增加计划任务:
控制面板->任务计划->新增->触发的任务->用户定义的脚本。


用户定义脚本中,加入之前编辑的脚本,并将打印日志写入日志文件。
bash /usr/local/addroute.sh >>/usr/local/addroute.log

并在任务计划中勾选“已启动->保存”

4、测试:
可在控制面板,计划任务中,选中刚才自定义的计划任务,点“运行”,运行一次脚本,并在telnet后台查看运行日志是否正常运行。日志存放在/usr/local/目录下。
查看命令:tail addroute.log
在PC电脑上ping NAS服务器 是否能够ping通。
如果可以正常运行,可以重启NAS,等几分钟后,再次ping NAS服务器IP地址,能够ping通说明自启动功能生效。
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
我有一个奇怪的问题:我在rvm上安装了rubyonrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(
设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server