| | 1 | = [wiki:UserGuide Przewodnik użytkownika] > Tytuł - identyczny z linkiem z działu = |
| | 2 | |
| | 3 | === Automatyczna synchronizacja przy wykorzystaniu zaplanowanych zadań === #crontab |
| | 4 | |
| | 5 | 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). |
| | 6 | |
| | 7 | '''Konfiguracja środowiska''' |
| | 8 | |
| | 9 | Zanim zostanie utworzone pierwsze zadanie - system trzeba przygotować do uruchamiania skryptu '''CronRunner.php'''. |
| | 10 | W tym celu w systemie linux należy dodać odpowiedni wpis do pliku {{{/etc/crontab}}} |
| | 11 | {{{ |
| | 12 | */1 * * * * www-data cd /home/edokumenty/public_html/apps/edokumenty && php -f CronRunner.php >> /var/log/cronrunner.log |
| | 13 | }}} |
| | 14 | |
| | 15 | Natomiast w systemie Windows można utworzyć zadanie w systemowym panelu Harmonogram Zadań lub też wykonać z lini poleceń (cmd) komendę: |
| | 16 | {{{ |
| | 17 | schtasks /create /sc co_minutę /mo 5 /tn "CronRunner" /tr "php -f C:\Program Files\BetaSoft\eDokumenty\CronRunner.php" |
| | 18 | }}} |
| | 19 | |
| | 20 | 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. |
| | 21 | W tym celu należy przejść na konto użytkownika www-data: |
| | 22 | {{{ |
| | 23 | su - www-data |
| | 24 | }}} |
| | 25 | |
| | 26 | [[Image(dodatkowe_003.png)]][[BR]]''Rys. 4.''[[BR]] |
| | 27 | |
| | 28 | Jeżeli uruchomi się powłoka sh należy wykonać polecenie: |
| | 29 | {{{ |
| | 30 | bash |
| | 31 | }}} |
| | 32 | |
| | 33 | [[Image(dodatkowe_004.png)]][[BR]]''Rys. 5.''[[BR]] |
| | 34 | |
| | 35 | Będąc w powłoce bash należy wykonać polecenie: |
| | 36 | |
| | 37 | {{{ |
| | 38 | cd /home/edokumenty/public_html/apps/edokumenty && php -f CronRunner.php >> /var/log/cronrunner.log |
| | 39 | }}} |
| | 40 | |
| | 41 | 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 |
| | 42 | |
| | 43 | |
| | 44 | Poniższe zrzuty ekranu pokazują typowe problemy napotkane przy uruchamianiu CronRunner-a.: |
| | 45 | |
| | 46 | ''Brak uprawnień do pliku CronRunner.log'' |
| | 47 | [[Image(dodatkowe_005.png)]][[BR]]''Rys. 6.''[[BR]] |
| | 48 | |
| | 49 | 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: |
| | 50 | {{{ |
| | 51 | cd /var/log |
| | 52 | vim CronRunner.log -> następnie w Vimie zapisać pusty plik poleceniem |
| | 53 | :wq |
| | 54 | chmod 664 CronRunner.log |
| | 55 | chown www-data:edokumenty CronRunner.log |
| | 56 | }}} |
| | 57 | |
| | 58 | [[Image(dodatkowe_006.png)]][[BR]]''Rys. 7.''[[BR]] |
| | 59 | |
| | 60 | Testując powinniśmy uzyskać następujący efekt: |
| | 61 | |
| | 62 | [[Image(dodatkowe_007.png)]][[BR]]''Rys. 8.''[[BR]] |
| | 63 | |
| | 64 | Taki widok w konsoli oznacza, że skrypt wykonał się. |
| | 65 | Na wszelki wypadek nalezy spojrzeć do pliku log-a: |
| | 66 | {{{ |
| | 67 | tail /var/log/CronRunner.log |
| | 68 | }}} |
| | 69 | |
| | 70 | W przypadku wystąpienia następującego komunikatu: |
| | 71 | |
| | 72 | [[Image(dodatkowe_008.png)]][[BR]]''Rys. 9.''[[BR]] |
| | 73 | |
| | 74 | Oznacza to, że w pliku {{{/etc/php5/cli/php.ini}}} jest zła konfiguracja. |
| | 75 | Sposób postępowania jest podobny także w przypadkach np. braków rozszerzeń do obsługi innych systemów. |
| | 76 | W celu naprawy sytuacji należy utworzyć link symboliczny do php.ini apache'a, który wiemy, ze jest prawidłowy. |
| | 77 | |
| | 78 | {{{ |
| | 79 | cd /etc/php5/cli/ |
| | 80 | mv php.ini php.ini.bak |
| | 81 | ln -s /etc/php5/apache2/php.ini php.ini |
| | 82 | }}} |
| | 83 | |
| | 84 | [[Image(dodatkowe_009.png)]][[BR]]''Rys. 10.''[[BR]] |
| | 85 | |
| | 86 | Wynikiem tej operacji powinien być log, w którym nie pojawił się żadeń nowy wpis z błędem. |
| | 87 | [[Image(dodatkowe_010.png)]][[BR]]''Rys. 11.''[[BR]] |
| | 88 | |
| | 89 | '''Konfiguracja zadań w systemie eDokumenty''' |
| | 90 | |
| | 91 | Konfigurację automatycznego pobierania przeprowadzamy w oknie mechanizmu BSConnect. Należy przejść na koncie administratora systemu eDokumenty {{{Narzędzia > Połączenia z systemami zewnętrznymi}}}. W otwartym oknie połączęń wybieramy połączenie i klikamy ikonę zaplanowane zadania |
| | 92 | |
| | 93 | [[Image(dodatkowe_011.png)]][[BR]]''Rys. 12. Ikona Zaplanowane Zadania''[[BR]] |
| | 94 | |
| | 95 | W otwartym oknie widać wszystkie dotychczas skonfigurowane akcje z podziałem na typy obiektów synchronizacji. |
| | 96 | |
| | 97 | [[Image(dodatkowe_012.png)]][[BR]]''Rys. 13. Skonfigurowane akcje''[[BR]] |
| | 98 | |
| | 99 | W oknie tym należy wybrać akcję i kliknąć przycisk nowy. Pojwai się okno, w którym wpisujemy własną nazwę zdarzenia oraz ustawiamy czas, kiedy ma się wykonywać operacja. |
| | 100 | |
| | 101 | [[Image(dodatkowe_013.png)]][[BR]]''Rys. 14. Konfiguracja zaplanowanego zadania dla wybranej akcji ''[[BR]] |
| | 102 | |
| | 103 | Po skonfigurowaniu i zapisaniu w oknie Zaplanowanych zadań przy akcji pojawi się ikona zaplanowanego zadania. |
| | 104 | |
| | 105 | [[Image(dodatkowe_014.png)]][[BR]]''Rys. 15. Zaplanowane zadanie dla akcji''[[BR]] |