关键词:ubuntu,mono,.Net framework 4.5,asp.net mvc 4,Entityframework 6,Mysql

  1. Mono安装

参考文章:

Install Mono on Linux | Mono

http://www.mono-project.com/docs/getting-started/install/linux/

sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 3FA7E0328081BFF6A14DA29AA6A19B38D3D831EF

echo"deb http://download.mono-project.com/repo/debian wheezy main" | sudo tee /etc/apt/sources.list.d/mono-xamarin.list

sudo apt-get install mono-complete

mono -V

mono运行时环境安装成功。

  1. Jexus

Jexus V5.5.3 使用问答- Linux DotNET程序员大本营

http://www.linuxdot.net/bbsfile-3500

  1. 安装

sudo wget http://www.linuxdot.net/down/jexus-5.6.3.tar.gz

sudo tar -zxvf jexus-5.6.3.tar.gz

cd jexus-5.6.3

sudo ./install

  1. 启动服务

启动:sudo /usr/jexus/jws start
停止:sudo /usr/jexus/jws stop
重启:sudo /usr/jexus/jws restart
重启指定网站:sudo /usr/jexus/jws restart siteName
停止指定网站:sudo /usr/jexus/jws stop siteName

首先得建"网站配置文件",在/usr/jexus/siteconf中的每一个文件都是一个网站的配置文件,每一个配置文件就代表一个网站。

  1. 安装

jexus后,在/usr/jexus/site配置

ocnf中,就已经有一个默认的网站配置文件,文件名叫"default"。

你可以修改这个配置文件,也可以将这个配置文件复制并修改为一个新站。

配置文件中,有关键的三项是必填项:

port:端口号定义

root:虚拟根路径和物理根路径的定义

hosts:域名定义

端口号(port)是一个整数,一般是80,也可以是65535以下的其它整数,但这个端口号必须没有其它服务程序占用。

根路径(root)由两部分组成,中间用空格分开。空格前表示这个网站访问时的虚拟根路径(一般都是"/"),空格后是存放这个网站内容的文件夹的物理路径(比如"/var/www/default")。

域名(hosts),填写访问这个网站的域名,如果有多个域名,域名间就英文逗号分开,同时还可以用"泛域名",比如"*.mysite.com"。

网站名:jexus把网站配置文件的名称,作为网站名。

** 强调,网站配置文件名,不能有空格,第一个字符不能是"~"。

用 sudo /usr/jexus/jws restart,即可生效。
当然,更可以用 sudo /usr/jexus/jws restart siteName格式,指定需重启的网站。

  1. 测试

在/var/www/default文件件新建default.html.

在浏览器输入:

http://{server ip}/default.html

正常显示,就表示web服务器安装成功。

  1. Mysql

    1. 安装

sudo apt-get install mysql-server mysql-client

  1. 启动服务

sudo start mysql

#手动的话这样启动

  1. 创建测试数据库

Create database demo

GO

CREATE TABLE `User` (

`UserId` int(11) NOT NULL AUTO_INCREMENT,

`UserName` varchar(20) DEFAULT NULL,

`Password` varchar(50) DEFAULT NULL,

`Email` varchar(20) DEFAULT NULL,

`Birthday` datetime DEFAULT NULL,

PRIMARY KEY (`UserId`)

) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=latin1

GO

  1. Asp.net mvc

    1. 环境

Vs.net 2013

Asp.net mvc 4(注意,其他版本没测试,貌似mvc4比较稳定,后期测试)

EntityFramework 6

Mysql 6

  1. 新建工程

如果使用vs.net 默认模板,建议选择asp.net mvc 4模板,也可以建空网站使用nuget 自己添加dll。

.Net framework 选择4.5.

  1. 发布测试默认站点

使用WinScp上传至默认站点。

注意:删除Microsoft.Web.Infrastructure.dll,System.Net.Http.Formatting.dll

重新打开:http://{serverip}/

能正常运行恭喜,你运气不错。

错误排查,一般mono出错,大部分问题处在dll上,mono没有实现或者有另外的实现,需要替换为mono的dll。

例如,以下问题:

System.InvalidProgramException

Invalid IL code in System.Net.Http.Headers.MediaTypeHeaderValue:.ctor (string): method body is empty.

Description: HTTP 500.Error processing request.

Details: Non-web exception. Exception origin (name of application or object): System.Net.Http.Formatting.

Exception stack trace:

Version Information: 3.2.3 ((no/8d3b4b7 Tue Sep 23
14:47:41 IST 2014); ASP.NET Version: 4.0.30319.17020

据错误提示就知System.Net.Http.Formatting.dll有问题。

  1. 检查bin目录是否缺少dll。
  2. Ubuntu中执行find / | grep System.Net.Http.Formatting.dll

在mono中已经有此实现,直接删除。

遇到问题就根据这种方式排查,可以解决绝大部分问题。

  1. 安装Mysql connect

http://cdn.mysql.com/Downloads/MySQLInstaller/mysql-installer-web-community-5.6.22.0.msi

  1. Nuget 安装EntityFramework 6

Install-Package EntityFramework

在命令行中输入。

  1. Nuget 安装Mysql Entity

Install-Package MySql.Data.Entity

安装完成后,引用里面会出现Mysql程序及,web.config会出现EntityFramework的Mysql驱动。

  1. 新建EntityFramework连接

EntityFramework自动生成Mysql连接。

完整web.config参考如下:

<?xml
version="1.0"?>

<!--

有关如何配置 ASP.NET 应用程序的详细信息,请访问

http://go.microsoft.com/fwlink/?LinkId=152368

-->

<configuration>

<configSections>

<section
name="entityFramework"
type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
requirePermission="false"/>

</configSections>

<connectionStrings>

<add
name="DataEntities"
connectionString="metadata=res://*/Models.DataModel.csdl|res://*/Models.DataModel.ssdl|res://*/Models.DataModel.msl;provider=MySql.Data.MySqlClient;provider connection string=&quot;server=192.168.10.X;user id=XX;password=XX;persistsecurityinfo=True;database=demo&quot;"
providerName="System.Data.EntityClient"/>

</connectionStrings>

<appSettings>

<add
key="webpages:Version"
value="2.0.0.0"/>

<add
key="webpages:Enabled"
value="false"/>

<add
key="PreserveLoginUrl"
value="true"/>

<add
key="ClientValidationEnabled"
value="true"/>

<add
key="UnobtrusiveJavaScriptEnabled"
value="true"/>

</appSettings>

<!--

有关 web.config 更改的说明,请参见 http://go.microsoft.com/fwlink/?LinkId=235367。

可在 <httpRuntime> 标记上设置以下特性。

<system.Web>

<httpRuntime targetFramework="4.5" />

</system.Web>

-->

<system.web>

<customErrors
mode="Off"/>

<httpRuntime
targetFramework="4.5" />

<compilation
debug="true"
targetFramework="4.5"/>

<!--<authentication mode="Forms">

<forms loginUrl="~/Account/Login" timeout="2880" />

</authentication>-->

<pages
controlRenderingCompatibilityVersion="4.0">

<namespaces>

<add
namespace="System.Web.Helpers"/>

<add
namespace="System.Web.Mvc"/>

<add
namespace="System.Web.Mvc.Ajax"/>

<add
namespace="System.Web.Mvc.Html"/>

<add
namespace="System.Web.Optimization"/>

<add
namespace="System.Web.Routing"/>

<add
namespace="System.Web.WebPages"/>

</namespaces>

</pages>

<!--

If you are deploying to a cloud environment that has multiple web server instances,

you should change session state mode from "InProc" to "Custom". In addition,

change the connection string named "DefaultConnection" to connect to an instance

of SQL Server (including SQL Azure and SQL Compact) instead of to SQL Server Express.

-->

</system.web>

<system.webServer>

<validation
validateIntegratedModeConfiguration="false"/>

<modules
runAllManagedModulesForAllRequests="true"/>

<handlers>

<remove
name="ExtensionlessUrlHandler-ISAPI-4.0_32bit"/>

<remove
name="ExtensionlessUrlHandler-ISAPI-4.0_64bit"/>

<remove
name="ExtensionlessUrlHandler-Integrated-4.0"/>

<add
name="ExtensionlessUrlHandler-ISAPI-4.0_32bit"
path="*."
verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS"
modules="IsapiModule"
scriptProcessor="%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll"
preCondition="classicMode,runtimeVersionv4.0,bitness32"
responseBufferLimit="0"/>

<add
name="ExtensionlessUrlHandler-ISAPI-4.0_64bit"
path="*."
verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS"
modules="IsapiModule"
scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll"
preCondition="classicMode,runtimeVersionv4.0,bitness64"
responseBufferLimit="0"/>

<add
name="ExtensionlessUrlHandler-Integrated-4.0"
path="*."
verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS"
type="System.Web.Handlers.TransferRequestHandler"
preCondition="integratedMode,runtimeVersionv4.0"/>

</handlers>

</system.webServer>

<runtime>

<assemblyBinding
xmlns="urn:schemas-microsoft-com:asm.v1">

<dependentAssembly>

<assemblyIdentity
name="System.Web.Helpers"
publicKeyToken="31bf3856ad364e35"/>

<bindingRedirect
oldVersion="1.0.0.0-2.0.0.0"
newVersion="2.0.0.0"/>

</dependentAssembly>

<dependentAssembly>

<assemblyIdentity
name="System.Web.Mvc"
publicKeyToken="31bf3856ad364e35"/>

<bindingRedirect
oldVersion="1.0.0.0-4.0.0.0"newVersion="4.0.0.0"/>

</dependentAssembly>

<dependentAssembly>

<assemblyIdentity
name="System.Web.WebPages"
publicKeyToken="31bf3856ad364e35"/>

<bindingRedirect
oldVersion="1.0.0.0-2.0.0.0"
newVersion="2.0.0.0"/>

</dependentAssembly>

<dependentAssembly>

<assemblyIdentity
name="WebGrease"
publicKeyToken="31bf3856ad364e35"/>

<bindingRedirect
oldVersion="0.0.0.0-1.3.0.0"
newVersion="1.3.0.0"/>

</dependentAssembly>

<dependentAssembly>

<assemblyIdentity
name="System.Net.Http"
publicKeyToken="b03f5f7f11d50a3a"
culture="neutral"/>

<bindingRedirect
oldVersion="0.0.0.0-4.0.0.0"
newVersion="4.0.0.0"/>

</dependentAssembly>

<dependentAssembly>

<assemblyIdentity
name="EntityFramework"
publicKeyToken="b77a5c561934e089"
culture="neutral"/>

<bindingRedirect
oldVersion="0.0.0.0-6.0.0.0"
newVersion="6.0.0.0"/>

</dependentAssembly>

</assemblyBinding>

</runtime>

<system.data>

<DbProviderFactories>

<remove
invariant="MySql.Data.MySqlClient"/>

<add
name="MySQL Data Provider"
invariant="MySql.Data.MySqlClient"
description=".Net Framework Data Provider for MySQL"
type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.9.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"/>

</DbProviderFactories>

</system.data>

<entityFramework>

<defaultConnectionFactory
type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">

<parameters>

<parameter
value="v11.0"/>

</parameters>

</defaultConnectionFactory>

<providers>

<provider
invariantName="System.Data.SqlClient"
type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/>

<provider
invariantName="MySql.Data.MySqlClient"
type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.9.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"/>

</providers>

</entityFramework>

</configuration>

注意黄色背景的配置。

  1. 新建Mysql测试代码

直接在Index中对Mysql进行数据保存。

public ActionResult Index()

{

//todo test

UserServices.Save(new User()

{

UserName = "admin",

Password = Guid.NewGuid().ToString(),

Email = "ss@ss.com",

Birthday = DateTime.Now

});

return View();

}

public static void Save(User user)

{

using (var provider = new DataEntities())

{

provider.User.Add(user);

provider.SaveChanges();

}

}

  1. 使用Vs。net 发布

参考4.3章节排除问题。

运行成功。

  1. FAQ

    1. 问题排除

find / | grep System.Net.Http.Formatting.dll

  1. 参考bin程序集清单

Ubuntu 环境 运行Asp.net mvc +EntityFramework+ Mysql的更多相关文章

  1. Mono 4.0 Mac上运行asp.net mvc 5.2.3

    Mono 4.0 已经发布,二进制包已经准备好,具体的发布说明参见:http://www.mono-project.com/docs/about-mono/releases/4.0.0/. 今天在Ma ...

  2. Asp.Net MVC +EntityFramework主从表新增编辑操作的实现(删除操作怎么实现?)

    Asp.Net MVC +EntityFramework主从表新增编辑操作的实现 对于MVC中同时对主从表的表单操作在网上现有的解决很少,而这样的操作在做业务系统中是经常为遇到的.我在网上搜索了很久都 ...

  3. asp.net mvc entityframework sql server 迁移至 mysql方法以及遇到的问题

    背景: 我原来的项目是asp.net mvc5 + entityframework 6.4 for sql server(localdb,sql server),现在需要把数据库切换成mysql,理论 ...

  4. 在Ubuntu13.04中配置Jexus+Mono3.2运行Asp.Net Mvc 4站点 (一)

    这篇文章打算分两部分来写,第一部分介绍在Ubuntu中安装和配置.Net Framework4.5环境,第二部分介绍如何部署Asp.Net Mvc 4站点并确保Mvc4的几个重要特性都能正常工作. 一 ...

  5. ASP.Net MVC连接MySQL和Code First的使用

    首先要准备一下的工具作为环境 MySQL Community Server 5.7.x My Workbench 6.3 VS2017 新建一个项目,NetMySQLCodeFirst 选择MVC,再 ...

  6. 使用asp.net mvc + entityframework + sqlServer 搭建一个简单的code first项目

    步骤: 1. 创建一个asp.net mvc 项目 1.1 项目创建好结构如下 2 通过vs安装EntityFramework框架 install-package entityframework 3. ...

  7. Linux 安装Mono环境 运行ASP.NET(一)

    1.先看一下Linux环境下面请求的过程,(画的不是很好,简单的了解一下原理.) .NET跨平台其实需要这三个关键:编译器.CLR和基础类库.在.NET下我们编写一个最简单的"Hello W ...

  8. Linux 安装Mono环境 运行ASP.NET(二)

    一.安装libgdiplus     前面我们已经安装了apr.apr_util.pcre和httpd apache .现在我们来安装libgdiplus Libgdiplus是一个Mono库,用于对 ...

  9. ubuntu中下运行asp.net程序

    首先在ubuntu下面是不能直接运行VISUAL STUTIO的,必须借助mono开发工具和xsp4.0.那我们就来看一下在ubuntu的电脑中怎么安装这两个工具. 首先安装mono,打开终端,输入a ...

随机推荐

  1. Direct3D11学习:(七)绘图基础——彩色立方体的绘制

    转载请注明出处:http://www.cnblogs.com/Ray1024 一.概述 在前面的几篇文章中,我们详细介绍了Direct3D渲染所需要的数学基础和渲染管道理论知识.从这篇文章开始,我们就 ...

  2. Android 学习笔记之AndBase框架学习(一) 实现多功能标题栏

    PS:Volley框架终于通过看源码的方式完成了所有的学习..开始学习AndBase...AndBase的源码实在是多的离谱...因此就不对所有的源码进行分析了... 学习内容: 1.使用AndBas ...

  3. CentOS6.5菜鸟之旅:VirtualBox4.3识别USB设备

    一.前言 VirtualBox默认是不能识别USB设备的,但可以通过Oracle VM VirtualBox Extension Pack来增强VirtualBox的功能,增强的功能如下: 1. US ...

  4. Tools Function

    public static void TraceLog(string message, string logFileName) { string tmppath = AppDomain.Current ...

  5. 以神经网络使用为例的Matlab和Android混合编程

    由于需要在一个Android项目中使用神经网络,而经过测试发现几个Github上开源项目的训练效果就是不如Matlab的工具箱好,所以就想在Android上使用Matlab神经网络代码(可是...) ...

  6. 第二sprint总结

    总结:在第二轮sprint中,团队的开发工作出现了极大的懈怠,团队成员分配的工作完成情况较差,进度较慢,希望能在最后一周中,完成预定的功能模块 个人贡献分: 124陈彦生:22=20*5*22% 14 ...

  7. 0406.复利计算器5.0版-release

    复利计算器5.0-release 目录 项目简介 Github链接推送 客户需求 新增需求分析 项目设计 效果演示 操作说明 程序结构 结对分工 合作照片 总结 1.项目简介 项目名称:复利计算器 目 ...

  8. 文本对象模型(Document Object Model)

    本文内容: 1. 概述 2. DOM中的节点类型 3. DOM节点的选取 4. 存取元素属性 5.DOM元素的增删 6.小结 ★ 概述 文本对象模型(DOM)是一个能够让程序和脚本动态访问和更新文档内 ...

  9. 返璞归真 asp.net mvc (13) - asp.net mvc 5.0 新特性

    [索引页][源码下载] 返璞归真 asp.net mvc (13) - asp.net mvc 5.0 新特性 作者:webabcd 介绍asp.net mvc 之 asp.net mvc 5.0 新 ...

  10. SQL Server性能影响的重要结论

    第一次访问数据会比接下来的访问慢的多,因为它要从磁盘读取数据然后写入到缓冲区: 聚合查询(sum,count等)以及其他要扫描大部分表或索引的查询需要大量的缓冲,而且如果它导致SQL Server从缓 ...