草庐IT

linux - Docker-Machine 命令超时 TLS 握手,但 Dock Swarmer 工作正常

coder 2023-05-28 原文

我现在在使用 docker-machine 时遇到了问题,之前它工作正常,因为它在 Digital Ocean 中运行 docker 的机器上的命令超时。

我可以通过 SSH 连接到机器并且 Docker Swarm 和我们的系统似乎在机器上运行正常(docker node 命令似乎工作正常,例如 docker node ls)。

问题似乎出在 docker 机器上。我过去有类似的事情,可以通过增加超时时间来解决,但现在没有帮助。

错误似乎是由 net/http HTLS 握手超时引起的,输出来自:

docker-machine ls --timeout 30

显示:

NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
default - virtualbox Stopped Unknown 
dev-m0 - digitalocean Error Unknown Get https://api.digitalocean.com/v2/droplets/42100174: net/http: TLS handshake timeout
dev-w1 - digitalocean Error Unknown Get https://api.digitalocean.com/v2/droplets/42115817: net/http: TLS handshake timeout
... repeated for all managers and workers.

我在我的 Mac 上运行 Docker CE 版本 17.05.0-ce-rc1-mac8 Edge,在 Digital Ocean 上的 Linux 机器上运行 17.03.0-ce(这似乎是它们可用的最新版本)。我已经在 Mac 上的 Edge 和 Stable 之间进行了切换,以查看是否是导致问题的原因,但没有帮助。

我已重新启动机器(停止和启动)。我没有重新生成证书,因为我可以毫无问题地使用 docker-machine ssh dev-m1 SSH 进入机器,所以证书对我来说似乎不是问题。我不想在本地运行任何容器。

过去一切正常,但最近停止了。

非常感谢任何帮助或建议。

谢谢, 阿什利。

最佳答案

假设

我的猜测是您的 docker 客户端 VM 内的时间与 digital ocean 服务器不同步,这导致 TLS 握手失败。尝试通过在您的 Mac 上运行此命令来同步时钟:

$ docker run --rm --privileged alpine hwclock -s

该命令将使用 hwclock 将 VM 内的时钟设置为您的 mac 上的时钟。命令。它需要特权访问,因为容器需要从主机硬件读取时间。

说明

您 Mac 上的 docker 客户端在瘦虚拟机中运行。 VM 中时钟的计时可能与您的 Mac 上的时间和外部世界的时间不同步,尤其是当您在允许 sleep 的笔记本电脑上使用 docker 时。该时间不同步可能会导致任何操作出现问题,这些操作需要知道事件发生在 docker 服务器(VM 内部)上的时间,并将其与 docker 服务器外部发生的事件进行比较。我怀疑与 digital ocean 的 TLS 握手就是这样一种操作。

我遇到了 docker 事件未按预期运行的问题。在 docker 存储库的问题部分 (moby/moby#25579) 中进行了长时间讨论后,我们发现时钟不同步是原因。

关于linux - Docker-Machine 命令超时 TLS 握手,但 Dock Swarmer 工作正常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43772859/

有关linux - Docker-Machine 命令超时 TLS 握手,但 Dock Swarmer 工作正常的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  4. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  5. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  6. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  7. ruby - 简单获取法拉第超时 - 2

    有没有办法在这个简单的get方法中添加超时选项?我正在使用法拉第3.3。Faraday.get(url)四处寻找,我只能先发起连接后应用超时选项,然后应用超时选项。或者有什么简单的方法?这就是我现在正在做的:conn=Faraday.newresponse=conn.getdo|req|req.urlurlreq.options.timeout=2#2secondsend 最佳答案 试试这个:conn=Faraday.newdo|conn|conn.options.timeout=20endresponse=conn.get(url

  8. ruby - JetBrains RubyMine 3.2.4 调试器不工作 - 2

    使用Ruby1.9.2运行IDE提示说需要gemruby​​-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall

  9. Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting - 2

    1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里

  10. ruby - `rescue $!` 是如何工作的? - 2

    我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的

随机推荐