A separação de papéis é um conceito importante a ser aplicado aqui. Se você tiver um compartilhamento de rede que esteja hospedando documentos do usuário, poderá aplicar determinadas abordagens de backup, disponibilidade e segurança a esse compartilhamento, dependendo de como os tipos de arquivos que ele hospeda e em que horas durante o dia os usuários precisarão acessá-lo. Você também sabe que, se precisar levar o servidor que o mantém offline durante o dia para manutenção, basta notificar seus usuários para fechar todos os documentos abertos enquanto durar.
Agora, considere que você adicionou algum software a esse compartilhamento de arquivos, que os usuários executam diretamente do compartilhamento. De repente, você está fazendo backup dos dados do programa juntamente com os dados do arquivo do usuário. Agora você tem complicações extras se precisar desativar o servidor para manutenção (o que acontece se o servidor ficar offline enquanto o aplicativo estiver em execução?). Este é um exemplo de muitos, onde suas necessidades de administração do programa e suas necessidades de administração do restante do compartilhamento de arquivos podem gerar conflitos diferentes. Você nem sempre pode prever esses tipos de conflito antes do tempo, mas é uma daquelas coisas que, na maioria das vezes, leva a dores de cabeça administrativas.
Portanto, é por isso que você deve separar funções e papéis sempre que possível, se suas características forem diferentes ou se houver probabilidade de divergir no futuro. É mais elegante e suportável, com surpresas menos desagradáveis.
Para um exemplo do mundo real: em uma empresa em que trabalhei anteriormente, tínhamos um arquivo geral & servidor de impressão, e nós rodamos o Lotus Notes / Domino para o groupware. A instalação do Lotus Notes para todos os usuários foi hospedada em um compartilhamento de arquivos no arquivo & servidor de impressão e execute diretamente a partir dele. Acredito que isso tenha sido feito originalmente com a intenção de poder atualizar o Notes uma vez e ter todos os clientes atualizados automaticamente. Talvez em um momento isso funcionou.
A realidade da situação era que um único sinal de rede, talvez uma vez por semana, acionaria todos os usuários do Notes por e-mail e geraria um arquivo de bloqueio no compartilhamento que precisaria ser excluído manualmente por um administrador. As pessoas realmente notam quando "o e-mail está inativo". O software carregou lentamente também, especialmente no início da manhã, quando você tinha 150 usuários simultaneamente tentando carregar um único .exe. Para completar, as atualizações do Notes ainda exigiam visitar cada PC. O benefício líquido acabou sendo zero ou negativo, embora eu ache que parecia uma ótima maneira de economizar tempo, originalmente.
Quanto ao seu problema específico ... o que você está realmente tentando fazer ao fazer isso? Se o seu .exe é um que está sendo criado internamente e atualizado com freqüência, e seus desenvolvedores só querem uma maneira mais rápida de publicar suas atualizações .. tenha cuidado. Trocar um EXE enquanto os usuários ainda o acessam pode causar dores de cabeça e inconsistências de dados. Além disso, o carregamento de aplicativos em um servidor de terminal deve ser feito de uma maneira específica, usando o comando set user / install no TS antes de instalar, depois definir user / execute quando instalado e pronto para ser executado. Ignorar esse processo pode levar a resultados imprevisíveis.