Exemplos usando shell script
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
- 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
- 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
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