【Step By Step】将Dotnet Core部署到Docker下
一、使用.Net Core构建WebAPI并访问Docker中的Mysql数据库
这个的过程大概与我之前的文章《尝试.Net Core—使用.Net Core + Entity FrameWork Core构建WebAPI(一)》一致。
但是在我们这里,由于docker中无法部署sql server,所以我采用了Mysql数据库,顺便吐槽一下 SQL Server真的太贵了,阿里云的Mysql实例价格和SQL Server实例价格差10倍,真的好夸张。
Mysql官方的EF Core支持刚刚出来,由于文章是后续补充的,在我尝试的时候官方驱动还没有出,所以我使用的是第三方的驱动:Pomelo.EntityFrameworkCore.MySql,据说是国内一个90后的小伙儿写的,非常牛X.
引用之后,就和EF访问SQL Server没有什么区别了,但是:由于我们的Mysql实例是安装在Docker容器中的,那两个Docker容器之间怎么互相通信呢?
首先在启动API Image的时候,需要使用--link 命令,来建立API和Mysql 容器之间的访问通道,大概命令如下:
docker run -it -p : --name testapi --link msyqldb:msyqldb testapi
在Link的时候我们给需要连接的容器起了一个别名,这个别名就是一个主机名一样,可以直接用来访问,这个时候我们的连接字符串就类似于:
Data Source=mysqldb;port=;Initial Catalog=数据库名称;Integrated Security=False;Persist Security Info=False;User ID=用户名;Password=密码
这里,我们的DataSource,也就是实例的名称,就直接写主机名,也就是我们在Link的时候起的那个别名,就OK啦~只要你突破了这点,那访问基本上就没有什么问题了。
Coding 工作结束之后,发布你的API,并且最终打包成Image,启动容器,这一系列过程可以参考我的上一篇文章:《【Step By Step】将Dotnet Core部署到Docker上》
二、使用.Net Core构建一个Web程序并访问Docker中的WebAPI
在Docker中的Web程序访问另外一个Docker容器中的API, 需要解决的问题如下:
1.API的路径是啥?
2.跨域问题
其中第一个问题的解决思路和我们上面连接数据库的解决思路是完全一致的,只要在Link的时候,加上别名,就可以用http://别名:端口号 来访问你的api即可。
第二个问题不仅仅是在docker中会遇到的问题,在平时我们开发Web程序时,也会遇到这样子的问题,常用的解决方案有以下几种:
A.避免用js访问API,而采用后端代码去调用,就没有跨域这一说了
B.后端API HttpHeader增加Access-Control-Allow-Origin:* Access-Control-Allow-Headers:Content-type Access-Control-Allow-Methods:GET, POST, PUT, DELETE, OPTIONS三个选项
C.Jsonp,就是把数据当做一个js文件来加载~
这里我采用方法A来解决跨域问题(简单、暴力、最彻底):
第一步:通过Nuget引用Orion.ApiClientLight类库,这是一个封装了一系列调用api方法的类库,我们可以通过他很方便的调用API并序列化结果
第二步:在Controller中初始化APIClient对象,JsonApiClientLight apiClient = new JsonApiClientLight();
第三步:调用方法来访问API。
下面的代码是我调用一个CRUD的API来访问API的简单实现:
public class HomeController : Controller
{
JsonApiClientLight apiClient = new JsonApiClientLight(); public async Task<IActionResult> Index()
{
var list = await apiClient.GetAsync<List<Member>>("http://jb91api:9103/api/mermbers/mermber/list");
return View(list.Response);
} [HttpGet]
public IActionResult Create()
{
return View();
} [HttpPost,ActionName("Create")]
public async Task<IActionResult> CreatePost(CreateMember model)
{
if(ModelState.IsValid)
{
var member = await apiClient.PostAsync("http://jb91api:9103/api/mermbers/mermber/", model);
return RedirectToAction("Index");
}
return View(model);
} public async Task<IActionResult> Delete(int id)
{
if (id > )
{
await apiClient.DeleteAsync("http://jb91api:9103/api/mermbers/mermber?id=" + id.ToString());
}
return RedirectToAction("Index");
}
}
【Step By Step】将Dotnet Core部署到Docker下的更多相关文章
- 【Step By Step】将Dotnet Core部署到Docker上
本教程的前提是,你已经在Linux服务器上已经成功的安装了Docker,我会大概介绍在此过程中用到的Docker命令,并不会介绍所有的Docker命令(因为我也不会). 一.在Docker中运行Dot ...
- 【Step By Step】将Dotnet Core部署到Docker(中)
在Docker中运行MySql MySQL 官方也提供了各种版本的MySQL Image来供用户使用,我们可以使用如下命令来创建并运行一个MySQL Image: docker run -it -p ...
- .NET core 部署到Docker +Docker Protainer管理实现
.NET core 部署到Docker +Docker Protainer管理实现 上次说到将.net core的应用程序发布到Linux中(https://www.cnblogs.com/Super ...
- dotnet core部署方式两则:CLI、IIS
最近在使用dotnet core研究整个开发过程,使用下面两种方式部署: 一,使用 dotnet run 命令运行 在项目路径,shift+右键,选择 “在此处打开命令窗口”,在CMD窗口中运行“do ...
- Linux下将.Asp Core 部署到 Docker容器中
我们来部署一个简单的例子: 将一个简单的.Aps Core项目部署到Docker容器中并被外网访问 说明: 下面的步骤都是建立在宿主服务器系统已经安装配置过Docker容器,安装Docker相对比较简 ...
- 我用asp.net core 部署到docker遇到的问题
1.怎么部署 我是用文件的形式先发布出来,然后把文件拷贝到服务器上部署到docker中去. 2.端口映射 根据查找到的资料,dockerfile 是不支持指定映射服务器端口的,只能在run的时候用-p ...
- 将.NET Core部署在Docker
转载自:ASP.NET Core 2.1 使用Docker运行 1.新建ASP.NET Core项目 新建一个名为“DockerSample”的ASP.NET Core项目 运行程序,页面如下: 2. ...
- 【Core】.NET Core 部署( Docker + CentOS)
CentOS 下 Docker安装 使用脚本安装 Docker (1)安装docker sudo yum install docker (2)启动docker systemctl start do ...
- 关于.Net Core 部署在Linux下连接SqlServer数据库超时解决办法
.Net Core 在 Linux 下连接 SqlServer 需要 SqlServer2008 SP3或以上版本,或SqlServer2012,或SqlServer2014. 如果SqlServer ...
随机推荐
- libevent学习笔记 —— 第一个程序:计时器
用libevent写个定时器其实步骤不多: 1.初始化libevent 2.设置事件 3.添加事件 4.进入循环 由于定时事件触发之后,默认自动删除,所以如果要一直计时,则要在回调函数中重新添加定时事 ...
- Freebsd10.3 Nginx多版本PHP
服务器上需要使用多个php版本,费了好几天劲,终于有所收获.记录如下: 1.下载php-5.5.37.tar.bz2. 2.tar zvxf php-5.5.37.tar.bz2 -C /usr/l ...
- Myeclipse下集成SVN插件
一.下载SVN插件subclipse 下载地址:http://subclipse.tigris.org/servlets/ProjectDocumentList?folderID=2240 在 ...
- 03.CSS选择器-->交集并集选择器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- h5的classList对象
H5新增属性classList h5中新增了一个classList,原生js可以通过它来判断获取dom节点有无某个class. classList是html元素对象的成员,它的使用非常简单,比如 co ...
- 【js常用DOM方法】
介绍几个js DOM的常用方法 获取元素节点 getElementById getElementsByTagName getElementsByClassName 先写一个简单的网页做测试: /* ...
- 【javascript】javascript设计模式之单例模式
单例模式: 定义:单例模式之所以这么叫,是因为它限制一个类只能有一个实例化对象. 实现方法:判断实例是否存在,如果存在则直接返回,如果不存在就创建了再返回.(确保一个类只有一个实例对象) 特点: 命名 ...
- SpringBoot整合Slf4j+logback日志框架
一.Slf4j简单介绍与优势 1.介绍 Slf4j的全称是Simple Loging Facade For Java(Java简单日志门面),它仅仅是一个为Java程序提供日志输出的统一接口,并不是一 ...
- Vue.js双向绑定原理
Vue.js最核心的功能有两个,一个是响应式的数据绑定系统,另一个是组件系统.本文仅仅探究双向绑定是怎样实现的.先讲涉及的知识点,再用简化的代码实现一个简单的hello world示例. 一.访问器属 ...
- 基于Vue的WebApp项目开发(三)
实现根组件通用的头部和底部样式 明白由webpack搭建起来的Vue项目的执行流程,那么就可以知道实现这个需要只要在根组件和入口文件上做“手脚”即可 <!--以后项目的根组件--> < ...