Exemplos usando shell script

De Wiki Cursos IFPR Foz
Ir para navegaçãoIr para pesquisar

O que é Shell Script?

É um arquivo executável, que se transforma em uma ferramenta de automação interpretado pelo shell de comandos das derivações de sistemas operacionais Linux/Unix. É uma arquivo com comandos e intruções que facilita muito as tarefas dos profissionais de TI, pois proporciona ao usuário executar ou automatizar várias tarefas para serem executadas pelo sistema. Resumindo, acaba sendo uma linguagem de programação de alto nível que é interpretada pela shell.

Iniciando a linguagem de programação Shell Script

No terminal do linux, devemos escolher um editor para criar o shell script. Como exemplo, usando o editor nano, digitamos:

nano.nomedoscript.sh

Linha inicial do script

#!/bin/bash

Esta linha, após ser digitada em um editor, invoca o bash (ou /sh no caso do shell), que interpreta e executa as instruções contidas no script.

SHELL SCRIPT sem variável

  • shell script pasta mediawiki (sem variável)

A pasta mediawiki possui toda a base de dados gerada. Em nosso exemplo, ela está localizada no endereço: /var/www/html. A seguir segue o exemplo de shell script para acessar a pasta, compactar ela e fazer a cópia para a pasta Backup. O nome "backupwwwwiki.tar.gz" foi atribuído por escolha pessoal.

#!/bin/bash
cd /var/www/html
tar -zcvf backupwwwwiki.tar.gz mediawiki/
cp backupwwwwiki.tar.gz /home/usuario/Backup
exit


  • shell script base de dados my_wiki do banco de dados MySQL (sem variável)

No exemplo a seguir, foi escolhida uma base de dados do MySQL (my_wiki.sql),gerou o dump dessa base de dados, compactou e copiou para a pasta Backup do ususário.

#!/bin/bash
mysqldump -u root -psenha my_wiki > my_wiki.sql
cd /home/usuario
tar -zcvf backupmysqlwiki.tar.gz my_wiki.sql
cp backupmysqlwiki.tar.gz /home/usuario/Backup
exit
  • shell script base de dados moodle do banco de dados MySQL (sem variável)

Neste outro exemplo, foi escolhida outra base de dados do MySQL (moodle), também foi gerada o dump dessa base de dados, foi compactada e copiada para a pasta Backup do usuário.

#!/bin/bash
mysqldump -u root -psenha moodle > moodle.sql
cd /home/usuario
tar -zcvf backupwwwmoodle.tar.gz moodle.sql
cp backupwwwmoodle.tar.gz /home/usuario/Backup
exit

SHELL SCRIPT com variável

Devido a programação trabalhar com muitos valores, eles acabam variando muito em determinadas situações. Em nosso exemplo, utilizamos da variável para ser alterada quando for necessário, sem que se desvie do objetivo final do script criado.

  • shell script pasta mediawiki (com variável)

Seguindo a mesma descrição dos scripts criando sem variável, segue o script com variável da pasta "mediawiki". Este script vai gerar um arquivo compactado, que terá um nome, seguido de um número, que representa a hora, dia e mês em que foi criado.

#!/bin/bash
data=$(date +%s)
$DIR=/var/www/html
cd $DIR
DIR_ORIG="/var/www/html/mediawiki/"
DIR_DEST="/home/usuario/Backup"
BKP_NAME="backupwwwwiki-${data}.tar.gz"
tar -zcvf ${BKP_NAME} ${DIR_ORIG}
cp ${BKP_NAME} ${DIR_DEST}
exit


  • shell script pasta my_wiki (com variável)

Abaixo segue o script com variável da pasta de base de dados my_wiki do banco de dados do MySQL. Em relação ao script sem variável da mesma pasta citada acima, observa-se o uso das variáveis como diferencial. Este script vai gerar um arquivo compactado, que terá um nome seguido de um número, que representa a hora, dia e mês em que foi criado.

#!/bin/bash
data=$(date +%s)
mysqldump -u root -psenha my_wiki > /home/usuario/my_wiki.sql
$diretorio =/home/usuario/
cd  $diretorio
DIR_ORIG="/home/usuario/my_wiki.sql"
BKP_NAME="backupmysqlwiki-${data}.tar.gz"
DIR_DEST="/home/usuario/Backup/"
tar -zcvf ${BKP_NAME} ${DIR_ORIG}
cp ${BKP_NAME} ${DIR_DEST}
exit


  • shell script pasta moodle (com variável)

Abaixo segue o script com variável da pasta de base de dados moodle do banco de dados do MySQL. Em relação ao script sem variável ,da pasta moodle que foi citada acima, observa-se o uso das variáveis como diferencial. Este script vai gerar um arquivo compactado, que terá um nome seguido de um número, que representa a hora, dia e mês em que foi criado.

#!/bin/bash
data=$(date +%s)
mysqldump -u root -psenha moodle > /home/usuario/moodle.sql
$diretorio =/home/usuario/
cd  $diretorio
DIR_ORIG="/home/usuario/moodle.sql"
BKP_NAME="backupwwwmoodle-${data}.tar.gz"
DIR_DEST="/home/usuario/Backup/"
tar -zcvf ${BKP_NAME} ${DIR_ORIG}
cp ${BKP_NAME} ${DIR_DEST}
exit

SHELL SCRIPT para deletar arquivos

Como visto nos scripts acima, foram gerados backups de determinados arquivos. Chega um momento que eles precisam ser eliminados quando se esgotar o prazo de guarda que foi determinado como política de armazenamento, ou até mesmo para que o espaço reservado para backups não seja totalmente preenchido. Uma maneira de resolver essa situação, é criar um script, determinando algum critério para eliminação dos arquivos. Abaixo, alguns exemplos utilizados nessa ação.

O script abaixo, no momento em que for executado, determina que sejam eliminados os arquivos modificados a mais de 5 dias que estão dentro da pasta /home/marco/Backup.

#!/bin/bash
find /home/marco/Backup/ -mtime +5 -exec rm {} \;
exit



#!/bin/bash
find /home/marco/Backup/ -ctime +5 -exec rm {} \;
exit

Neste caso, o difencial é em relação a data de criação. Serão eliminados os arquivos que estiverem na pasta /home/marco/Backup que foram criados a mais de 5 dias.


#!/bin/bash
find /home/marco/Backup/ -mmin +60 -exec rm {} \;
exit

Agora o que muda neste exemplo, é que os arquivos serão deletados pela contagem em minutos, o script determina que sejam deletados os arquivos modificados a mais de 60 minutos.


#!/bin/bash
find /home/marco/Backup/ -cmin +60 -exec rm {} \;
exit

Esse outro exemplo, o script determina que sejam eliminados os arquivos da pasta /home/marco/Backup/ que foram criados a mais de 60 minutos.