Cron: Difference between revisions

From MoodleDocs
No edit summary
 
(21 intermediate revisions by 2 users not shown)
Line 3: Line 3:
O script primário do Moodle que faz tudo isso está localizado no diretório admin, e é chamado de cron.php. Contudo, ele não pode se auto-executar,  então você precisa estabelecer um mecanismo no qual o script é executado regularmente (ex. a cada 5 ou 10 minutos). Isso fornece um "ritmo" para que o script possa realizar funções em períodos definidos por cada módulo. Esse tipo de mecanismo regular é conhecido como '''serviço cron'''. O serviço pode ser parte de um webhost ou pode ser algo executado a partir de um servidor ou computador diferente.
O script primário do Moodle que faz tudo isso está localizado no diretório admin, e é chamado de cron.php. Contudo, ele não pode se auto-executar,  então você precisa estabelecer um mecanismo no qual o script é executado regularmente (ex. a cada 5 ou 10 minutos). Isso fornece um "ritmo" para que o script possa realizar funções em períodos definidos por cada módulo. Esse tipo de mecanismo regular é conhecido como '''serviço cron'''. O serviço pode ser parte de um webhost ou pode ser algo executado a partir de um servidor ou computador diferente.


==Sobre o cron==
==Visão geral do cron==
===Sobre o script===
===Visão geral do script===


O script cron.php procura através da tabela mdl_modules (assumindo que a tabela o prefixo da tabela padrão seja mdl_) na base de dados do Moodle por módulos que tenham agendado funções do cron; então ele procura em cada diretório desses módulos por uma função chamada nome-do-modulo_cron no arquivo lib.php e a executa. Ele também procura através da tabela mdl_block por blocos que tenham agendado seus métodos cron (funções de objeto);  então, para cada um desses blocos, ele executa o método cron para um novo objeto  associado àquele bloco (eu estou omitindo detalhes para não complicar muito para não-programadores; os programadores podem ler admin/cron.php para mais informações). Esses arquivos (os lib.php e os nos quais as classes de bloco são definidas) podem conter funções de limpeza, email ou qualquer coisa que precise ser executada regularmente. For example, cron will trigger the system to create the backups of courses at the time specified in the administration settings. It also triggers any messaging module or forum email notifications, but not all functions are called each time the cron runs. Some functions, such as unenrolling students who have not logged in or deleting old copies of log files, are only run occasionally. The cron.php file has a section which will randomly call these core tasks approximately 1 in 5 times the cron runs.
O script cron.php procura através da tabela mdl_modules (assumindo que o prefixo da tabela padrão seja mdl_) na base de dados do Moodle por módulos que tenham agendado funções do cron; então ele procura em cada diretório desses módulos por uma função chamada nome-do-modulo_cron no arquivo lib.php e a executa. Ele também procura através da tabela mdl_block por blocos que tenham agendado seus métodos cron (funções de objeto);  então, para cada um desses blocos, ele executa o método cron para um novo objeto  associado àquele bloco (eu estou omitindo detalhes para não complicar muito para não-programadores; os programadores podem ler admin/cron.php para mais informações). Esses arquivos (os lib.php e os nos quais as classes de bloco são definidas) podem conter funções de limpeza, email ou qualquer coisa que precise ser executada regularmente. Por exemplo, o cron irá ativar o sistema para criar os backups dos cursos no horário especificado nas configurações de administração. Ele também ativa qualquer módulo de envio de mensagens ou notificações por email dos fóruns, mas nem todas as funções são chamadas toda vez que o cron roda. Algumas funções, como desinscrever estudantes que não tenham logado ou excluir cópias antigas dos arquivos de log, só são executadas ocasionalmente. O arquivo cron.php tem uma sessão que irá chamar aleatoriamente essas tarefas centrais aproximadamente 1 de cada 5 vezes que o cron rodar.


===Cron service location and timing===
===Localização do serviço cron e configuração de tempo===
Note that the machine performing the cron '''does not need to be the same machine that is running Moodle'''. For example, if you have a limited web hosting service that does not have a cron service, then you might choose to run cron on another server or on your home computer. All that matters is that the cron.php file is called regularly.
Note que a máquina que executa o cron '''não precisa ser a mesma máquina que está rodando o Moodle'''. Por exemplo, se você tem um serviço de web hosting limitado que não tem um serviço cron, então você pode escolher rodar o cron em um outro servidor ou no seu computador de casa. O importante é que o arquivo cron.php seja chamado regularmente.


The load of this script is not very high, so 5 minutes is usually reasonable, but if you're worried about it you can reduce the time period to something like 15 minutes or even 30 minutes. It's best not to make the time period too long, as delaying mail-outs can slow down activity within the course. Remember that mail-outs also wait for the editing time to expire before being queued for sending.
O carregamento desse script não é muito alto, assim 5 minutos é geralmente um tempo razoável, mas se você estiver preocupado quanto a isso você pode aumentar o período de tempo para algo como 15 ou até mesmo 30 minutos. É melhor não deixar esse período muito longo, pois atrasos de envio de emails podem diminuir a atividade em um curso. Lembre-se de que o envio de emails também espera que o tempo de edição expire antes de entrar na fila para execução.


===Testing cron and manual trigger===
===Testando o cron e ativação manual===


First, test that the script works by running it directly from your browser: ''<nowiki>http://example.com/moodle/admin/cron.php</nowiki>''
Primeiro, teste se o script está funcionando rodando-o diretamente no seu navegador: ''<nowiki>http://example.com/moodle/admin/cron.php</nowiki>''


If cron is called from the command line by any user logged in to your Moodle it will create a temporary admin environment in order to run and then log the user out. You can disable command line running of cron by disabling the appropriate section in the cron.php file.
Se o cron for chamado pela linha de comando por qualquer usuário logado no seu Moodle será criado um ambiente admin temporário para executar e então    deslogar o usuário. Você pode desabilitar a execução do cron por linha de comando desativando a sessão apropriada no arquivo cron.php.


Now, you need to set up some of way of running the script automatically and regularly.
Agora, você precisa configurar alguma maneira de executar o script automaticamente e regularmente.


==Managing Cron on Windows systems==
==Administrando o cron em sistemas Windows==


There are two different ways for setting-up Moodle cron.php on Windows systems:
Existem duas maneiras de configurar a execução do script Moodle cron.php em sistemas Windows:


*Use the '''Moodle Cron package'''. The simplest way is to use this little package [http://download.moodle.org/download.php/sourceforge/MoodleCron-Setup.exe MoodleCron-Setup.exe], which makes this whole thing very easy by installing a small Windows service. Run it and forget about it! :-)
*Use o '''pacote Cron do Moodle'''. O modo mais simples é utilizar este pequeno pacote [http://download.moodle.org/download.php/sourceforge/MoodleCron-Setup.exe MoodleCron-Setup.exe], que torna todo o processo bastante simples instalando um pequeno serviço Windows. Execute-o e esqueça-o! :-)
*Use a '''Scheduled Task'''. If you prefer to use the built-in Windows Scheduler or are having trouble with moodle-cron-for-windows package, you can use wget for windows or php from the command line and setup a scheduled task. Just follow these steps:
*Use uma '''tarefa agendada'''. Se você preferir utilizar o agendador que já vem no Windows ou está tendo problemas com o pacote moodle-cron-para-windows, você pode utilizar wget para windows ou php na linha de comando e agendar uma tarefa. Apenas siga os seguintes passos:
** Choose either the '''php.exe/php-win.exe (command line binary)''' or '''wget'''
** Escolha ou o '''php.exe/php-win.exe (binário de linha de comando)''' ou '''wget'''
::The php.exe or php-win.exe binary (for PHP version 5 or later) is installed in your php folder (e.g. c:\php) will give you better performance when running the cron script.
::O php.exe ou o binário php-win.exe (para a versão 5 ou posterior do PHP), que está instalado na pasta do seu php (ex. c:\php), lhe dará uma melhor performance ao executar o script cron.
::If you want to use wget, download a compiled version of wget for windows from the native GNU Win32 ports (http://unxutils.sourceforge.net/), from Heiko Herold's wget for windows page (http://xoomer.virgilio.it/hherold/) or Bart Puype's wget for windows page (http://users.ugent.be/~bpuype/wget/). If you use Heiko Herold's package, copy all of the .DLL files to your C:\Windows\system32 directory. Copy the wget.exe file to c:\windows (this makes sure wget is always in the search path).
::Se você quiser usar wget, baixe uma versão compilada para Windows das portas nativas do GNU Win32 (http://unxutils.sourceforge.net/), da página  Heiko Herold's wget for windows (http://xoomer.virgilio.it/hherold/) ou da página Bart Puype's wget for windows (http://users.ugent.be/~bpuype/wget/). Se você usar o pacote de Heiko Herold, copie todos os arquivos .DLL para o diretório C:\Windows\system32. Copie o arquivo wget.exe para c:\windows (isso garante que wget esteja sempre no caminho de busca).
:* Setup a '''Scheduled Task'''.  
:* Configure uma '''tarefa agendada'''.  
:: - Go to Start >> Control Panel >> Scheduled Tasks >> Add Scheduled Task.
:: - Vá em Iniciar >> Painel de Controle >> Tarefas Agendadas >> Adicionar Tarefa Agendada.
:: - Click "Next" to start the wizard:
:: - Clique em "Avançar" to start the wizard:
:: - Click in the "Browse..." button and browse to c:\php\php.exe or c:\windows\wget.exe and click "Open"
:: - Click in the "Browse..." button and browse to c:\php\php.exe or c:\windows\wget.exe and click "Open"
:: - Type "Moodle Cron" as the name of the task and select "Daily" as the schedule. Click "Next".
:: - Type "Moodle Cron" as the name of the task and select "Daily" as the schedule. Click "Next".
Line 42: Line 42:
:: - Mark the "Repeat task" checkbox and set "Every:" to 5 minutes, and set "Until:" to "Duration" and type "23" hours and "59" minutes.
:: - Mark the "Repeat task" checkbox and set "Every:" to 5 minutes, and set "Until:" to "Duration" and type "23" hours and "59" minutes.
:: - Click "OK" and you are done.
:: - Click "OK" and you are done.
* '''Test your scheduled task'''. You can test that your scheduled task can run successfully by clicking it with the right button and chosing "Run". If everything is correctly setup, you will briefly see a DOS command window while wget/php executes and fetches the cron page and then it disappears. If you refresh the scheduled tasks folder, you will see the ''Last Run Time column'' (in detailed folder view) reflects the current time, and that the Last Result column displays "0x0" (everything went OK). If either of these is different, then you should recheck your setup.
* '''Teste sua tarefa agendada'''. You can test that your scheduled task can run successfully by clicking it with the right button and chosing "Run". If everything is correctly setup, you will briefly see a DOS command window while wget/php executes and fetches the cron page and then it disappears. If you refresh the scheduled tasks folder, you will see the ''Last Run Time column'' (in detailed folder view) reflects the current time, and that the Last Result column displays "0x0" (everything went OK). If either of these is different, then you should recheck your setup.
* '''Logging cron output'''. You may want to log the output of the cron script as it executes, in case you see the job is producing errors, backups are not being completed or users are experiencing delays in receiving forum emails. To do this, adjust the command so that it uses the php.exe and stores the output in a file called (for example c:\moodle\admin\cron.log). Here is an example of the php.exe command:
* '''Logging cron output'''. You may want to log the output of the cron script as it executes, in case you see the job is producing errors, backups are not being completed or users are experiencing delays in receiving forum emails. To do this, adjust the command so that it uses the php.exe and stores the output in a file called (for example c:\moodle\admin\cron.log). Here is an example of the php.exe command:
<pre>c:\php\php.exe -f c:\moodle\admin\cron.php > c:\moodle\admin\cron.log</pre>
<pre>c:\php\php.exe -f c:\moodle\admin\cron.php > c:\moodle\admin\cron.log</pre>


==Managing cron on web hosting services==
==Administrando o cron em serviços de web hosting==


Your web-based control panel may have a web page that allows you to set up a cron service process.  
Your web-based control panel may have a web page that allows you to set up a cron service process.  


===CPanel cron service===
===Serviço cron CPanel===
If you are using CPanel, login then look for "Advanced" category towards the bottom of the page. Click on Cron Jobs -> Advanced (Unix style). Enter the following for the cron to run every 30 minutes.
Se você está usando CPanel, faça login e então olhe para  categoria "Avançada " para o roda-pé da página. Faça clique em Cron Jobs -> Advanced (Unix style). Entre no seguinte para o cron rodar a cada 30 minutos.


  Email address for output: emailaddress@mydomain.con
  Email address for output: emailaddress@mydomain.con
Line 61: Line 61:
  <nowiki>Command: wget -q -O /dev/null http://www.mydomain.com/moodle/admin/cron.php</nowiki>
  <nowiki>Command: wget -q -O /dev/null http://www.mydomain.com/moodle/admin/cron.php</nowiki>


Click Commit Changes. Check your email for the output.  
Clique Commit Changes. Confira seu e-mail para a saída.  


[[Image:Cpanel-cron-setup.JPG]]
[[Image:Cpanel-cron-setup.JPG]]


===Other systems cron service===
===Serviço cron para outros sistemas===
For other systems, look for a button called "Cron jobs". In there you can put the same sort of Unix commands as listed below.
Para outros sistemas, procure um botão chamado "Cron jobs". Lá você pode pôr a mesma classificação de comandos de Unix como listado abaixo.




If you don't have permissions to run the 'wget' command on the server, you can use this php command:
Se você não tem permissões para rodar o comando ' wget' no servidor, você pode usar este comando php:


  /usr/local/bin/php -q /real/path/to/script/admin/cron.php
  /usr/local/bin/php -q /real/path/to/script/admin/cron.php


For example:  
Por Exemplo:  


  /usr/local/bin/php -q /home/username/public_html/moodle/admin/cron.php
  /usr/local/bin/php -q /home/username/public_html/moodle/admin/cron.php


If you don't know what is the real path of your Moodle folder you can use the PHP command realpath.
Se você não sabe qual é o caminho real de sua pasta de papéis de Moodle você pode usar o comando PHP realpath.


Another alternative, if you do not have permission to run the 'wget' command, may be to use a curl command.
Outro alternativa, se você não tem permissão para rodar o comando ' wget', pode ser usado o comando curl.


For example:
Por exemplo:


curl --silent --compressed http://mydomain.com/moodle/admin/cron.php
curl --silent --compressed http://mydomain.com/moodle/admin/cron.php


==Using a cron command line in Unix==
==Usando uma linha de comando cron em Unix==


There are different command line programs you can use to call the page from the command line. Not all of them may be available on a given server.
Existem diferentes programas de linha de comando que você pode usar para chamar a página. Nem todos podem estar disponíveis em um certo servidor.


For example, you can use a Unix utility like 'wget':
Por exemplo, você pode utilizar uma utilidade Unix como 'wget':


  wget -q -O /dev/null <nowiki>http://example.com/moodle/admin/cron.php</nowiki>
  wget -q -O /dev/null <nowiki>http://example.com/moodle/admin/cron.php</nowiki>


Note in this example that the output is thrown away (to /dev/null).
Note que nesse exemplo o resultado é descartado (para /dev/null).


A number of users of Moodle have found that 'wget' sometimes fails. Especially if you have trouble with email digests not being sent on a daily basis to all users, an alternative command that solves the problem is:
Vários usuários do Moodle descobriram que 'wget' às vezes falha. Especialmente se você tem problemas com email digests não sendo enviados diariamente para todos os usuários, um comando alternativo que resolve o problema é:


  php <nowiki>http://example.com/moodle/admin/cron.php</nowiki>
  php <nowiki>http://example.com/moodle/admin/cron.php</nowiki>


The same thing using lynx:
A mesma coisa usando lynx:


  lynx -dump <nowiki>http://example.com/moodle/admin/cron.php</nowiki> > /dev/null
  lynx -dump <nowiki>http://example.com/moodle/admin/cron.php</nowiki> > /dev/null


Note in this example that the output is thrown away (to /dev/null).
Note que nesse exemplo o resultado é descartado (para /dev/null).


Alternatively you could use a standalone version of PHP, compiled to be run on the command line. The advantage with doing this is that your web server logs aren't filled with constant requests to cron.php. The disadvantage is that you need to have access to a command-line version of php.
Alternativamente, você pode usar uma versão standalone do PHP, compilada para ser executada na linha de comando. A vantagem é que os logs do seu servidor web não são enchidos com contastes solicitações ao cron.php. A desvantagem é que você precisa ter acesso a uma versão linha-de-comando do php.


  /opt/bin/php /web/moodle/admin/cron.php
  /opt/bin/php /web/moodle/admin/cron.php


===Using the crontab program on Unix===
===Usando o programa crontab em Unix===


All that Cpanel does is provide a web interface to a Unix utility known as crontab. If you have a command line, you can set up crontab yourself using the command:
Tudo que o Cpanel faz é fornecer uma interface web para uma utilidade do Unix conhecida como crontab. Se você tem um linha de comando, você mesmo pode configurar o crontab pelo comando:


  crontab -e
  crontab -e


and then adding one of the above commands like:
e então adicionando um dos comandos acima como:


  */30 * * * * wget -q -O /dev/null <nowiki>http://example.com/moodle/admin/cron.php</nowiki>
  */30 * * * * wget -q -O /dev/null <nowiki>http://example.com/moodle/admin/cron.php</nowiki>


The first five entries are the times to run values, followed by the command to run. The asterisk is a wildcard, indicating any time. The above example means run the command ''wget -q -O /dev/null...'' every 30 minutes (*/30), every hour (*), every day of the month (*), every month (*), every day of the week (*).  
As primeiras 5 entradas são os valores do tempo para execução, seguidas do comando a ser executado. O asterisco é um curinga, indicando qualquer valor. O exemplo acima significa rodar o comando ''wget -q -O /dev/null...'' a cada 30 minutos (*/30), toda hora (*), todos os dias do mês (*), todos os dias da semana (*).  


The "O" of "-O" is the capital letter not zero, and refers the output file destination, in this case "/dev/null" which is a black hole and discards the output. If you want to see the output of your cron.php then enter its url in your browser.  
O "O" em "-O" é a letra maiúscula, não zero, e faz referência a destinação do arquivo resultante (output file), nesse caso "/dev/null" que é um buraco negro e descarta esse resultado. Se você quiser ver o resultado do cron.php, insira a url dele no seu navegador.  


* [http://linuxweblog.com/node/24 A basic crontab tutorial]  
* [http://linuxweblog.com/node/24 Um tutorial básico de crontab]  
* [http://www.freebsd.org/cgi/man.cgi?query=crontab&apropos=0&sektion=5&manpath=FreeBSD+6.0-RELEASE+and+Ports&format=html Online version of the man page]  
* [http://www.freebsd.org/cgi/man.cgi?query=crontab&apropos=0&sektion=5&manpath=FreeBSD+6.0-RELEASE+and+Ports&format=html Versão online da página principal]  


For '''beginners''', "EDITOR=nano crontab -e" will allow you to edit the crontab using the [http://www.nano-editor.org/dist/v1.2/faq.html nano] editor. Ubuntu defaults to using the nano editor.
Para '''iniciantes''', "EDITOR=nano crontab -e" irá lhe permitir editar o crontab utilizando o editor  [http://www.nano-editor.org/dist/v1.2/faq.html nano]. No Ubuntu o editor padrão já é o nano.


Usually, the "crontab -e" command will put you into the 'vi' editor. You enter "insert mode" by pressing "i", then type in the line as above, then exit insert mode by pressing ESC. You save and exit by typing ":wq", or quit without saving using ":q!" (without the quotes). Here is an [http://www.unix-manuals.com/tutorials/vi/vi-in-10-1.html intro] to the 'vi' editor.
Geralmente, o comando "crontab -e" lhe colocará no editor 'vi'. Você entra em "insert mode" (modo de inserção) pressionando "i", então digite a linha exemplificada acima, depois saia do modo de inserção pressionando ESC. Você salva e sai digitando ":wq", ou sai sem salvar digitando ":q!" (sem as aspas). Aqui uma [http://www.unix-manuals.com/tutorials/vi/vi-in-10-1.html introdução] ao editor 'vi'.


==Ver também==
==Ver também==


Using Moodle forum discussions:
Discussões do fórum Using Moodle:
*[http://moodle.org/mod/forum/discuss.php?d=41827 Cron - can someone give me a quick confirmation of function?]
*[http://moodle.org/mod/forum/discuss.php?d=41827 Cron - can someone give me a quick confirmation of function?]
*[http://moodle.org/mod/forum/discuss.php?d=97684 Cronjob Question]
*[http://moodle.org/mod/forum/discuss.php?d=97684 Cronjob Question]

Latest revision as of 02:57, 5 November 2009

O cron auxilia alguns módulos do Moodle a executar tarefas de forma agendada. Por exemplo, o processo cron pode dizer ao Moodle para verificar todos os fóruns de discussão para que ele possa enviar cópias por email dos novos posts para os assinantes daquele fórum.

O script primário do Moodle que faz tudo isso está localizado no diretório admin, e é chamado de cron.php. Contudo, ele não pode se auto-executar, então você precisa estabelecer um mecanismo no qual o script é executado regularmente (ex. a cada 5 ou 10 minutos). Isso fornece um "ritmo" para que o script possa realizar funções em períodos definidos por cada módulo. Esse tipo de mecanismo regular é conhecido como serviço cron. O serviço pode ser parte de um webhost ou pode ser algo executado a partir de um servidor ou computador diferente.

Visão geral do cron

Visão geral do script

O script cron.php procura através da tabela mdl_modules (assumindo que o prefixo da tabela padrão seja mdl_) na base de dados do Moodle por módulos que tenham agendado funções do cron; então ele procura em cada diretório desses módulos por uma função chamada nome-do-modulo_cron no arquivo lib.php e a executa. Ele também procura através da tabela mdl_block por blocos que tenham agendado seus métodos cron (funções de objeto); então, para cada um desses blocos, ele executa o método cron para um novo objeto associado àquele bloco (eu estou omitindo detalhes para não complicar muito para não-programadores; os programadores podem ler admin/cron.php para mais informações). Esses arquivos (os lib.php e os nos quais as classes de bloco são definidas) podem conter funções de limpeza, email ou qualquer coisa que precise ser executada regularmente. Por exemplo, o cron irá ativar o sistema para criar os backups dos cursos no horário especificado nas configurações de administração. Ele também ativa qualquer módulo de envio de mensagens ou notificações por email dos fóruns, mas nem todas as funções são chamadas toda vez que o cron roda. Algumas funções, como desinscrever estudantes que não tenham logado ou excluir cópias antigas dos arquivos de log, só são executadas ocasionalmente. O arquivo cron.php tem uma sessão que irá chamar aleatoriamente essas tarefas centrais aproximadamente 1 de cada 5 vezes que o cron rodar.

Localização do serviço cron e configuração de tempo

Note que a máquina que executa o cron não precisa ser a mesma máquina que está rodando o Moodle. Por exemplo, se você tem um serviço de web hosting limitado que não tem um serviço cron, então você pode escolher rodar o cron em um outro servidor ou no seu computador de casa. O importante é que o arquivo cron.php seja chamado regularmente.

O carregamento desse script não é muito alto, assim 5 minutos é geralmente um tempo razoável, mas se você estiver preocupado quanto a isso você pode aumentar o período de tempo para algo como 15 ou até mesmo 30 minutos. É melhor não deixar esse período muito longo, pois atrasos de envio de emails podem diminuir a atividade em um curso. Lembre-se de que o envio de emails também espera que o tempo de edição expire antes de entrar na fila para execução.

Testando o cron e ativação manual

Primeiro, teste se o script está funcionando rodando-o diretamente no seu navegador: http://example.com/moodle/admin/cron.php

Se o cron for chamado pela linha de comando por qualquer usuário logado no seu Moodle será criado um ambiente admin temporário para executar e então deslogar o usuário. Você pode desabilitar a execução do cron por linha de comando desativando a sessão apropriada no arquivo cron.php.

Agora, você precisa configurar alguma maneira de executar o script automaticamente e regularmente.

Administrando o cron em sistemas Windows

Existem duas maneiras de configurar a execução do script Moodle cron.php em sistemas Windows:

  • Use o pacote Cron do Moodle. O modo mais simples é utilizar este pequeno pacote MoodleCron-Setup.exe, que torna todo o processo bastante simples instalando um pequeno serviço Windows. Execute-o e esqueça-o! :-)
  • Use uma tarefa agendada. Se você preferir utilizar o agendador que já vem no Windows ou está tendo problemas com o pacote moodle-cron-para-windows, você pode utilizar wget para windows ou php na linha de comando e agendar uma tarefa. Apenas siga os seguintes passos:
    • Escolha ou o php.exe/php-win.exe (binário de linha de comando) ou wget
O php.exe ou o binário php-win.exe (para a versão 5 ou posterior do PHP), que está instalado na pasta do seu php (ex. c:\php), lhe dará uma melhor performance ao executar o script cron.
Se você quiser usar wget, baixe uma versão compilada para Windows das portas nativas do GNU Win32 (http://unxutils.sourceforge.net/), da página Heiko Herold's wget for windows (http://xoomer.virgilio.it/hherold/) ou da página Bart Puype's wget for windows (http://users.ugent.be/~bpuype/wget/). Se você usar o pacote de Heiko Herold, copie todos os arquivos .DLL para o diretório C:\Windows\system32. Copie o arquivo wget.exe para c:\windows (isso garante que wget esteja sempre no caminho de busca).
  • Configure uma tarefa agendada.
- Vá em Iniciar >> Painel de Controle >> Tarefas Agendadas >> Adicionar Tarefa Agendada.
- Clique em "Avançar" to start the wizard:
- Click in the "Browse..." button and browse to c:\php\php.exe or c:\windows\wget.exe and click "Open"
- Type "Moodle Cron" as the name of the task and select "Daily" as the schedule. Click "Next".
- Select "12:00 AM" as the start time, perform the task "Every Day" and choose today's date as the starting date. Click "Next".
- Enter the username and password of the user the task will run under (it doesn't have to be a priviledged account at all). Make sure you type the password correctly. Click "Next".
- Mark the checkbox titled "Open advanced properties for this task when I click Finish" and click "Finish".
- In the new dialog box, type the following in the "Run:" text box:
c:\windows\wget.exe -q -O NUL http://my.moodle.site/moodle/admin/cron.php
or
c:\php\php-win.exe -f c:\moodle\admin\cron.php
Replace "c:\moodle" with the path to your moodle directory or "my.moode.site" with the name of your site.

- Click on the "Schedule" tab and there in the "Advanced..." button.
- Mark the "Repeat task" checkbox and set "Every:" to 5 minutes, and set "Until:" to "Duration" and type "23" hours and "59" minutes.
- Click "OK" and you are done.
  • Teste sua tarefa agendada. You can test that your scheduled task can run successfully by clicking it with the right button and chosing "Run". If everything is correctly setup, you will briefly see a DOS command window while wget/php executes and fetches the cron page and then it disappears. If you refresh the scheduled tasks folder, you will see the Last Run Time column (in detailed folder view) reflects the current time, and that the Last Result column displays "0x0" (everything went OK). If either of these is different, then you should recheck your setup.
  • Logging cron output. You may want to log the output of the cron script as it executes, in case you see the job is producing errors, backups are not being completed or users are experiencing delays in receiving forum emails. To do this, adjust the command so that it uses the php.exe and stores the output in a file called (for example c:\moodle\admin\cron.log). Here is an example of the php.exe command:
c:\php\php.exe -f c:\moodle\admin\cron.php > c:\moodle\admin\cron.log

Administrando o cron em serviços de web hosting

Your web-based control panel may have a web page that allows you to set up a cron service process.

Serviço cron CPanel

Se você está usando CPanel, faça login e então olhe para categoria "Avançada " para o roda-pé da página. Faça clique em Cron Jobs -> Advanced (Unix style). Entre no seguinte para o cron rodar a cada 30 minutos.

Email address for output: emailaddress@mydomain.con
Minute:*/30
Hour:*
Day:*
Month:*
Weekday:* 
Command: wget -q -O /dev/null http://www.mydomain.com/moodle/admin/cron.php

Clique Commit Changes. Confira seu e-mail para a saída.

Cpanel-cron-setup.JPG

Serviço cron para outros sistemas

Para outros sistemas, procure um botão chamado "Cron jobs". Lá você pode pôr a mesma classificação de comandos de Unix como listado abaixo.


Se você não tem permissões para rodar o comando ' wget' no servidor, você pode usar este comando php:

/usr/local/bin/php -q /real/path/to/script/admin/cron.php

Por Exemplo:

/usr/local/bin/php -q /home/username/public_html/moodle/admin/cron.php

Se você não sabe qual é o caminho real de sua pasta de papéis de Moodle você pode usar o comando PHP realpath.

Outro alternativa, se você não tem permissão para rodar o comando ' wget', pode ser usado o comando curl.

Por exemplo:

curl --silent --compressed http://mydomain.com/moodle/admin/cron.php

Usando uma linha de comando cron em Unix

Existem diferentes programas de linha de comando que você pode usar para chamar a página. Nem todos podem estar disponíveis em um certo servidor.

Por exemplo, você pode utilizar uma utilidade Unix como 'wget':

wget -q -O /dev/null http://example.com/moodle/admin/cron.php

Note que nesse exemplo o resultado é descartado (para /dev/null).

Vários usuários do Moodle descobriram que 'wget' às vezes falha. Especialmente se você tem problemas com email digests não sendo enviados diariamente para todos os usuários, um comando alternativo que resolve o problema é:

php http://example.com/moodle/admin/cron.php

A mesma coisa usando lynx:

lynx -dump http://example.com/moodle/admin/cron.php > /dev/null

Note que nesse exemplo o resultado é descartado (para /dev/null).

Alternativamente, você pode usar uma versão standalone do PHP, compilada para ser executada na linha de comando. A vantagem é que os logs do seu servidor web não são enchidos com contastes solicitações ao cron.php. A desvantagem é que você precisa ter acesso a uma versão linha-de-comando do php.

/opt/bin/php /web/moodle/admin/cron.php

Usando o programa crontab em Unix

Tudo que o Cpanel faz é fornecer uma interface web para uma utilidade do Unix conhecida como crontab. Se você tem um linha de comando, você mesmo pode configurar o crontab pelo comando:

crontab -e

e então adicionando um dos comandos acima como:

*/30 * * * * wget -q -O /dev/null http://example.com/moodle/admin/cron.php

As primeiras 5 entradas são os valores do tempo para execução, seguidas do comando a ser executado. O asterisco é um curinga, indicando qualquer valor. O exemplo acima significa rodar o comando wget -q -O /dev/null... a cada 30 minutos (*/30), toda hora (*), todos os dias do mês (*), todos os dias da semana (*).

O "O" em "-O" é a letra maiúscula, não zero, e faz referência a destinação do arquivo resultante (output file), nesse caso "/dev/null" que é um buraco negro e descarta esse resultado. Se você quiser ver o resultado do cron.php, insira a url dele no seu navegador.

Para iniciantes, "EDITOR=nano crontab -e" irá lhe permitir editar o crontab utilizando o editor nano. No Ubuntu o editor padrão já é o nano.

Geralmente, o comando "crontab -e" lhe colocará no editor 'vi'. Você entra em "insert mode" (modo de inserção) pressionando "i", então digite a linha exemplificada acima, depois saia do modo de inserção pressionando ESC. Você salva e sai digitando ":wq", ou sai sem salvar digitando ":q!" (sem as aspas). Aqui uma introdução ao editor 'vi'.

Ver também

Discussões do fórum Using Moodle: