O SCP bloqueia o arquivo que está transferindo?

8

Tenha uma situação em que tenhamos um log de aplicativo em um servidor AIX. O log está sendo gravado continuamente a partir do aplicativo e temos usuários no Windows que desejam visualizar o arquivo. O que eles estão fazendo é usar o WinSCP para transferir o arquivo para a área de trabalho e abri-lo usando um editor de texto.

O que eu acho que pode estar acontecendo é scp está bloqueando o arquivo para a duração da transferência, e o aplicativo deixa de ser capaz de gravar no arquivo. A razão pela qual eu acredito que este é o arquivo de log irá parar de crescer em pontos aleatórios durante o dia.

É isso que talvez está acontecendo?

    
por ThaDon 05.03.2010 / 17:05

2 respostas

8

Por que você não tenta isso? Inicie scp'ing um arquivo grande, em seguida, execute lsof /path/to/file no servidor AIX e veja o que a coluna FD diz.

Na página do manual lsof:

   FD         is the File Descriptor number of the file or:
                   cwd  current working directory;
                   Lnn  library references (AIX);
                   err  FD information error (see NAME column);
                   jld  jail directory (FreeBSD);
                   ltx  shared library text (code and data);
                   Mxx  hex memory-mapped type number xx.
                   m86  DOS Merge mapped file;
                   mem  memory-mapped file;
                   mmap memory-mapped device;
                   pd   parent directory;
                   rtd  root directory;
                   tr   kernel trace file (OpenBSD);
                   txt  program text (code and data);
                   v86  VP/ix mapped file;
              FD is followed by one of these characters, describing the mode under which the file is open:
                   r for read access;
                   w for write access;
                   u for read and write access;
                   space if mode unknown and no lock
                        character follows;
                   '-' if mode unknown and lock
                        character follows.
              The mode character is followed by one of these lock characters, describing the type of lock applied to the file:
                   N for a Solaris NFS lock of unknown type;
                   r for read lock on part of the file;
                   R for a read lock on the entire file;
                   w for a write lock on part of the file;
                   W for a write lock on the entire file;
                   u for a read and write lock of any length;
                   U for a lock of unknown type;
                   x for an SCO OpenServer Xenix lock on part of the file;
                   X for an SCO OpenServer Xenix lock on the entire file;
                   space if there is no lock.
              See the LOCKS section for more information on the lock information character.
              The FD column contents constitutes a single field for parsing in post-processing scripts.

Se você fizer isso, pelo menos no Linux, você verá que a coluna FD é "3r", o que significa que tem algum tipo de bloqueio de leitura, mas não tenho certeza do que significam os 3 na frente.

    
por 05.03.2010 / 17:33
1

A maioria dos programas Unix não usa bloqueio ou quando eles o usam, não é obrigatório, então Eu duvido que o bloqueio esteja impedindo seu log de crescer. É mais provável que a transferência do SCP esteja diminuindo a gravação do log.

    
por 05.03.2010 / 17:28

Tags