码迷,mamicode.com
首页 > Web开发 > 详细

asp.netcore 3.0 Docker Nginx(震惊,原来docker是这样的!)

时间:2019-11-30 00:19:21      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:名称   erer   如何   镜像   挂载   开发人员   sea   虚拟目录   string   

原文:asp.netcore 3.0 Docker Nginx(震惊,原来docker是这样的!)

引言

Docker发布于2013年,Docker是dotCloud公司创始人在法国期间发起的一个公司内部项目,他是dotCloud多年云技术的一个革新.Docker在容器基础上进行了一步的封装,从网络进程到网络互连到进程隔离极大的减少了容器的创建和维护,Docker比虚拟机技术更加便捷.
Docker是个跨时代的开源项目,他释放了虚拟化的威力,降低了云计算的开发成本,可以让线上线下的部署的成本变低,无论是开发人员还是运维等信息人员都有必要去了解和掌握Docker,减少不必要的时间成本,远离它(996),当然Docker在如火如荼的时代也成为了面试的加分项.

技术图片

Base

仓库

仓库是放镜像的地方,同时我们可以往里推镜像,同一个镜像也可以有多个版本(tag),也就是标签

镜像

镜像其实是将应用打包运行的环境,他是一个轻量级的(实际开发中可以将镜像导出并复制到另一台机器.)

拉镜像

docker pull xxx

搜索镜像

docker search xxx

删除镜像

docker rmi xxid

容器

容器相当于类与实例关系,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等 。

正在运行的命令

docker ps

运行命令

docker run xxx /bin/bash

杀掉运行中的容器

docker kill [CONTAINERID]

Docker Nginx

先拉镜像吧

docker pull nginx

搜索一下本地刚才安装的镜像

技术图片

镜像资源有了,那么我再启动一个容器实例

技术图片

  • --name是容器名称
  • -p 是端口进行映射,将本地8010映射到容器内部的80端口
  • -d 设置在后台运行的容器

Run

技术图片

上面运行没问题了,但是并满足不了日常需求,下面我演示一下如何在docker nginx运行静态页面

创建 conf、 www、logs文件夹

  • www:映射nginx容器配置虚拟目录
  • conf:映射nginx配置文件
  • logs:映射日志文件目录

在www目录下面创建一个index.html

将nginx文件配置拷贝到本地目录中

docker cp 2b3869ba5206:/etc/nginx/nginx.conf /docker/conf

部署

docker run -d -p 8011:80 --name blognginx-test-web -v ~/docker/www:/usr/share/nginx/html -v ~/docker/conf/nginx.conf:/etc/nginx/nginx.conf -v ~/docker/logs:/var/log/nginx nginx

技术图片

  • -p 8011:80:将容器的80端口映射到主机的8011端口。

  • --name blognginx-test-web:将容器命名为 blognginx-test-web。

  • -v ~/nginx/www:/usr/share/nginx/html:将www挂载到/usr/share/nginx/html

  • -v ~/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:将nginx.conf挂载到/etc/nginx/nginx.conf

  • -v ~/nginx/logs:/var/log/nginx:logs挂载到/var/log/nginx

Docker DotNetCore

netcore项目发布到docker并且通过nginx进行代理
创建一个项目工程,再创建个文件 Dockerfile

Copy
FROM mcr.microsoft.com/dotnet/core/aspnet:3.0-buster-slim AS base WORKDIR /app EXPOSE 80 EXPOSE 443 FROM base AS final WORKDIR /app COPY . . ENTRYPOINT ["dotnet", "DockerDeployDemo.dll"]

技术图片

docker build -t dockerwebtest . 构建镜像

docker run --name dockerwebtest -p 8012:80 dockerwebtest//运行镜像

技术图片

code 200

通过nginx进行代理,附上nginx代码

Copy
user nginx; worker_processes 1; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main $remote_addr - $remote_user [$time_local] "$request" ‘ $status $body_bytes_sent "$http_referer" ‘ ‘"$http_user_agent" "$http_x_forwarded_for"‘; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; #gzip on; #include /etc/nginx/conf.d/*.conf; server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; #access_log logs/access.log main; #error_log logs/error.log; location / { proxy_pass http://172.17.0.1:8012; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection keep-alive; proxy_set_header Host $http_host; proxy_cache_bypass $http_upgrade; proxy_set_header X-Real-IP $remote_addr; proxy_set_header REMOTE-HOST $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } }

修改完后重新启动8011端口的容器
Run

技术图片

Demo已发布到github上面有需要的可以进行下载.

概要

Demo:https://github.com/fhcodegit/DotNetAspectCore/tree/master/DockerDeployDemo

asp.netcore 3.0 Docker Nginx(震惊,原来docker是这样的!)

标签:名称   erer   如何   镜像   挂载   开发人员   sea   虚拟目录   string   

原文地址:https://www.cnblogs.com/lonelyxmas/p/11960787.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!