zoukankan      html  css  js  c++  java
  • 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

    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代码

    
    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

  • 相关阅读:
    手机模式input框输入框收起键盘失焦后强制让页面归位
    造一个智能语音音箱!!!太简单了【语音智能管家】
    教你搭建一个花卉识别系统(超级简单)
    【语音智能管家】之语音唤醒(附演示视频)
    conda 安装GPU——CUDA
    筹划了几年,我终于开始实现了---语音智能管家
    我爬取了爬虫岗位薪资,分析后发现爬虫真香
    最近爆火的帅小伙丁真在AI面前颜值多少分?
    生物信息学云论坛第十三场报告会
    生物信息学云论坛第十二场报告会
  • 原文地址:https://www.cnblogs.com/yyfh/p/11613763.html
Copyright © 2011-2022 走看看