Ir para conteúdo
  • 0
Shinchila_Matadora

Função CRON no servidor

Pergunta

Pessoal, estou precisando executar um arquivo .php dentro de um servidor todos os dias da semana as 13, exceto sábado e domingo.
Alguém sabe qual o comando que devo dar para que isso seja possível?

E além disso, tem alguma forma de visualizar as funções CRON que eu inputar no servidor?
Estou começando agr e preciso de ajuda.
Obrigado!

Compartilhar este post


Link para o post
Compartilhar em outros sites

12 respostas a esta questão

Recommended Posts

  • 1
Em 08/09/2017 at 10:47, Shinchila_Matadora disse:

Quero que execute de segunda a sexta em 3 horários diferentes
15:29, 15:30 e 15:31.

29-31 15 * * 1-5 /usr/bin/php /path/para/o/arquivo.php >/dev/null 2>&1

 

Significa: todos os minutos de 29 até 31, à partir das 15 horas, de segunda à sexta-feira.

  • +1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 2
0 13 * * 1-5 /usr/bin/php /path/para/o/arquivo.php >/dev/null 2>&1

Significa: às 13 horas de segunda à sexta-feira.

 

;)

  • +1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 1

1 - você precisa colocar o arquivo que você quer executar em alguma pasta que posse ser lida pelo apache.
2 - Indicar as coisas que devem ser feitas e as condições ao CRON, e apontar o CRON pra abrir o arquivo em um navegador.
 

Essa abertura pode ser feita de duas formas:

 

1 - Indicar para o cron abrir o navegador e acessar a url.

2 - Criar um atalho que abra direto o navegador na url em questão, e indicar para o CRON trigerar esse atalho.

 

Para visualizar os comandos atuais se não me engano é 'contrab -l'.
 

Eu preciso fazer um negócio parecido, mas ainda não fiz, mas acredito que seja esse o caminho.

  • +1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 1

@Shinchila_Matadora da uma olhada aqui, foi bem mais simples do que eu tinha imaginado.


Para abrir

Citar

contrab -e


Esse executa todo dia as 19 horas a rotina que verifica as modificações e faz um backup diário.
Citar

00 19 * * * /var/www/routines/backup-modified.php

 

 

E essa chama um arquivo que faz o backup completo toda sexta feira as 20 horas, e armazena num local separado.

 

Citar

00 20 * * 5 /var/www/routines/dump-all-structure-and-data.php

 

Não testei 100%, mas é basicamente só isso.

 

A lógica do crontab é:

 

*  *  *  * * /caminho/objeto.formato

 

1 ° *  => Minutos

2 ° *  => Hora

3 ° *  => Dia do mês

4 ° * => Mês (1-12)

5 ° * => Dia da semana (0 dom, 6 sab)

 

E no final vai o caminho para o que deve ser executado.

 

PS: Eu rodo isso direto no servidor com pacote LAMP, então ele ja le automatico, se você usar um pacote como o XAMPP não sei dizer se ele vai ler só executando, mas acredito que sim, exceto se você substituiu o apache nativo ( e também depende de qual distro você usa, eu uso Debian 7).

  • +1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0

AnthraxisBR, obrigado por responder.
 

Pelo oq eu pesquisei aqui, eu teria que dar 5 comando diferentes(Um pra cada dia útil  da semana) pra executar o meu arquivo de segunda a sexta. Minha grande dúvida é se tem como fazer isso com um único comando.
E obrigado pela segunda resposta.

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0

@AnthraxisBR Obrigado pela resposta cara, já me deu uma luz imensa.

Mas ainda estou com um porém. Dessa forma que é feita, eu teria que criar uma função CRON para cada dia da semana exceto sábado e domingo.
Existe alguma forma de escrever isso que faça com que ele execute o arquivo todos os dias 'exceto' sábado e domingo?

 

Essa é minha grande questão

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • 0
Em 05/09/2017 at 12:52, João Batista Neto disse:

0 13 * * 1-5 /usr/bin/php /path/para/o/arquivo.php >/dev/null 2>&1

Significa: às 13 horas de segunda à sexta-feira.

 

;)

Obrigado, era isso que eu queria.

Mas vou apertar um pouco mais kkk

Quero que execute de segunda a sexta em 3 horários diferentes
15:29, 15:30 e 15:31.
Tem como fazer isso num único comando?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por capaldi
      <?php
      if(isset($_GET['deletar']) && $_GET['deletar'] == 'sim'):
          $id_produto = (int)$_GET['produto'];
          $pegar_dados_produto = BD::conn()->prepare("SELECT img_padrao FROM loja_produtos WHERE id = ?");
          $pegar_dados_produto->execute(array($idProduto));
          $dadosProd = $pegar_dados_produto->fetchObject();
          
          $verificar_imagens = BD::conn()->prepare("SELECT * FROM loja_imgprod WHERE id_produto = ?");
          $verificar_imagens->execute(Array($idProduto));
          
          if($verificar_imagens->rowCount() == 0){
              if(unlink('../../produtos/'.$dadosProd->img_padrao)){
                  $deletar_produto =BD::conn()->prepare("DELETE FROM loja_produtos WHERE id = ?");
                  if($deletar_produto->execute(array($IdProduto))){
                      echo'<script>alert("Produto excluido com sucesso!");location.href"index.php?pagina=editarProdutos</script>';    
                  }
                  
              }
              
          }else{
              while($dadosImagenm = $verificar_imagens->fetchObject()){
                  unlink('../../produtos/'.$dadosImagem->img);
              }
              if(unlik('../../produtos/'.$dadosProd->img_padrao)){
                  $deletar_produto = BD::conn()->prepare("DELETE FROM loja_produtos WHERE id = ?");
                  if($deletar_produto->execute(array($idproduto))){
                      echo'<script>alert("Produto excluido com sucesso!");location.href"index.php?pagina=editarProdutos</script>';
                  }
              }
          }
      endif;
      ?>
       
      Ola, estou tabalhando com esse script, e não consigo resolver esse problema alguém pose me ajudar?
    • Por mateumt15
      Estou com o trecho de codigo abaixo, mas quando tento mostrai isto em uma tabela ele sempre pula a primeira linha do banco. 
      <?php $servername = "127.0.0.1";
              $username = "root";
              $password = "12345678";
              $dbname = "mydb";
              $conn = new mysqli($servername, $username, $password, $dbname);
              $sql = ("select id_link,link,data_inicio,data_fim,acao,dominio from link");
              $result = $conn->query($sql);
              $row = $result->fetch_assoc();
             
              while ($row = $result->fetch_assoc()):
                  echo "<tr>";
                  echo"<td>";echo $row['id_link'];echo "</td>";
                  echo"<td>";echo $row['link'];echo "</td>";
                  echo"<td>";echo $row['data_inicio'];echo "</td>";
                  echo"<td>";echo $row['data_fim'];echo "</td>";
                  if($row['acao']==='0')
                  {
                      echo"<td>";echo 'Bloqueado';echo "</td>";
                  }
                  if($row['acao']==='1')
                  {
                      echo"<td>";echo 'Permitido';echo "</td>";
                  }
                  if($row['dominio']==='0')
                  {
                      echo"<td>";echo 'URL';echo "</td>";
                  }
                  if($row['dominio']==='1')
                  {
                      echo"<td>";echo 'Dominio';echo "</td>";
                  }
              endwhile;
              $conn->close();
      ?>
    • Por patriciahelena
      Boa noite,
       
      Preciso de ajuda.
      No arquivo form.php tenho 3 inputs de entrada(valor1, valor2, valor3) e 3 inputs(disabled) que receberão os valores calculados do arquivo form_matematico5.php.
      Na tag form onsubmit="return calcula()"
       
          <h4 class="calcula"></h4>
       
      <script>
      function calcula($volmedio, $temp, $precogas) {
      $.get("form_matematico5.php", $('#calculorecovap').serialize(),
          function(data){
              $('.calcula').html(data);
          }
      );
      return false;
      }
      </script>
       
       
      No arquivo form_matecatico5.php é feito os calculos gerando 3 valores. 
      Tenho um echo:
      echo 'texto<br><div style=font-size:23px;color:red;>' . number_format($Resultado1,0,",","."). '</div> <br> texto<br><div style=font-size:23px;color:red;>'. number_format($Resultado2,0,",","."). '</div> <br>texto<br><div style=font-size:23px;color:red;>R$ '. number_format($Resultado3,2,",","."). '</div>';
       
      Ele retorna o echo certinho em     <h4 class="calcula"></h4>.
      Mas o que eu quero mesmo é que Resultado1 retorne dentro do primeiro input(disabled), o Resultado2 dento do segundo input(disabled) e assim com o terceiro. Ou seja,
      Cada input(disabled), recebera um valor diferente e não o total de .calcula.
       
      Espero ter explicado direitinho,
      Obrigada
       
       
       
       
       
       
       
    • Por luisfeliperm2
      Estou criando um sistema de login e cadastro de um jogo em php. Conectei ao postgresql e agora estou com um problema. Preciso saber qual criptografia é utilizada. Todas as hashs possuem 32 caracteres e por isso pensei que fosse MD5. Mas não é.
      password - > 62f9f2022536274b47f4daa0887361cf
      teste1 -> deaafc806aef00d0262e098ff089fff1
      Outras senhas criptografadas:
      59a93faaaf6d43ca4c3ef9ec183200ea
      47d163c4e9388dfd4b2dc7c327a33761
      8dffc56f2382d0f5552c04d9fa014d0e
    • Por raphael123
      Estou tentando realizar um insert no banco e está ocorrendo esse erro ao clicar em salvar. Poderiam me ajudar a solucionar esse problema, estou utilizando a linguagem PHP, segue o erro e meu código abaixo.
       


       
      <?php 
       
      $ieqbairro = $_POST['ieqbairro'];
      $pastor = $_POST['pastor'];
      $lider = $_POST['lider'];
      $celulaAtivas = $_POST['celulasativas'];
      $participantes = $_POST['participantescelulas'];
      $quantidade = $_POST['quantidadereunioes'];
      $quantmensais = $_POST['quantidadeensaiosmensais'];
      $diaensaio = $_POST['diaensaio'];
      $hora = $_POST['horaensaio'];
      $totalmenbrosminis = $_POST['totalmembrosdepartamento'];
      $vocal = $_POST['vocal'];
      $mulhercontralto = $_POST['mulhercontralto'];
      $mezzosoprano = $_POST['mezzosoprano'];
      $soprano = $_POST['soprano'];
      $homensbaixo = $_POST['homensbaixo'];
      $baritono = $_POST['baritono'];
      $tenor = $_POST['tenor'];
      $guitarra = $_POST['guitarrista'];
      $baterista = $_POST['bateristas'];
      $tecladista = $_POST['tecladistas'];
      $violao = $_POST['violao'];
      $baixo = $_POST['baixistas'];
      $meialua = $_POST['meialua'];
      $cajon = $_POST['cajon'];
      $outros = $_POST['outros'];
      $ministeriodecarreira = $_POST['ministeriocarreira'];
      $descrinomemstcarreira = $_POST['nomeministeriocarreira'];
      $connect = mysqli_connect('localhost','root','') or die('Erro ao conectar ao banco de dados');
      $db = mysqli_select_db($connect,'1regiao');
      mysqli_set_charset($connect,'utf8');
      $query = mysqli_query($connect,"INSERT INTO tbfichacadadanca (ieqbairro, pastor, lider, celulaAtivas, participantescelulas,
      quantidadecelulas, quantidaensamensal, diaensaio, horaensaio, totalmenbrosminis, vocalquant, mulhercontralto, mulhermezzosoprano, mulhersoprano, homensbaixo, homensbaritono, homenstenor, guitarraqtd, bateristaqtd, tecladistaqtd, violaoqtd, baixoqtd, meialuaqtd, cajonqtd, outros, ministeriodecarreira, descrinomemstcarreira,) VALUES ('$ieqbairro','$pastor','$lider', '$celulaAtivas', '$participantes','$quantidade', '$quantmensais','$diaensaio', '$hora', '$totalmenbrosminis','$vocal', '$mulhercontralto','$mezzosoprano', '$soprano','$homensbaixo', '$baritono','$tenor', '$guitarra','$baterista', '$tecladista','$violao', '$baixo','$meialua', '$cajon','$outros', '$ministeriodecarreira','$descrinomemstcarreira')") or die mysqli_error($query); 
       
      if($query){
             echo"<script language='javascript' type='text/javascript'>alert('Dados Salvos com sucesso!');window.location.href='fichacadastral1regiaodanca.html'</script>";
          }
                
      mysqli_close($connect);
      ?>

×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.