消息断开正在重新连接服务器,为什么Fabric显示“从服务器断开连接”消息将近2分钟?...

每当我发出fab命令时,Fabric显示Disconnecting from username@server... done.,然后显示一个新的命令提示符。在

当使用同时向内部服务器和机架空间云服务器发出的Fabric命令时,存在此问题。下面我已经包括了日志验证在服务器上,我在我的MacBook上没有看到任何日志。在

有什么问题吗?在

服务器的SSH日志验证使用LogLevel VERBOSEApr 21 13:30:52 qsandbox01 sshd[19503]: Accepted password for mrankin from 10.10.100.106 port 52854 ssh2

Apr 21 13:30:52 qsandbox01 sshd[19503]: pam_unix(sshd:session): session opened for user mrankin by (uid=0)

Apr 21 13:30:52 qsandbox01 sudo: mrankin : TTY=unknown ; PWD=/home/mrankin ; USER=root ; COMMAND=/bin/bash -l -c apache2ctl graceful

Apr 21 13:30:53 qsandbox01 sshd[19503]: pam_unix(sshd:session): session closed for user mrankin

服务器配置操作系统:Ubuntu9.10和Ubuntu6.10(用这些操作系统测试了4台服务器)

OpenSSH:Ubuntu包版本1.5.1p1-6ubuntu2

客户端配置操作系统:Mac OS X 10.6.3

织物版本0.9

Vritualenv 1.4.7版

pip版本0.7

简单工厂文件.py用于测试

即使我刚用下面的fabfile运行fab -H server_ip host_type,问题仍然存在。在

^{pr2}$

关于问题起因的思考

我不确定这个问题持续了多长时间,但下面是一些事情,自从我开始注意到使用Fabric的服务器断开连接缓慢以来发生了一些变化。在我用virtualenv1.4.7、virtualenvwrapper 2.1和pip0.7重新创建了我的virtualenv。不确定这是否相关,但这是一个想法,因为我运行我的fabfiles是在一个virtualenv中运行的。

我启用了OS X的防火墙。我禁用了OS X的防火墙,问题仍然存在,因此这不是问题所在。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Socket自动重连,可以在Socket连接失败后,使用一个循环不断尝试重新连接,直到连接成功为止。连接失败可以通过捕获SocketException异常来判断。 判断远端服务器连接状态可以通过发送心跳包来实现。比如可以定时发送一个固定格式的数据包(心跳包)到服务器,如果一段时间内没有收到服务器的回应,则认为连接断开,需要进行重连。在Java中,可以使用ScheduledExecutorService来定时发送心跳包。 下面是一个简单的示例代码: ```java public class SocketClient { private static final int HEARTBEAT_INTERVAL = 5000; // 心跳间隔时间,单位毫秒 private String host = "localhost"; private int port = 8080; private Socket socket; private ScheduledExecutorService executorService; public void connect() { try { socket = new Socket(host, port); executorService = Executors.newSingleThreadScheduledExecutor(); executorService.scheduleAtFixedRate(() -> { try { // 发送心跳包 OutputStream outputStream = socket.getOutputStream(); outputStream.write("ping".getBytes()); outputStream.flush(); // 设置读取超时时间 socket.setSoTimeout(HEARTBEAT_INTERVAL); // 接收服务器的响应 InputStream inputStream = socket.getInputStream(); byte[] buffer = new byte[1024]; int len = inputStream.read(buffer); if (len > 0) { String response = new String(buffer, 0, len); if (!"pong".equals(response)) { // 服务器返回的响应不是预期的值,说明连接断开,需要重连 throw new SocketException("Unexpected response from server"); } } else { // 服务器没有响应,说明连接断开,需要重连 throw new SocketException("No response from server"); } } catch (IOException e) { try { socket.close(); } catch (IOException ex) { ex.printStackTrace(); } socket = null; System.out.println("Connection lost, trying to reconnect..."); } }, 0, HEARTBEAT_INTERVAL, TimeUnit.MILLISECONDS); } catch (IOException e) { System.out.println("Connection failed"); } } public void disconnect() { try { executorService.shutdown(); socket.close(); } catch (IOException e) { e.printStackTrace(); } } public static void main(String[] args) { SocketClient client = new SocketClient(); client.connect(); } } ``` 在上面的代码中,我们使用了一个ScheduledExecutorService来定时发送心跳包,并在心跳包发送失败后捕获SocketException异常来判断连接是否已断开。如果连接断开,则关闭Socket并设置为null,并输出提示信息。在心跳包发送成功后,我们设置了读取超时时间,如果一段时间内没有收到服务器的回应,则也认为连接断开

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值