我正在构建某种代理.
当我在机架应用程序中调用某个URL时,我会将该请求转发给其他URL.
我转发的请求是带有文件和一些参数的POST.
我想添加更多参数.
但文件可能很大.所以我发送它Net::HTTP#body_stream代替Net::HTTP#body.
我得到了我的请求作为Rack::Request对象,我用它创建我的Net :: HTTP对象.
req = Net::HTTP::Post.new(request.path_info)
req.body_stream = request.body
req.content_type = request.content_type
req.content_length = request.content_length
http = Net::HTTP.new(@host, @port)
res = http.request(req)
Run Code Online (Sandbox Code Playgroud)
我已经尝试了几种方法来添加代理的参数.但似乎Net :: HTTP中的任何内容都不允许向body_stream请求添加参数,只允许向body_stream请求添加参数.
是否有更简单的方法来代理这样的机架请求?或者将我的参数添加到我的请求的干净方法?
我创建了一个线程池并为它提供了50个连接到服务器的任务.所以一旦完成连接,发送一些数据,然后断开连接.它的读取超时设置为5秒(当然是5000长).我甚至将线程池设置为最大大小为1.然后在linux上启动它,然后运行htop(更好的top版本)来检查CPU使用率.我一直在100%看到我的一个核心(2核心机器).我使用hprof(-agentlib:hprof=cpu=samples,interval=20,depth=3)对此进行了分析,并将socket.connect()置于99%.
这是我觉得奇怪的,是不是阻止IO阻止(因此等待)?我的JDK是(来自java -version):
OpenJDK Runtime Environment (IcedTea6 1.6.1) (6b16-1.6.1-3ubuntu3)
OpenJDK Server VM (build 14.0-b16, mixed mode)
Update1:Sun的JVM也出现同样的问题:
java -version
Java version "1.6.0_20"
Run Code Online (Sandbox Code Playgroud)
Update2:这是由于本地的doConnect方法.任何人都知道如何查看此本机/ C代码的来源?
Update3:我登录windows编写代码并测试它.它工作正常,没有CPU资源被冲洗.我重新登录到linux,现在问题仍然在这里,但不是像整个CPU核心那样只需1次连接就可以了.这是代码:
import java.io.IOException;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Vector;
import java.util.concurrent.Callable;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class SocketTest {
public static void main(String[] args) {
new SocketTest();
}
public SocketTest() {
ThreadPoolExecutor tpe = (ThreadPoolExecutor) Executors.newFixedThreadPool(40);
Vector<Callable<Object>> tasks = new Vector<Callable<Object>>();
for (int …Run Code Online (Sandbox Code Playgroud) 我们编写了所有单元测试,以便在HSQL中创建和填充表.我希望使用它的开发人员能够通过编写查询来编写针对此HSQL DB(1)的查询,他们可以更好地理解数据模型,而那些不熟悉SQL的人可以在编写运行时语句之前使用数据和2 )因为他们无法访问测试DB /安全性原因).有没有办法坚持测试数据的结果,以便可以使用SQL客户端进行检查和分析?
现在我通过将数据源切换到不同的数据库(比如DB2/mysql,然后连接到我的机器上的数据库,这样我可以使用持久数据)来操纵它,但是如果HSQL支持持久化,那么对我来说会更容易这比向每个新开发者解释如何做到这一点.
为了清楚起见,我需要一个SQL客户端来与持久数据进行交互,因此调试和检查内存将不会很干净.这与初始开发有关,而与调试/维护/测试无关.
我想在 HSQL 中编写一个简单的函数,以便它向后兼容 DB2 函数。从理论上讲,我应该能够在 java 中编写一个自定义函数并将其挂钩到 HSQL 中。是否有任何说明/文档?
我正在寻找比Wireshark更好的工具.Wireshark的问题在于它没有格式化数据层(这是我正在查看的唯一部分),因为我可以比较不同的数据包并尝试理解第三方编码(这是封闭源代码).
具体来说,什么是查看数据的好工具,而不是TCP/UDP头信息?特别是,一种格式化数据以进行比较的工具.
非常具体:我想要一个用十六进制比较多个(不仅仅是2个)文件的程序.
那么我怎样才能编写漂亮的代码,例如:
'im a string meing!'.pop
Run Code Online (Sandbox Code Playgroud)
注意:str.chop答案不够
如何从thead返回变量(我也有线程处理).在这种情况下,静态变量不起作用.
更新:这是一个转折点,如何在不必阻塞并等待结果的情况下执行此操作?我需要能够轮询创建的线程并在它挂起太长时间(例如> 1分钟)时将其终止,然后如果生成的线程花费的时间太长则继续在主线程中.
任何人都知道一个库来处理从命令行传递的解析争论(IE:args []在public static main中).
是否存在一个库甚至是标准API调用,它允许我区分两个字符串并将diff字符数作为一个int?我不介意其他功能,只要我能获得更多程序化的差异结果(例如int)而不是只输出整个人类可读差异的东西.
java ×5
ruby ×3
hsqldb ×2
comparison ×1
db2 ×1
encoding ×1
encryption ×1
http ×1
persistence ×1
profiling ×1
proxy ×1
rack ×1
regex ×1
unit-testing ×1