Ativando um servidor de depuração
Há duas maneiras de ativar o servidor de depuração. Ele pode ser ativado quando o depurador é iniciado usando a opção de linha de comando -server em uma janela elevada do Prompt de Comando (Executar como Administrador). Ele também pode ser ativado depois que o depurador está em execução. Inicie o depurador com privilégios elevados (Executar como administrador) e digite o comando .server.
Observação Você pode ativar um servidor de depuração sem ter privilégios elevados, e os clientes de depuração poderão se conectar ao servidor. No entanto, os clientes não poderão descobrir um servidor de depuração, a menos que ele tenha sido ativado com privilégios elevados. Para obter informações sobre como descobrir servidores de depuração, consulte Procurando servidores de depuração.
Importante
Há considerações de segurança adicionais importantes ao usar a depuração remota, para obter mais informações, incluindo informações sobre como habilitar o modo seguro, consulte Segurança durante a depuração remota e Considerações de segurança para ferramentas de depuração do Windows.
Os depuradores suportam vários protocolos de transporte: named pipe (NPIPE), TCP, COM port, secure pipe (SPIPE) e secure sockets layer (SSL).
A sintaxe geral para ativar um servidor de depuração depende do protocolo usado.
Métodos de conexão recomendados, com alguns de segurança adicionais
Debugger -server spipe:proto=Protocol,{certuser=Cert|machuser=Cert},pipe=PipeName[,hidden][,password=Password] [-noio] [Options]
Debugger -server ssl:proto=Protocol,{certuser=Cert|machuser=Cert},port=Socket[,hidden][,password=Password] [-noio] [Options]
Debugger -server ssl:proto=Protocol,{certuser=Cert|machuser=Cert},port=Socket,clicon=Client[,password=Password] [-noio] [Options]
Métodos de conexão não seguros
Debugger -server npipe:pipe=PipeName[,hidden][,password=Password][,IcfEnable] [-noio] [Options]
Debugger -server tcp:port=Socket[,hidden][,password=Password][,ipversion=6][,IcfEnable] [-noio] [Options]
Debugger -server tcp:port=Socket,clicon=Client[,password=Password][,ipversion=6] [-noio] [Options]
Debugger -server com:port=COMPort,baud=BaudRate,channel=COMChannel[,hidden][,password=Password] [-noio] [Options]
Outro método de ativar um servidor de depuração é usar o comando .server (Create Debugging Server) depois que o depurador já tiver sido iniciado.
Métodos de conexão recomendados, com alguns de segurança adicionais
.server spipe:proto=Protocol,{certuser=Cert|machuser=Cert},pipe=PipeName[,hidden][,password=Password]
.server ssl:proto=Protocol,{certuser=Cert|machuser=Cert},port=Socket[,hidden][,password=Password]
.server ssl:proto=Protocol,{certuser=Cert|machuser=Cert},port=Socket,clicon=Client[,password=Password]
Métodos de conexão não seguros
.server npipe:pipe=PipeName[,hidden][,password=Password][,IcfEnable]
.server tcp:port=Socket[,hidden][,password=Password][,ipversion=6][,IcfEnable]
.server tcp:port=Socket,clicon=Client[,password=Password][,ipversion=6]
.server com:port=COMPort,baud=BaudRate,channel=COMChannel[,hidden][,password=Password]
Parâmetros
Os parâmetros nos comandos anteriores têm os seguintes valores possíveis:
Depurador
Pode ser KD, CDB, NTSD ou WinDbg.
pipe=PipeName
Quando o protocolo NPIPE ou SPIPE é usado, PipeName é uma cadeia de caracteres que servirá como o nome do pipe. Cada nome de pipe deve identificar um servidor de depuração exclusivo. Se você tentar reutilizar um nome de pipe, receberá uma mensagem de erro.
PipeName não deve conter espaços ou aspas.
PipeName pode incluir um código numérico de formato printf-style, como %x ou %d. O depurador substituirá isso pela ID do processo do depurador. Um segundo código desse tipo será substituído pelo ID do thread do depurador.
Observação Talvez seja necessário habilitar o compartilhamento de arquivos e impressoras no computador que está executando o servidor de depuração. No Painel de Controle, navegue até Centro de Rede e Internet > Rede e Compartilhamento> Configurações avançadas de compartilhamento. Selecione Ativar a partilha de ficheiros e impressoras.
port=Socket
Quando o protocolo TCP ou SSL é usado, Socket é o número da porta do soquete.
Também é possível especificar um intervalo de portas separadas por dois pontos. O depurador verificará cada porta neste intervalo para ver se está livre. Se encontrar uma porta livre e não ocorrer nenhum erro, o servidor de depuração será criado. O cliente de depuração terá que especificar a porta real que está sendo usada para se conectar ao servidor. Para determinar a porta real, use qualquer um dos métodos descritos em Searching for Debugging Servers; Quando este servidor de depuração é exibido, a porta será seguida por dois números separados por dois pontos. O primeiro número será a porta real utilizada; o segundo pode ser ignorado. Por exemplo, se a porta foi especificada como port=51:60e a porta 53 foi realmente usada, os resultados da pesquisa mostrarão "port=53:60". (Se você estiver usando o parâmetro clicon para estabelecer uma conexão reversa, o cliente de depuração poderá especificar um intervalo de portas dessa maneira, enquanto o servidor deverá especificar a porta real usada.)
clicon= Cliente
Quando o protocolo TCP ou SSL é usado e o parâmetro
Como o servidor está procurando um cliente específico, você não pode conectar vários clientes ao servidor se você usar esse método. Se a conexão for recusada ou for interrompida, você terá que reiniciar a conexão do servidor. Um servidor de conexão reversa não aparecerá quando outro depurador exibir todos os servidores ativos.
Observação Quando clicon é usado, é melhor iniciar o cliente de depuração antes que o servidor de depuração seja criado, embora a ordem usual (servidor antes do cliente) também seja permitida.
port=COMPort
Quando o protocolo COM é usado, COMPort especifica a porta COM a ser usada. O prefixo "COM" é opcional -- por exemplo, "com2" e "2" são aceitáveis.
baud=BaudRate
Quando o protocolo COM é usado, BaudRate especifica a taxa de transmissão na qual a conexão será executada. Qualquer taxa de transmissão suportada pelo hardware é permitida.
channel=COMChannel
Se o protocolo COM for usado, COMChannel especifica o canal COM a ser usado na comunicação com o cliente de depuração. Pode ser qualquer valor entre 0 e 254, inclusive. Você pode usar uma única porta COM para várias conexões usando números de canal diferentes. (Isso é diferente do uso de portas COM para um cabo de depuração -- nessa situação, você não pode usar canais dentro de uma porta COM.)
proto=Protocolo
Se o protocolo SSL ou SPIPE for usado, protocolo especifica o protocolo Secure Channel (S-Channel). Pode ser qualquer uma das strings tls1, pct1, ssl2 ou ssl3.
Cert
Se o protocolo SSL ou SPIPE for usado, Cert especifica o certificado. Pode ser o nome do certificado ou a impressão digital do certificado (a cadeia de dígitos hexadecimais fornecida pelo snapin do certificado). Se a sintaxe certuser=Cert for usada, o depurador procurará o certificado no armazenamento do sistema (o repositório padrão). Se a sintaxe machuser=Cert for usada, o depurador procurará o certificado no armazenamento da máquina. O certificado especificado deve oferecer suporte à autenticação do servidor.
escondido
Impede que o servidor apareça quando outro depurador exibe todos os servidores ativos.
password=Password
Requer que um cliente forneça a senha especificada para se conectar à sessão de depuração.
de senha pode ser qualquer cadeia alfanumérica, com até doze caracteres.
Importante
Usar uma senha com protocolo TCP, NPIPE ou COM oferece apenas uma pequena quantidade de proteção, porque a senha não é criptografada. Quando utiliza uma palavra-passe juntamente com um protocolo SSL ou SPIPE, a palavra-passe é encriptada. Se você quiser estabelecer uma sessão remota mais segura, você deve usar o protocolo SSL ou SPIPE.
ipversion=6
(Somente Ferramentas de Depuração para Windows 6.6.07 e versões anteriores) Força o depurador a usar IP versão 6 em vez de versão 4 ao usar TCP para se conectar à Internet. No Windows Vista e versões posteriores, o depurador tenta definir automaticamente o padrão para IP versão 6, tornando essa opção desnecessária.
-noio
Se o servidor de depuração for criado com a opção -noio, nenhuma entrada ou saída poderá ser feita através do próprio servidor. O depurador só aceitará entrada do cliente de depuração (além de qualquer comando inicial ou script de comando especificado pela opção de linha de comando -c). Toda a saída será direcionada para o cliente de depuração. A opção -noio só está disponível com KD, CDB e NTSD. Se NTSD for usado para o servidor, nenhuma janela de console será criada.
IcfEnable
Faz com que o depurador habilite as conexões de porta necessárias para comunicação TCP ou pipe nomeado quando o Firewall de Conexão com a Internet estiver ativo. Por padrão, o Firewall de Conexão com a Internet desativa as portas usadas por esses protocolos. Quando IcfEnable é usado com uma conexão TCP, o depurador faz com que o Windows abra a porta especificada pelo parâmetro Socket. Quando IcfEnable é usado com uma conexão de pipe nomeado, o depurador faz com que o Windows abra as portas usadas para pipes nomeados (portas 139 e 445). O depurador não fecha essas portas após o término da conexão.
Opções
Quaisquer parâmetros de linha de comando adicionais podem ser colocados aqui. Consulte Command-Line Opções para obter uma lista completa.
Você pode usar o comando .server para iniciar vários servidores usando diferentes opções de protocolo. Isso permite que diferentes tipos de clientes de depuração participem da sessão.