Краткий конспект по проблемам, с которыми сталкивался разворачивая MVC3-сайт на Ubuntu с nginx и Mono. Пост «для себя» чтобы не забыть. В результате будем иметь наш ASP.Net MVC3 сайт работающий на Ubuntu-сервере с фронтэндом в виде nginx и моно запущенным как fcgi-server.
- Ставим последнюю версию Mono wget —no-check-certificate https://github.com/nathanb/iws-snippets/raw/master/mono-install-scripts/ubuntu/install_mono-2.10.sh когда выйдет следующая версия гуглить на тему install_mono.
- Скрипт запуска fcgi-сервера моно копируем в /etc/init.d, копируем monosites.conf. в /etc предварительно изменив в нём путь к папке, где будет лежать ваш MVC-проект (этот файл требуется monoserve’у, путь к нему прописан в нём же, при необходимости можно поменять).
- Настраиваем nginx. Насколько я представляю, это стандартная настройка с использованием fcgi. Пример конфигов factcgi_params и настройка конкретного сайта monosite (лежит в папке sites_enabled)
- Деплоим проект на сервер. Должна получиться следующая структура
/
— App_Code (копируем из проекта, если используем шареные хелперы)
— Views (папка с вьюшками, копируем из проекта)
— bin (папка с бинарниками. копируем из проекта)
— Default.aspx (копируем из примера приложения, см. ниже)
— Web.config (копируем из проекта)
— Global.asax (копируем из проекта) - В MVC проекте ставим CopyLocal=true для библиотек: System.Web.Helpers, System.Web.Mvc, System.Web.Razor, System.Web.WebPages, System.Web.WebPages.Razor, System.Web.WebPages.Deployment. Здесь важен не CopyLocal, а тот факт, чтобы они попали в папку bin на сервере.
- Копируем в папку bin файл Microsoft.Web.Infrastructure из установленной версии Mono (/opt/mono/lib/gac…). Если библиотеки пункта 2 должны быть Майкрософтовские, то эта должна быть Моновская!
- Стартуем моно: /etc/init.d/monoserve start и nginx /etc/init.d/nginx restart. Monoserve выдаст в консоль свои не очень понятные логи, но «взлетели» или нет разобрать можно :)
На этом этапе всё уже должно работать. - Если что-то не работает и непонятно, где ошибка — в установке моно или деплое проекта, то можно скопировать точно работающий проект в ту папку, куда вы деплоите. Перезапустить моно и решить дилему, кто же всё-таки неправ :)
Ниже список возможных ошибок и немного кода
Возможные ошибки:
1) «The view ‘***’ or its master was not found or no view engine supports the searched locations.»
не хватает директив @using во вьюшке. Проверьте наличие недефолтных неймспейсов в Views/Web.Config.
Default.aspx:
<%@ Page Language="C#" AutoEventWireup="true" %><script runat="server" languange="C#">public void Page_Load(object sender, System.EventArgs e) { // Change the current path so that the Routing handler can correctly interpret // the request, then restore the original path so that the OutputCache module // can correctly process the response (if caching is enabled). string originalPath = Request.Path; HttpContext.Current.RewritePath(Request.ApplicationPath, false); IHttpHandler httpHandler = new MvcHttpHandler(); httpHandler.ProcessRequest(HttpContext.Current); HttpContext.Current.RewritePath(originalPath, false); } </script>