Desmarcar opção de ajustar automaticamente o horário de verão no Windows

outubro 21st, 2018 by franklin Sem comentários »

Usei em servidores legados Windows 2003. Resumindo, para desmarcar a opção e ajustar a hora usei o comando abaixo.

reg.exe add HKLM\SYSTEM\CurrentControlSet\Control\TimeZoneInformation /f /v DisableAutoDaylightTimeSet /t REG_DWORD /d 1 && tzchange /c "Middle East Standard Time" && tzchange /c "E. South America Standard Time"

Ele cria um registro para desmarcar a opção, depois muda o GMT e depois volta o GMT para o da America do Sul. Ele tem que mudar o GMT senão não atualiza a hora.

Comando para pegar quantidades de processadores no Windows

outubro 15th, 2018 by franklin Sem comentários »

Barbadinha 😀

echo %NUMBER_OF_PROCESSORS%

Pegar parte da string no prompt de comando do Windows

abril 6th, 2018 by franklin Sem comentários »

O exemplo é para pegar somente o nome da pool de aplicativo do retorno do seguinte comando

C:\>appcmd list apppools /state:started /xml | findstr "APPPOOL.NAME"
    <APPPOOL APPPOOL.NAME="site1" PipelineMode="Integrated" RuntimeVersion="" state="Started" />
    <APPPOOL APPPOOL.NAME="site1" PipelineMode="Integrated" RuntimeVersion="" state="Started" />
    <APPPOOL APPPOOL.NAME="site1" PipelineMode="Integrated" RuntimeVersion="v4.0" state="Started" />

Para pegarmos somente o nome, podemos usar o seguinte

C:\>FOR /F delims^=^"^ tokens^=2 %i IN ('appcmd list apppools /state:started /xml ^| findstr "APPPOOL.NAME"') DO @ECHO %i
site1
site2
site3

onde delims é o delimitador que será quebrada a string e tokens é o número da coluna onde está a string que você quer, no nosso caso é a segunda coluna, conforme o primeiro comando deste exemplo, no final nós damos um DO para fazer alguma coisa com a saída do comando, no nosso caso nós só mostramos no prompt, mas poderiamos executar algum comando com base nessa saída, por exemplo.

Kill em vários processos no sql server usando o sqlcmd

outubro 4th, 2017 by franklin Sem comentários »

Na verdade é um facilitador.
Só precisa alterar a query pra condição que tu quer, no meu caso é pegar todos os PIDs que não são do usuário SA.
O output disso vai para o path informado depois do ‘-o’, que são as linhas prontas com os comandos para dar kill nos processos filtrados, daí é só colar no sql management

sqlcmd -q "Select 'kill ' + cast(spid as varchar(10)) from master..sysprocesses where loginame != 'sa'" -o %homepath%\desktop\killPids.txt

Exemplo do conteúdo do arquivo killPids.txt

 
---------------
kill 1000      
kill 1001      
kill 1002      
kill 1003      
kill 1004      
kill 1005      
kill 1006      
kill 1007      
kill 1008

Tipo comando awk no Windows

setembro 12th, 2017 by franklin Sem comentários »
for /f "tokens=2,5" %i in ('netstat -n -o ^| findstr /v "Active Proto"') do @echo Local Address = %i, PID = %j

Tokens diz quais as colunas que serão printadas do retorno do comando que está dentro do in.
Para a primeira coluna se usa %i, para a segunda %j, caso haja uma terceira, ela será %k

Mais detalhes com o comando

for /?

Link que me ajudou: https://superuser.com/questions/524822/awk-equivalent-functionality-on-windows

Apagar arquivos antigos e diretórios vazios com powershell

setembro 5th, 2017 by franklin Sem comentários »

Apagar arquivos com mais de 31 dias
Substitua %diretorio% pelo diretório que deseja apagar o conteúdo antigo

Get-ChildItem %diretorio% -recurse | Where {!$_.PSIsContainer -and $_.LastWriteTime -lt (get-date).AddDays(-31)} | Remove-Item -whatif

Apagar diretórios vazios
Substitua %diretorio% pelo diretório que deseja apagar os diretórios vazios

Get-ChildItem %diretorio% -recurse | Where {$_.PSIsContainer -and @(Get-ChildItem -Lit $_.Fullname -r | Where {!$_.PSIsContainer}).Length -eq 0} |Remove-Item -recurse -whatif

Lembrando que o parâmetro -whatif no final simula o que aconteceria se o comando fosse realmente executado. Para ele ser realmente executado, remova o -whatif do final

Referência: https://stackoverflow.com/questions/1575493/how-to-delete-empty-subfolders-with-powershell

Reciclar todas as pools de aplicativos do IIS com um comando

junho 26th, 2017 by franklin Sem comentários »

Ele pega o resultado do primeiro comando e manda pro segundo

appcmd list apppools /state:started /xml | appcmd recycle apppool /in

Créditos: http://adicodes.com/powershell-script-recycle-all-application-pools/

Pegar espaço utilizado de um disco através do PowerShell

maio 30th, 2017 by franklin Sem comentários »

No powershell é só executar o comando abaixo

1
Get-PSDrive C | Select {$_.Used / 1GB}

Para chamar o powershell no prompt command do Windows, então execute o comando abaixo

1
powershell -command "Get-PSDrive C | Select {$_.Used / 1GB}"

Lembrando que o C, no comando, é a unidade C, se tirar ele aparece de todos os discos

Erro ColdFusion: Could not create connection to database server. Attempted reconnect 3 times. Giving up.

fevereiro 8th, 2017 by franklin Sem comentários »

Estava com um problema ao conectar as DSNs de mysql ao banco de dados, o seguinte erro esporadicamente ocorria:

1
2
3
"Error Executing Database Query.Could not create connection to database server. Attempted reconnect 3 times. Giving up."
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Could not create connection to database server. Attempted reconnect 3 times. Giving up.
Caused by: java.security.AccessControlException: access denied ("java.net.SocketPermission" "mysql.franklin.com.br" "resolve")

O problema era que acontecia em alguns momentos, não era sempre. Pesquisando pelo erro achei o link abaixo
http://stackoverflow.com/questions/5489880/tomcat-6-and-mysql-5-x-connection-error-on-ubuntu
Onde o ocorria o mesmo problema mas no Java, como o CF roda com o Java, tentei descobrir como fazia a alteração no ColdFusion.
No servidor onde trabalho tem o sandbox habilitado para o ColdFusion, para resolver isso tive que ir, no administrador do CF, em security > Sandbox Security > path do site que acontecia o problema > Server/Ports
E no campo Server/IP Address, eu informei o IP de conexão com o servidor mysql e a porta que eu uso para conexão, assim a permissão de connect,resolve foi dada, conforme o link do stackoverflow, e tudo funcionou sem problemas 😀

Tipo nmap com o PowerShell

janeiro 18th, 2017 by franklin Sem comentários »

Precisava verificar IPs de um range para saber se estavam em uso, no Linux o serviço é bem fazer de se fazer, usando nmap -v -sP 192.168.0.0/24 se descobre fácil. No Windows eu dei uma pesquisada e achei o System.Net.Networkinformation.Ping que me ajudou bastante. O comando ficou assim

$ping = New-Object System.Net.Networkinformation.Ping
1..254 | % { $ping.send("192.168.100.$_") | select address, status | where status -eq 'Success'}

Resumindo é um foreach de 1 a 254 que vai testando o IP.

Baseado nas informações do seguinte link:
http://www.thomasmaurer.ch/2011/11/powershell-ping-ip-range/