Apache не запускается в MAMP (но MySQL работает) в OSX
У меня был MAMP работает в течение нескольких месяцев и недавно установлен PostgreSQL. Он также рекомендовал установить Apache, что я и сделал, чтобы убедиться, что PostgreSQL работает. Затем я удалил PostgreSQL и сборку apache и попытался перезапустить MAMP. Он запустил базу данных MySQL (зеленый свет), но Apache не запустился. Я удалил и переустановил MAMP только для решения той же проблемы.
Apache, похоже, не регистрирует никаких ошибок в папке MAMP, поэтому без каких-либо ошибок доложите, что я не знаю, с чего начать. Я надеюсь, что это связано с тем, что я установил другую версию (и удалил ее), которая вызвала проблему, но я слишком неопытен, чтобы знать, что я сделал.
где я могу найти какие-либо ошибки, если не в папке MAMP? Не в:
- / приложения/MAMP/библиотека / журналы
- / приложения/MAMP/bin / logs
16 ответов
для тех из вас, кто переходит на Yosemite, кажется, есть ошибка, которую я действительно не понимаю, но ее легко исправить, как опубликовано в их учетной записи twitter.
обходной путь для ошибки 10.10 Preview 5: переименуйте файл "envvars", расположенный в" /Applications/MAMP/Library/bin", в "_envvars" (@mamp_en)
у меня была аналогичная проблема и я мог решить ее, запустив в командной строке apachectl, включенный в MAMP:
$ /Applications/MAMP/Library/bin/apachectl start
что приведет
Syntax error on line 427 of /Applications/MAMP/conf/apache/httpd.conf:
Invalid command '\xef\xbf\xbc#AllowOverride', perhaps misspelled or defined by a module not included in the server configuration
это сообщение об ошибке больше нигде не было, ни в одном файле журнала или системной консоли. (Оказывается, я скопировал строку из файла документации, который скопировал некоторые специальные символы, которые не были предназначены для моей системы - как легко это найти!)
Это для MAMP 2.0.1, возможно, он обрабатывается лучше в новая версия.
возможно, это потому, что оригинальный apache включен. Вы пытались увидеть статус ? Вы можете попробовать эту команду, чтобы остановить его "статус apachectl", а затем перезапустить mamp и посмотреть, работает ли он.
Я знаю, что это старый, но в случае если кто-то еще приходит через это. У меня была опечатка в моем файле виртуального хоста (/Applications/MAMP/conf/apache/extra/httpd-vhosts.conf), что заставляло Apache не запускаться. Это было до тех пор, пока я вручную не попытался запустить версию Apache MAMP из командной строки (/Applications/MAMP/bin/startApache.sh
), что я увидел ошибку и смог ее исправить.
в моем случае был неправильный SSL-сертификат на vhost. Чтобы проверить, просто временно отключите ssl от всего вашего ssl vhost и посмотрите, запускается ли он. Примечание: даже если ssl vhost не проверен.
У меня была та же проблема. После большого разочарования из-за отсутствия описательного сообщения об ошибке я понял, что могу проверить журнал "Все сообщения" под приложения/инструменты/системные сообщения (или какой-то аналогичный путь, как я только что перевел с моего языка здесь). Там я нашел объяснение, которое в моем случае означало, что ссылка на библиотеку была нарушена (вероятно, из-за удаления postgres). Я исправил это, воссоздав ссылку. В моем случае это означало, что я должен был выполнить следующую команда в терминале:
sudo ln -s /usr/lib/libpq.5.3.dylib /usr/lib/libpq.5.dylib
и теперь он работает!
Если он в какой-то момент работал нормально, то я думаю, что что-то еще в вашей сети в настоящее время использует тот же порт для чего-то другого.
У меня тоже была эта проблема: в моем случае я изменил порт Apache MAMP по умолчанию с 8888 на 80. Он работал нормально, пока я не установил веб-сервер на другой машине в своей сети и не настроил /etc/hosts на моей локальной машине, чтобы включить новый сервер. Это означало, что порт 80 уже используется, а Apache MAMP не может начать.
решением было либо остановить второй веб-сервер в моей сети, либо вернуть MAMP обратно в 8888. Оба подхода работали нормально.
Командная строка помогает в этом вопросе. как и внизу,
/ приложения/MAMP/библиотека/bin / apachectl start
/ приложения/MAMP/библиотека/bin / apachectl stop
Я просматривал все сообщения Stackoverflow, но не повезло. Наконец, я наткнулся на это: https://www.speakinginbytes.com/2013/02/mamp-problems/
иногда Apache устанавливается через MAMP, чтобы открыть определенную папку, и эта папка больше не существует. Если вы просто пойдете к MAMP и измените это настройка с помощью кнопки настроек вы должны быть в состоянии исправить это.
Что сделал трюк для меня. Надеюсь, это поможет кому-то другому!
1) выйти из MAMP
2) Используйте командную строку для запуска:
$ sudo apachectl restart
3) Откройте MAMP и запустите Apache
4) Apache должен начать на этот раз с любой удачи
моя ситуация заключалась в том, что когда я использовал командную строку для запуска:
$ sudo apachectl stop
ничего не изменилось. И когда я использовал командную строку для запуска:
$ sudo apachectl start
Я получил
httpd (pid 600) already running
я попробовал перезагрузить, а он работал.
чтобы исправить эту конкретную проблему, я переустановил PostgreSQL и Apache build, который пришел с ним, затем я снова установил MAMP, и MAMP работал нормально.
Если ваша htdocs (или эквивалентная) папка хранится на внешнем хранилище, вам может потребоваться подключиться к ней (в finder или с помощью cmd + K) до запуска apache.
У меня была эта проблема, и оказалось, что a .txt-файл, который не был файлом vhosts, каким-то образом был сохранен в my sites-available
папка, которую Apache автоматически включал, и ожидал, что каждый файл будет файлом vhosts.
также убедитесь, что вы не запускаете более старую версию MAMP. Это случилось со мной, когда я использовал spotlight для поиска MAMP. Когда приложение обновляется, оно сохраняет старые копии в папке приложений.