Я настраиваю Drupal Open Atrium и на полпути к настройке получаю сообщение об ошибке:
Для использования OpenAtrium должны быть доступны и разрешены чистые URL-адреса.
https://www.drupal.org/docs/7/configuring-clean-urls/enable-clean-urls говорит мне бежать sudo a2enmod rewrite
, что происходит:
Enabling module rewrite.
To activate the new configuration, you need to run:
service apache2 restart
но когда я бегу sudo service apache2 restart
Я получаю следующую ошибку:
Job for apache2.service failed because the control process exited with error code.
See "systemctl status apache2.service" and "journalctl -xe" for details.
systemctl status apache2.service
возвращает:
● apache2.service - LSB: Apache2 web server
Loaded: loaded (/etc/init.d/apache2; bad; vendor preset: enabled)
Drop-In: /lib/systemd/system/apache2.service.d
└─apache2-systemd.conf
Active: failed (Result: exit-code) since Mon 2017-04-03 18:21:04 UTC; 7s ago
Docs: man:systemd-sysv-generator(8)
Process: 11268 ExecStop=/etc/init.d/apache2 stop (code=exited, status=0/SUCCESS)
Process: 11345 ExecStart=/etc/init.d/apache2 start (code=exited, status=1/FAILURE)
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: *
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: * The apache2 configtest failed.
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: Output of config test was:
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: apache2: Syntax error on line 140 of /etc/apache2/apache2.conf: Syntax error on line 1 of /etc/apache2/mods-enabled/rew
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: Action 'configtest' failed.
Apr 03 18:21:04 ip-172-31-31-251 apache2[11345]: The Apache error log may have more information.
Apr 03 18:21:04 ip-172-31-31-251 systemd[1]: apache2.service: Control process exited, code=exited status=1
Apr 03 18:21:04 ip-172-31-31-251 systemd[1]: Failed to start LSB: Apache2 web server.
Apr 03 18:21:04 ip-172-31-31-251 systemd[1]: apache2.service: Unit entered failed state.
Apr 03 18:21:04 ip-172-31-31-251 systemd[1]: apache2.service: Failed with result 'exit-code'.
Проблема решается с помощью a2dismod rewrite
, но потом я вернулся к тому, с чего начал.
Мой /etc/apache2/mods-enabled/rewrite.load
выглядит вот так, если в этом проблема.
LoadModule rewrite_module modules/mod_rewrite.so
Как заставить мод перезаписи работать с apache?
Это было окончательно решено с помощью sudo apache2ctl graceful
и следуя ссылкам на файлы из сообщений об ошибках, например:
apache2: Syntax error on line 140 of /etc/apache2/apache2.conf: Syntax error on line 1 of /etc/apache2/mods-enabled/rewrite.load: LoadModule takes two arguments, a module name and the name of a shared object file to load it from
Action 'graceful' failed.
The Apache error log may have more information.
В итоге удалил AddModule mod_rewrite.c
из rewrite.load
это было предложено Drupal, и изменил ссылку с modules/mod_rewrite.so
к /usr/lib/apache2/modules/mod_rewrite.so
где оно было на самом деле (найдено с помощью sudo find / -name mod_rewrite.so
)
Затем я перезапустил apache, и все заработало!