| 88 | ''[#integracja Powrót do menu]'' |
| 89 | |
| 90 | === Automatyczna synchronizacja przy wykorzystaniu zaplanowanych zadań === #crontab |
| 91 | |
| 92 | System eDokumenty pozwala uruchomić zadania synchronizacji automatycznie. Wykorzystuje do tego celu systemowy Harmongram Zadań (w linuksie cron). Mechanizm ten uruchamia skrypt '''CronRunner.php''' w trybie klienta. Skrypt ten odpowiedzialny jest za realizację zadań zapisanych w bazie danych systemu eDokumenty (konkretnie w tabeli crontab). |
| 93 | |
| 94 | '''Konfiguracja środowiska''' |
| 95 | |
| 96 | Zanim zostanie utworzone pierwsze zadanie - system trzeba przygotować do uruchamiania skryptu '''CronRunner.php'''. |
| 97 | W tym celu w systemie linux należy dodać odpowiedni wpis do pliku {{{/etc/crontab}}} |
| 98 | {{{ |
| 99 | */1 * * * * www-data cd /home/edokumenty/public_html/apps/edokumenty && php -f CronRunner.php >> /var/log/cronrunner.log |
| 100 | }}} |
| 101 | |
| 102 | Natomiast w systemie Windows można utworzyć zadanie w systemowym panelu Harmonogram Zadań lub też wykonać z lini poleceń (cmd) komendę: |
| 103 | {{{ |
| 104 | schtasks /create /sc co_minutę /mo 5 /tn "CronRunner" /tr "php -f C:\Program Files\BetaSoft\eDokumenty\CronRunner.php" |
| 105 | }}} |
| 106 | |
| 107 | W tym momencie należy przetestować działanie skryptu. Na systemie Windows należy uruchomić zadanie i sprawdzić w historii pobierania, czy wykonała się synchronizacja. Tutaj oprzemy się o testowaniu na systemie Linux. |
| 108 | W tym celu należy przejść na konto użytkownika www-data: |
| 109 | {{{ |
| 110 | su - www-data |
| 111 | }}} |
| 112 | |
| 113 | [[Image(dodatkowe_003.png)]][[BR]]''Rys. 4.''[[BR]] |
| 114 | |
| 115 | Jeżeli uruchomi się powłoka sh należy wykonać polecenie: |
| 116 | {{{ |
| 117 | bash |
| 118 | }}} |
| 119 | |
| 120 | [[Image(dodatkowe_004.png)]][[BR]]''Rys. 5.''[[BR]] |
| 121 | |
| 122 | Będąc w powłoce bash należy wykonać polecenie: |
| 123 | |
| 124 | {{{ |
| 125 | cd /home/edokumenty/public_html/apps/edokumenty && php -f CronRunner.php >> /var/log/cronrunner.log |
| 126 | }}} |
| 127 | |
| 128 | Po kliknięciu przycisku Enter w konsoli powinna się pojawić standardowa linia ze znakiem zachęty. Jeżeli pokaże sie jakikolwiek komunikat, to znaczy, że coś nie działa |
| 129 | |
| 130 | |
| 131 | Poniższe zrzuty ekranu pokazują typowe problemy napotkane przy uruchamianiu CronRunner-a.: |
| 132 | |
| 133 | ''Brak uprawnień do pliku CronRunner.log'' |
| 134 | [[Image(dodatkowe_005.png)]][[BR]]''Rys. 6.''[[BR]] |
| 135 | |
| 136 | W celu rozwiązania tego problemu należy w odpowiedniej lokalizacji np. w katalogu {{{/var/log/}}} z poziomu użytkownika root utworzyć plik (pusty) i nadać mu odpowiednie uprawnienia: |
| 137 | {{{ |
| 138 | #cd /var/log |
| 139 | #vim CronRunner.log -> następnie w Vimie zapisać pusty plik poleceniem |
| 140 | :wq |
| 141 | |
| 142 | #chmod 664 CronRunner.log |
| 143 | #chown www-data:edokumenty CronRunner.log |
| 144 | }}} |
| 145 | |
| 146 | [[Image(dodatkowe_006.png)]][[BR]]''Rys. 7.''[[BR]] |
| 147 | |
| 148 | Testując powinniśmy uzyskać następujący efekt: |
| 149 | |
| 150 | [[Image(dodatkowe_007.png)]][[BR]]''Rys. 8.''[[BR]] |
| 151 | |
| 152 | Taki widok w konsoli oznacza, że skrypt wykonał się. |
| 153 | Na wszelki wypadek nalezy spojrzeć do pliku log-a: |
| 154 | {{{ |
| 155 | #tail /var/log/CronRunner.log |
| 156 | }}} |
| 157 | |
| 158 | W przypadku wystąpienia następującego komunikatu: |
| 159 | |
| 160 | [[Image(dodatkowe_008.png)]][[BR]]''Rys. 9.''[[BR]] |
| 161 | |
| 162 | Oznacza to, że w pliku {{{/etc/php5/cli/php.ini}}} jest zła konfiguracja. |
| 163 | Sposób postępowania jest podobny także w przypadkach np. braków rozszerzeń do obsługi innych systemów. |
| 164 | W celu naprawy sytuacji należy utworzyć link symboliczny do php.ini apache'a, który wiemy, ze jest prawidłowy. |
| 165 | |
| 166 | {{{ |
| 167 | #cd /etc/php5/cli/ |
| 168 | #mv php.ini php.ini.bak |
| 169 | #ln -s /etc/php5/apache2/php.ini php.ini |
| 170 | }}} |
| 171 | |
| 172 | [[Image(dodatkowe_009.png)]][[BR]]''Rys. 10.''[[BR]] |
| 173 | |
| 174 | Wynikiem tej operacji powinien być log, w którym nie pojawił się żadeń nowy wpis z błędem. |
| 175 | [[Image(dodatkowe_009.png)]][[BR]]''Rys. 10.''[[BR]] |
| 176 | |
| 177 | '''Konfiguracja zadań w systemie eDokumenty''' |