unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
From: Visuwesh <visuweshm@gmail.com>
To: Robert Pluim <rpluim@gmail.com>
Cc: Michael Albinus <michael.albinus@gmx.de>,  help-gnu-emacs@gnu.org
Subject: Re: Tramp timeout for currently unreachable connections?
Date: Thu, 12 Sep 2024 22:44:18 +0530	[thread overview]
Message-ID: <875xr06bh1.fsf@gmail.com> (raw)
In-Reply-To: <87plp8lwo2.fsf@gmail.com> (Robert Pluim's message of "Thu, 12 Sep 2024 17:27:25 +0200")

[வியாழன் செப்டம்பர் 12, 2024] Robert Pluim wrote:

>>>>>> On Thu, 12 Sep 2024 16:47:39 +0200, Michael Albinus <michael.albinus@gmx.de> said:
>
>     Michael> Visuwesh <visuweshm@gmail.com> writes:
>     >> Hello all,
>
>     Michael> Hi Visuwesh,
>
>     >> I know that non-essential=t prevents Tramp from establishing new
>     >> connections but is there a way to make Tramp use a very short timeout
>     >> when trying to connect to a previously established connection that is
>     >> now unreachable?  What I mean is: if I am connected to a remote host via
>     >> a ssh connection /ssh:user@remote: and my internet connection goes down,
>     >> I do not want Tramp trying to fetch remote resources forever.
>
>     Michael> Use 'M-x tramp-cleanup-connection'. Play with user option `tramp-connection-timeout'.
>
> Idle thought: would enabling 'ServerAliveInterval' help at all here?
> (my Tramp connections travel from one side of my desk to the other, so
> I canʼt tell ☺️)

I have it set to 100 but it doesn't help much.  I don't think I am
describing my problem well.  I have the following function

    (defun vz/stb--buffer-annotation (buffer)
      (let ((case-fold-search nil))
        (pcase (buffer-name buffer)
          ((rx bos (1+ anychar) "<" (+ (not ">")) ">")
              (let ((non-essential t))
                (vz/with-when (buffer-file-name buffer)
                  (abbreviate-file-name it)))
              ;; (let ((non-essential t))
              ;;   (vz/with-when (vz/file-visiting-buffer-p buffer)
              ;;     (abbreviate-file-name it)))
              )
          ((rx bos "*" (or "shell" "ssh") (? "-"))
              (let ((non-essential t))
                (abbreviate-file-name (buffer-local-value 'default-directory buffer))))
          (_ (vz/buffer-annotation buffer)))))

that returns an annotation string for my C-x b replacement.  If Tramp
already knows the connection is dead, non-essential=t signals Tramp to
not to bother to open a new connection.  I would like a similar variable
to make Tramp give up after a few seconds if it gets no reply from the
remote server in the case of connections that are no longer reachable.



  reply	other threads:[~2024-09-12 17:14 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-09-12 14:32 Tramp timeout for currently unreachable connections? Visuwesh
2024-09-12 14:47 ` Michael Albinus
2024-09-12 15:24   ` Visuwesh
2024-09-12 17:27     ` Michael Albinus
2024-09-12 15:27   ` Robert Pluim
2024-09-12 17:14     ` Visuwesh [this message]
2024-09-12 17:37       ` Michael Albinus
2024-09-12 17:45         ` Visuwesh
2024-09-12 17:22     ` Michael Albinus
2024-09-12 17:35       ` Visuwesh

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=875xr06bh1.fsf@gmail.com \
    --to=visuweshm@gmail.com \
    --cc=help-gnu-emacs@gnu.org \
    --cc=michael.albinus@gmx.de \
    --cc=rpluim@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).