SSH: X11 Forwarding
Com esta opção no SSH podemos redicionar conexão ao X Window no servidor para o servidor X local.
Ao realizar a conexão no servidor X Remoto a conexão é direcionada por default ao DISPLAY :10
Para isto realizamos a seguinte configuração nos arquivos abaixo:
SSH sem senha
Primeiro precisamos gerar um par de chaves públicas/privadas para autenticar com chaves RSA2 ou DSA.
RSA:
ssh-keygen -t rsa
DSA:
ssh-keygen -t dsa
As chaves são gerados no $HOME do usuário que você esta utilizando.
Utilizando rsh, rexec e rlogin
Primeiro precisamos ter instalado os seguintes pacotes:
server:~ # rpm -qa | grep rsh
rsh-0.17-548.13
rsh-server-0.17-548.9
server:~ #
Depois alteramos a linha abaixo nos arquivo de configurações de cada serviço no diretório /etc/xinet.d, como abaixo.
De:
disable = yes
Para:
disable = no
Logo após realizar um restart no serviço xinetd:
server:~ # /etc/init.d/xinetd restart
Shutting down xinetd: done
Starting INET services. (xinetd) done
server:~ #
Para verificar se os serviços encontram-se ativos:
server:~ # chkconfig --list rsh rexec rlogin
xinetd based services:
rsh: on
rexec: on
rlogin: on
server:~ #
NOTA:
Para executar comandos remotos através do rexec, utilize a linha de comando abaixo.
server:~ # rexec -a -l <username> -p <password> <server> <command>
Também é necessários liberar as portas TCP:
512 => rexec
513 => rlogin
514 => rsh
How to Find
Busca por nome de arquivos e/ou diretórios (pode-se realizar busca com expressões regulares)
- Case sensitive
# find / -name "*.sh" -print
# find / -name apache2 -print
# find / -name "[Bb]ind*" -print
- Case insensitve
# find / -iname "*lock*" -print
Busca com dois parâmetros (AND/OR)
- Arquivos .sh e .ksh
# find / \( -name \*.sh -a -name \*.ksh \) -print
- Arquivos .sh ou .ksh
# find / \( -name \*.sh -o -name \*.ksh \) -print
Busca por owner
- User ID
# find / -user www
- Group ID
# find / -group bin
Busca por tipo de permissões
- Octal
# find /usr/sbin/ -perm +0500
# find /usr/sbin/ -perm -0664
# find /usr/sbin/ -perm 0775
- Symbolic
# find /usr/sbin/ -perm +ug=rx
# find /usr/sbin/ -perm -u=rw
# find /usr/sbin/ -perm o=r
Busca apenas no diretório corrente
# find /usr -name "*.txt" -maxdepth 1 -print
Busca no diretório corrente e desce um subdiretório
# find /usr -name "*.txt" -maxdepth 2 -print
Busca apenas no file system corrente (existindo por exemplo um file system /usr/aap, este será excluído da busca)
# find /usr -xdev -name "*.txt" -print
Busca mantendo no diretório corrente (não é preciso utilizar -depth)
# find /usr -name "*.txt" -prune
Busca por tipo
- Somente arquivos
# find / -name apache2 -type f -print
- Somente diretórios
# find / -name apache2 -type d -print
- Somente links
# find / -name apache2 -type l -print
- Arquivos no home do usuário com 2 hard links
# find $HOME -type f -links 2
- Arquivos no home do usuário com mais de 1 hard link
# find $HOME -type f -links +1
Busca por tamanho de arquivo
- Arquivos maiores que 5M
# find / -size +5000 -print
- Arquivos menores que 5M
# find / -size -5000 -print
- Arquivos exatamente igual a 5M
# find / -size 5000 -print
Busca de arquivos por data de: acesso, criação e modificação
- Arquivos acessados com mais de 3 dias
# find /etc -atime +3 -print
- Arquivos acessados com menos de 3 dias
# find /etc -atime -3 -print
- Arquivos modificados com mais de 5 dias
# find /etc -mtime +5 -print
- Arquivos modificados com menos de 5 dias
# find /etc/ -mtime -5 -print
- Arquivos criados com mais de 10 dias
# find /var -ctime +10 -print
- Arquivos criados com menos de 10 dias
# find /var -ctime -10 -print
- Arquivos modificados exatamente há 7 dias
# find /etc -mtime 7 -print
- Arquivos acessados nas útimas 24 horas
# find /etc -atime 0 -print
Busca de arquivos e/ou diretórios com exceção (imprime tudo exceto parâmetro informado)
# find /usr ! -name "*lib*" -print
# find /usr -not -name "*lib*" -print
Busca com execução de comandos na saída
- Lista detalhe dos arquivos encontrados (equivalente a opção "ls -dils")
# find /var/log/ -name "*.log" -ls
- Excluir todos os arquivos no /tmp com mais de 3 dias
# find /tmp/ -ctime +3 -exec rm -rf {} \;
- Excluir todos arquivos no /tmp com extensão .lock sem confirmação
# find /tmp/ -name *.lock -exec rm -rf {} \;
- Exlcluir todos arquivos no /tmp com extensão .lock com confirmação
# find /tmp/ -name *.lock -ok rm -rf {} \;
- Excluir arquivos com nome core (-delete apenas para GNU find)
# find / -name "*core*" -type f -delete
- Compactar todos arquivos no /tmp com extensões .tmp e .bak
# find /tmp/ \( -name \*.tmp -o \*.bak \) -exec gzip {} \;
- Busca arquivos dentro do homedir com permissões 664 e altera para 775
# find $HOME -xdev type f -perm 664 -exec chmod 775 {} \;
Nota: Abaixo seguem alguns exemplos de expressões regulares e formatação do resultado da busca.
- Busca todos arquivos criados com menos de 5 dias, exceto arquivos que contenham "svn" no nome.
# find . -ctime -5 -not -regex '.*svn.*' -print
- Busca arquivos modificados a mais de uma semana e que tenham as extensões .csh ou .ksh
# find . -mtime +7 -regex '.*[ck]sh*'
- Formanto da saída da busca
# find . -printf "%TY%TW:%p\n"
# find . -printf '%TY-%Tm-%Td %TH:%TM:%TS %p\n'
# find . -printf '%p %a %m\n'
# find . -printf 'Name: %16f Size: %6s\n'
Importante: Descrição dos comandos acima.
%Ax - data do último acesso ao arquivo, formato da mesma definido em "x".
%Tx - data da última modificação do arquivo, formato da mesma definido em "x".d - dia do mês
D - data (dd/mm/aa)
h - mês (nome)
H - hora
m - mês (número)
M - minutos
S - segundos
T - hora (hh:mm:ss)
w - dia da semana
W - número da semana no ano
y - ano (2 digítos)
Y - ano (4 digítos)%a - data e hora do último acesso ao arquivo
%f - nome do arquivo (exclui PATH)
%m - permissões do arquivo (symbolic)
%p - nome do arquivo (inclui PATH)
%s - tamanho do arquivo (bytes)\n - quebra de linha
\t - tabulação horizontal
\v - tabulação vertical
OBS.: Neste artigo coloquei os arquivos que tenho utilizado diariamente, pois o comando find tem inúmeras possíbilidades, para explorá-las, basta dar uma lida no man. E lembrar também que todos os comandos poder ser mesclados, exemplos: busca por extensão de arquivo, permissão e mais de x dias acessados ou, busca por extensão x e y, tamanho e tipo de arquivo e etc...
Extendendo um LV no SUSE
Primeiro verificamos qual filesystem que queremos expandir, em VG e LV o mesmo pertence.
df -hT
Deveremos ter uma saída assim:
/dev/mapper/rootvg-optlv ext3 1.2G 997M 152M 87% /op
Onde podemos verificar que o filesystem pertence ao VG "rootvg" e ao LV "optlv". E então verificamos quanto de espaço temos livre no VG.
vgdisplay rootvg
server:~ # vgdisplay rootvg
--- Volume group ---
VG Name rootvg
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 9
VG Access read/write
VG Status resizable
MAX LV 255
Cur LV 7
Open LV 6
Max PV 255
Cur PV 1
Act PV 1
VG Size 14.81 GB
PE Size 4.00 MB
Total PE 3791
Alloc PE / Size 3373 / 13.18 GB
Free PE / Size 418 / 1.63 GB
VG UUID MnXXXX-JcR2-fcXX-dlXX-xxx3-bSfP-QmsdL9
Onde temos 1.63GB livre no VG, então verificamos que podemos expandir o nosso filesystem em até 1.63GB.
Agora basta realizar os passos abaixo para extender o filesystem /opt.
=> File system type ext3
umount /opt
lvexend -L 1GB /dev/rootvg/optlv
e2fsck -f /dev/rootvg/optlv
resize2fs /dev/rootvg/optlv
mount /opt
=> File system type reiserfs
umount /opt
lvexend -L 1GB /dev/rootvg/optlv
resize_reiserfs /dev/rootvg/optlv
mount /opt
A partir deste ponto podemos verificar que o filesystem foi aumentado em 1GB.
df -hT
OBS.: Em linux que possuem o "ext2online", este procedimento é realizado sem desmontar o filesystem.