Compartilhe que você está se especializando

Vamos organizar de modo que os comandos mais simples de explicar fiquem em primeiro.

Apesar do linux ser extremamente poderoso e leve, sua administração (mesmo em itens simples) as vezes pode ser oneroso, ainda mais para quem não atua o tempo todo sobre essa plataforma. Abaixo alguns dos comandos mais usados no dia a dia (comentados, lembramos que o linux diferencia letras maiúsculas de minusculas):

Gerenciar usuários e grupos

  • Criar um usuário: useradd nome_do_usuario
  • Alterar a senha de um usuário: passwd nome_do_usuario
  • Criar um grupo: groupadd nome_do_grupo
  • Adicionar um usuário no grupo: usermod -a -G nome_do_grupo nome_do_usuario
  • Criar um usuário já como membro de um grupo primário: useradd -mg nome_do_grupo nome_do_usuario

Listar, Apagar, Criar, Mover e Copiar

  • Listar o conteúdo de uma pasta: ls -lah (apenas ls funcionaria, usamos o -l para formato em lista, -a para mostrar até arquivos ocultos, -h para mostrar o tamanhos em megabytes)
  • Apagar (arquivo ou pastas): rm -rf arquivo (apenas rm funcionaria, usamos o -r para não perguntar -f para forçar que seja apagado)
  • Criar pastas: mkdir -p pasta/pasta/pasta (com o -p vai criar as pastas e subpastas, sem questionar)
  • Criar arquivo: touch arquivo
  • Mover (arquivo ou pasta): mv arquivo /pasta
  • Copiar (arquivo ou pasta): cp -R o_que /pasta (-R vai copiar o conteúdo todo da pasta)
  • Sincronizar arquivos entre pastas: rsync -ravzh /pasta1/ /pasta2/
  • Copiar de um servidor linux para outro (via ssh e precisa ter o scp): scp -P 6000 foobar.txt username@remotehost.edu:/var/log (vai copiar via SSH o arquivo foobar.txt que está na pasta temp para a pasta /var/log do servidor remotehost.edu usando o usuário username, a senha será solicitada depois de executar o comando , o -P foi opcional considerando que a porta do SSH estava na porta 6000)

Gerenciando serviços

  • Parar um serviço: systemctl stop NOME_SERVIÇO
  • Iniciar um serviço: systemctl start NOME_SERVIÇO
  • Verificar se o status de um serviço: systemctl status NOME_SERVIÇO
  • Habilitar um serviço (para inciar automaticamente): systemctl enable NOME_SERVIÇO
  • Desabilitar um serviço (para não inciar automaticamente): systemctl disable NOME_SERVIÇO

Localizar arquivos (ou conteúdos)

  • Alterar o conteúdo de arquivos: sed -i “s/antes/depois/g” arquivo (pode-se usar wildcard, para em vez de arquivo usar *.conf, por exemplo)
  • Ver o tamanho de uma pasta: du -sh (-s para somar as subpastas e -h para mostrar os tamanhos em megabytes)
  • Para procurar arquivos que possuem uma palavra específica: grep -R palavra arquivo
    (usamos -R para procurar nas subpastas, pode-se usar wildcard, para em vez de arquivo usar *.conf, por exemplo)
  • Para procurar arquivos com um nome: find / -name arquivo (colocamos / para procurar em todo o servidor, mas poderia ser em um local específico, como /tmp , pode-se usar wildcard, para em vez de arquivo usar *.conf, por exemplo)

Alterar Permissões (arquivos ou pastas)

Aqui é necessário um tópico a parte, pois você precisa entender alguns conceitos.

Quando se executa o comando ls -l para listar em formato lista, é exibido algumas informações importantes, por exemplo, vamos simular a seguinte resposta:

drwxrw-r– 1 root apache 3.0K Feb 19 20:21 arquivo1

Vamos separar um pouco o que vemos para facilitar a explicação:

d | rwx | rw- | r– 1 root | apache 3.0K Feb 19 20:21 arquivo1

Explicação das partes negritas:

  • O primeiro ID informa se é um diretório
  • Os 3 próximos IDs são as permissões do DONO
  • Os 3 próximos IDs são as permissões do GRUPO
  • Os 3 próximos IDs são as permissões dos demais usuários
  • O próximo é o nome do DONO
  • O próximo é o nome do GRUPO
  • O próximo é o nome do arquivo ou pasta

Vejamos se você entendeu: No exemplo acima apesar de se chamar arquivo1, se trata de uma pasta, o dono dessa pasta se chama root e tem permissão completa (ler, gravar e executar: RWX), já o grupo apache tem permissão de leitura e escrita, mas não de executar (RW-) e os demais tem permissão de leitura (R–)

Uma informação importante, as permissões possuem os seguintes IDs

  • Leitura: 4
  • Gravação: 2
  • Execução: 1

É importante entender esses IDs pois é necessário somá-los para dar uma permissão (por exemplo: 6 para leitura e gravação, ou 5 para ler e gravar)

Entendendo isso podemos administrar corretamente as permissões, se quisermos mudar para que pedro seja o dono (com permissão apenas de ler e gravar), quem for do grupo games possa executar e ninguém mais tenha acesso vamos executar:

chown -R pedro.games arquivo1 (-R para aplicar também nas subpastas e arquivos também)
chmod -R 610 arquivo1 (-R para aplicar também nas subpastas e arquivos também, a permissão para o dono foi a soma dos IDs de leitura e gravação, o grupo recebeu o ID de execução e os demais ficaram sem nenhuma permissão)

Editar arquivos

Para zerar o conteúdo de um arquivo e deixar SOMENTE uma nova linha: echo “palavra” > /pasta/arquivo
Para adicionar uma linha no final do arquivo: echo “palavra” >> /pasta/arquivo

Como usar o vi para editar arquivos:

  • Abrir o arquivo com o vi: vi arquivo ou vi /pasta/arquivo
  • Vamos chamar os modos do vi de modo de edição e modo de leitura (para facilitar a explicação dos comandos)
  • Para inserir uma linha: aperte INSERT do teclado para entrar em modo de edição;
  • Para voltar ao modo de leitura: pressione a tecla ESC;
  • Para apagar uma linha inteira: em modo de leitura digite dd
  • Para salvar as alterações: em modo de leitura, digite :w
  • Para sair do documento: em modo de leitura, digite :q
  • Para confirmar o comando use a exclamação no comando (por exemplo, sair sem salvar use digite :q!, para salvar e sair, digite :wq!)
  • Para localizar uma palavra específica: em modo de leitura digite /palavra (para procurar as próximas pressione n, as anteriores SHIFT+n)
  • Para ir para uma linha específica (exemplo, a 10 linha): em modo de leitura digite :10
  • Para substituir as palavras TESTE por PRODUCAO da linha 20 até o final do documento: em modo de leitura digite :20,$ s/TESTE/PRODUCAO

Manipular discos e partições

Listar discos: fdisk -l

Criar partição: fdisk /dev/sdc (nesse caso, sdc é o nome do disco), dentro do fdisk vamos dar a sequencia de comandos

  • d (e ENTER) para apagar a partição, n (e ENTER) para recriar a partição;
  • p (e ENTER) para a partição ser do tipo primária;
  • 1 (e ENTER) para ser a sdc1;
  • Pressione ENTER (para usar o setor inicial do disco) e ENTER novamente (para usar até o último setor do disco);
  • Pressione w (e ENTER) para salvar o que foi feito e sair.

Formatar uma partição: mkfs.ext4 /dev/sdc1 (nesse caso, sdc é o nome do disco e a partição formatada é a 1)

Outros comandos

  • Consultar histórico dos comandos usados: history | more (o | permite executar um segundo comando em conjunto, nesse caso o comando more vai parar de página em página para você consultar todo o histórico)
  • Entrar em um diretório: cd /var (colocamos a / para ele voltar a raiz do disco e entrar na pasta var, sem a / ele consideraria que existe uma pasta var DENTRO da pasta que você está no momento)
  • Saber em qual pasta está no momento: pwd
  • Para saber com qual usuário está usando: whoami

Mais Informações

Esperamos ter te ajudado e estaremos sempre a disposição para mais informações.

Se você tem interesse em algum assunto específico, tem alguma dúvida, precisa de ajuda, ou quer sugerir um post, entre em contato conosco pelo e-mail equipe@nvlan.com.br.

NVLAN - Consultoria