- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个由TestContainers创建的容器。一个是S3 LocalStack容器,另一个是自定义容器(来自GenericContainer)。它们共享相同的网络(在创建它们时添加到它们)。我在LocalStack容器上有一个网络别名。当启动第二个自定义容器时,我可以运行container.execInContainer()
以使用wget(以及别名和端口)连接到LocalStack容器。这个工作正常,我得到了预期的S3 XML响应(可以在下面的日志中看到)。因此,可以从第二个容器访问第一个容器。
在我的自定义容器中,我有一个Java应用程序,该应用程序使用Netty(通过Vertx)向我的S3容器发出HTTP请求。尽管失败,但带有UnknownHostException。因此,似乎我可以通过命令行上的wget连接到第二个容器,但不能从Java应用程序内部连接。我已经尝试获取LocalStack容器的网络IP并使用它代替网络别名,但这也不起作用。我还尝试过通过自定义容器上的container.withExtraHost
将别名和LocalStack容器IP添加到自定义容器的主机文件中,但这也不起作用。连接到真实的S3端点时(不使用测试testcontainer时),该应用程序可以正常工作。
堆栈跟踪来自Netty(堆栈跟踪中没有对Vertx客户端的任何引用):
[DEBUG] e.u.library.iiif.fester.utils.ContainerUtils:59 | =====================================================>
[DEBUG] e.u.library.iiif.fester.utils.ContainerUtils:61 | Trying to access http://s3.localstack:4572
[DEBUG] e.u.library.iiif.fester.utils.ContainerUtils:65 | <ListAllMyBucketsResult xmlns="http://s3.amazonaws.com/doc/2006-03-01"><Owner><ID>bcaf1ffd86f41161ca5fb16fd081034f</ID><DisplayName>webfile</DisplayName></Owner><Buckets></Buckets></ListAllMyBucketsResult>
[DEBUG] e.u.library.iiif.fester.utils.ContainerUtils:69 | <=====================================================
waiting... http://localhost:34784/bar/manifest
[INFO] FesterFT: | STDOUT: [ERROR] e.u.l.iiif.fester.handlers.GetManifestHandler:88 | failed to resolve 'http://s3.localstack:4572' after 2 queries
[INFO] FesterFT: | STDOUT: java.net.UnknownHostException: failed to resolve 'http://s3.localstack:4572' after 2 queries
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext.finishResolve(DnsResolveContext.java:925)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext.tryToFinishResolve(DnsResolveContext.java:884)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext.query(DnsResolveContext.java:356)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext.onResponse(DnsResolveContext.java:543)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext.access$400(DnsResolveContext.java:64)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsResolveContext$2.operationComplete(DnsResolveContext.java:400)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.notifyListener0(DefaultPromise.java:577)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.notifyListeners0(DefaultPromise.java:570)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.notifyListenersNow(DefaultPromise.java:549)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.notifyListeners(DefaultPromise.java:490)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.setValue0(DefaultPromise.java:615)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.setSuccess0(DefaultPromise.java:604)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.DefaultPromise.trySuccess(DefaultPromise.java:104)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsQueryContext.setSuccess(DnsQueryContext.java:204)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsQueryContext.finish(DnsQueryContext.java:196)
[INFO] FesterFT: | STDOUT: at io.netty.resolver.dns.DnsNameResolver$DnsResponseHandler.channelRead(DnsNameResolver.java:1320)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:374)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:360)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:352)
[INFO] FesterFT: | STDOUT: at io.netty.handler.codec.MessageToMessageDecoder.channelRead(MessageToMessageDecoder.java:102)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:374)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:360)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:352)
[INFO] FesterFT: | STDOUT: at io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1422)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:374)
[INFO] FesterFT: | STDOUT: at io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:360)
[INFO] FesterFT: | STDOUT: at io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:931)
[INFO] FesterFT: | STDOUT: at io.netty.channel.nio.AbstractNioMessageChannel$NioMessageUnsafe.read(AbstractNioMessageChannel.java:93)
[INFO] FesterFT: | STDOUT: at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:700)
[INFO] FesterFT: | STDOUT: at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:635)
[INFO] FesterFT: | STDOUT: at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:552)
[INFO] FesterFT: | STDOUT: at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:514)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.SingleThreadEventExecutor$6.run(SingleThreadEventExecutor.java:1044)
[INFO] FesterFT: | STDOUT: at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
[INFO] FesterFT: | STDOUT: at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
[INFO] FesterFT: | STDOUT: at java.base/java.lang.Thread.run(Thread.java:834)
最佳答案
好的,我做了一些愚蠢的事情,但是我想我会把它保留下来。现在,我正在使用具有默认Web端口以外的端口的S3端点,我相信我只需要以不同的方式初始化HTTP客户端的默认Web主机。可能应该是暗示要解决的问题并非严格是主机名(带有“ http://”和端口号)。无论如何,没有什么比问一个问题来帮助您自己找到解决方案了。我两天都不能接受,但是无论如何应该让我有时间确认。
关于java - 无法从Java程序解析TestContainers网络别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60686551/
上下文:我已经在域根上设置了一个用于 GIS 测试和 dokuwiki 的虚拟机服务器。我想在子域上提供 gis Web 应用程序,这样 dokuwiki url 重命名就不会发生冲突(而且感觉更干净
这个问题在这里已经有了答案: If two variables point to the same object, why doesn't reassigning one variable affe
代码如下: Select Branch.BranchName, Sum(Inventory.OnHand) From Inventory, Branch Inventory.BranchNum = B
我的目标是创建一种“Javascript 库”,如果您可以这样调用它的话。我打算在浏览网页时使用它来操作页面,将其作为 greasemonkey 脚本动态加载。这个想法是将“win”映射到window
是否可以在 javascript 中以某种方式为本地变量分配别名/引用? 我的意思是类似 C 的东西: function foo() { var x = 1; var y = &x; y+
SQLite 别名 您可以暂时把表或列重命名为另一个名字,这被称为别名。使用表别名是指在一个特定的 SQLite 语句中重命名表。重命名是临时的改变,在数据库中实际的表的名称不会改变。 列别名用来
我有以下导入(在同一个 TS 源文件中): import {Vector as sourceVector} from "ol/source"; import {Vector} from "ol/lay
我想弄清楚 this 到底是什么行是在这个 github json 项目的 cmake 文件中, add_library(${NLOHMANN_JSON_TARGET_NAME} INTERFACE)
使用集合时如何创建别名 (AS)。 $collection->addAttributeToSelect('total_qty') 可以这样做: $collection->getSelect()->co
这个问题在这里已经有了答案: Pass an argument to a Git alias command (4 个回答) 去年关闭。 我的团队在不同的分支上工作,通常,我需要快速从分支切换来帮助他
我正在寻找一种向我的 vimrc 添加自定义命令或别名的方法,以便快速切换到 Vim 中的不同目录。我曾经设置过一些东西,但丢失了那个配置。这是用于 Linux 设置。 基本上,我想设置一个别名(如果
我使用 Delphi 和 Firebird 1.5 开发了一个应用程序,其中服务器与应用程序位于同一台计算机上。我现在正在将应用程序部署到另一个站点,其中 Firebird 服务器( super 服务
我创建了一个全新的 React 应用 create-react-app demo 我需要为某些目录/组件创建别名,例如: import { Header } from '@uicomponents'
我正在尝试打印有向图,并且不断更改各种节点属性,例如颜色和形状。有什么方法可以使用一次定义并用于多个节点的变量?理想情况下,我想要这样的东西: digraph g { building_color =
server { listen 80; server_name pwta; root html; location /test/{ alia
我想匹配多个数组,并在匹配时构建另一个数组。该键可以在任意数量的数组中匹配,也可以根本不匹配。 [ [{ 'a': 13 }, { 'b': 62 }, { 'c': 93 }, { 'd': 52
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我有一个这样的查询: select a1.name, b1.info from (select name, id, status from table1 a) as a1 righ
我想给一些 racket 2htdp 函数/宏起别名,这样我就可以为我的 child 将它们翻译成另一种语言。 我可以简单地用define给函数起别名。我在使用 big-bang 结构时遇到了麻烦;例
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我是一名优秀的程序员,十分优秀!