安装Docker环境

参考本人这篇《CentOS 7 下Docker的安装》文章进行安装以及环境配置,这里不做赘述。

通过.NetCore开发WebApi项目

1. 创建.Net Core Web项目,如下图所示:

这里我们选择Web API模板进行项目创建,为了简单起见,我们不做身份验证,也不选择 Host in cloud,点击ok项目及创建好

默认的项目文件结构如图所示:

在cmd 执行dotnet restore 恢复依赖包

运行项目,在浏览器就可以查看到结果

至此,一个简单的.Net Core开发的Web API项目就做好了

现在我们就把它放到Docker中运行。

Docker中运行

1. 首先我们先修改一下项目文件,主要是Program.cs和project.json

在Program.cs文件中加 .UseUrls("http://*:9001")是为了让来自所有IP的请求都可以访问这个API,当然也可以写成.UseUrls("http://0.0.0.0:9001") 作用一样,9001是公布出去的端口号。

另外一个修改的文件就是project.json,注释掉type那行以及scripts。添加

"runtimes": {
    "debian.8-x64": { }
  }

因为我这里代码目标运行的机器是debian系统的docker镜像,所以runtimes写成了debian.8-x64。你可以按照你实际情况配置

2. 发布程序到文件系统

发布成功后,会在项目目录下面生成发布好的文件

将发布成功的文件打个压缩包,上传到Linux机器上,并且解压到一个目录中, 进入到这个目录中

新建一个Dockerfile文件 <touch Dockerfile>, 这个文件的作用是构建一个Docker运行镜像。其中所需要填写的内容如下:


 FROM microsoft/dotnet:latest

 RUN mkdir -p /usr/src/app/DockerTest

 COPY . /usr/src/app/DockerTest

 WORKDIR /usr/src/app/DockerTest

 EXPOSE 

 CMD ["dotnet", "DockerTest.dll", "--server.urls", "http://*:9002"]
上面内容第1行代表在microsoft/dotnet:latest基础上面构建Docker镜像(这个微软dotnet镜像是以debian系统构建生成的)

第2行是表示新建一个DockerTest目录

第3行是将当前目录下面的所有文件都复制到刚才新建的DockerTest目录下面

第4行是将程序工作目录切换到DockerTest

第5行是将9002端口公布出去

第6行是执行dotnet DockerTest.dll 命令

Dockerfile文件编辑好后,执行docker build -t docker_test . 如下图所示生成docker_test镜像文件

通过docker images命令可以查看刚才新建的docker_test镜像

运行docker_test镜像创建出来的容器

通过浏览器访问此docker容器Host起来的service

在Docker容器中运行.Net Core web Api项目的更多相关文章

  1. Docker容器中运行ASP.NET Core

    在Linux和Windows的Docker容器中运行ASP.NET Core 译者序:其实过去这周我都在研究这方面的内容,结果周末有事没有来得及总结为文章,Scott Hanselman就捷足先登了. ...

  2. .Net Core 3.0 的 docker 容器中运行 无法 访问 Oracle数据库

    .Net  Core 3.0 的 docker 容器中运行 无法 访问 Oracle数据库  , 一直报下面的错误 ORA-00604: error occurred at recursive SQL ...

  3. .NetCore下使用IdentityServer4 & JwtBearer认证授权在CentOS Docker容器中运行遇到的坑及填坑

    今天我把WebAPI部署到CentOS Docker容器中运行,发现原有在Windows下允许的JWTBearer配置出现了问题 在Window下我一直使用这个配置,没有问题 services.Add ...

  4. 一个docker容器中运行多个服务还是弄一堆docker容器运行?

    不建议直接在单个 Docker 容器中运行多个程序. 以 2017年 10 月18 日 Docker 官方支持 Kubernetes 为分水岭计算,Kubernetes 赢得容器编排之战的最终胜利已经 ...

  5. 在docker容器中运行hello world!

    在docker容器中运行hello world! docker容器可以理解为在沙盒中运行的进程.这个沙盒包含了该进程运行所必须的资源,包括文件系统.系统类库.shell 环境等等.但这个沙盒默认是不会 ...

  6. Elasticsearch核心技术(1)--- Docker容器中运行ES、Kibana、Cerebro

    Docker容器中运行ES,Kibana,Cerebro和Logstash安装与数据导入ES 想加强ES有关的知识,看了阮一鸣老师讲的<Elasticsearch核心技术与实战>收获很大, ...

  7. docker_facenet_image在Docker容器中运行Facenet环境搭建

    对开发和运维人员来说,可能最梦寐以求的就是一次性地创建或配置,可以在任意环境.任意时间让应用正常运行.而Docker恰恰是可以实现这一终极目标的瑞士军刀. 具体来说,Docker在开发和运维过程中,具 ...

  8. 详解Net Core Web Api项目与在NginX下发布

    前言 本文将介绍Net Core的一些基础知识和如何NginX下发布Net Core的WebApi项目. 测试环境 操作系统:windows 10 开发工具:visual studio 2019 框架 ...

  9. 在Linux和Windows的Docker容器中运行ASP.NET Core

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 译者序:其实过去这周我都在研究这方面的内容,结果周末有事没有来得及总结为文章,Scott H ...

随机推荐

  1. 基于Groovy应用程序的spring boot

    spring boot CLI 它是使用Spring Boot的最简单的和快速的的方法.他是一个基于Groovy脚本的命令工具.可以按照以下步骤安装次工具: 1.去spring官网下载 http:// ...

  2. SAS PROC MCMC example in R: Logistic Regression Random-Effects Model(转)

    In this post I will run SAS example Logistic Regression Random-Effects Model in four R based solutio ...

  3. 【2017-05-30】WebForm文件上传

    用 FileUpload控件进行上传文件. <asp:FileUpload ID="FileUpload1"  runat="server" /> ...

  4. Java File类应用:递归遍历文件夹和递归删除文件

    要求: 1)采用递归遍历文件夹下的所有文件,包括子文件夹下的文件 2)采用递归删除文件下的所有文件 注意: 以下递归删除文件的方法,只能删除文件,所有的文件夹都还会存在 若要删除正文文件夹,可以在递归 ...

  5. 机器学习:Python实现聚类算法(三)之总结

    考虑到学习知识的顺序及效率问题,所以后续的几种聚类方法不再详细讲解原理,也不再写python实现的源代码,只介绍下算法的基本思路,使大家对每种算法有个直观的印象,从而可以更好的理解函数中参数的意义及作 ...

  6. activeMQ的安装

    1.下载ActiveMQ 去官方网站下载:http://activemq.apache.org/ 2.运行ActiveMQ 解压缩apache-activemq-5.5.1-bin.zip, 修改配置 ...

  7. java数据结构(二叉树)

    Node节点: public class Node { public long data; public String sData; public Node leftChild; public Nod ...

  8. Awesome Hadoop

    A curated list of amazingly awesome Hadoop and Hadoop ecosystem resources. Inspired by Awesome PHP,  ...

  9. JavaBean在jsp中的使用

    JavaBean在Jsp中的引用: 1.用<jsp:useBean>标记: <jsp:useBean id="name" class="classnam ...

  10. java之真假分页

    真分页(要的是什么范围的记录在数据库查的时候就只查这几条记录):select s.* from (select *,row_number() over(order by SLoginId) as ro ...