前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >asp.netcore 自动挡Docker Nginx Redis(滴滴滴,自动挡)

asp.netcore 自动挡Docker Nginx Redis(滴滴滴,自动挡)

原创
作者头像
HueiFeng
修改2020-02-10 15:04:02
5280
修改2020-02-10 15:04:02
举报
文章被收录于专栏:HueiFeng技术专栏HueiFeng技术专栏

前言

上一章介绍了Docker通过多条命令创建启动运行Docker容器,由此可见这样一个个去创建单独的容器也是相当麻烦的,比如要在某个复杂项目中用DB、缓存、消息等等,这样我们还要去一个个再创建,为此这时候需要用上我们三剑客中的一员大将自动挡的(DockerCompose).Compose是一个用于定义和应用多个容器的工具(镜像、启动命令、端口映射等),一条命令便可配置我们引用中的所有服务.

Base

Image

指定镜像名称或者镜像Id,如果该镜像不存在,会尝试pull下来。

build

指定Dockerfile文件的路径

build: ./dir

也可以是一个对象。

build:

context: ./dir

dockerfile: Dockerfile-alternate

args:

代码语言:txt
复制
buildno: 1
command

覆盖容器启动后默认执行的命令。

command: bundle exec thin -p 3000

该命令也可以是列表,类似于 dockerfile:

command: ["bundle", "exec", "thin", "-p", "3000"]

links

链接到其他服务器中的容器,可以指定服务名称和链接的别名使用SERVICE:ALIAS的形式,或者只指定服务名称

代码语言:txt
复制
  links:
   - db
   - db:database
   - redis
external_links

表示链接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是对于那些提供共享容器或共同服务。格式跟links类似

代码语言:txt
复制
external_links:
  - redis_1
  - project_db_1:mysql
  - project_db_1:postgresql
  
ports

暴露端口信息。使用宿主端口:容器端口的格式,或者仅仅指定容器的端口(此时宿主机将会随机指定端口),类似于docker run -p

代码语言:txt
复制
ports:
 - "3000"
 - "3000-3005"
 - "8000:8000"
 - "9090-9091:8080-8081"
 - "49100:22"
 - "127.0.0.1:8001:8001"
 - "127.0.0.1:5000-5010:5000-5010"
expose

暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机

代码语言:txt
复制
expose:
 - "3000"
 - "8000"volumes卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) 或加上访问模式 (HOST:CONTAINER:ro)

volumes:

Just specify a path and let the Engine create a volume

  • /var/lib/mysql

Specify an absolute path mapping

  • /opt/data:/var/lib/mysql

Path on the host, relative to the Compose file

  • ./cache:/tmp/cache

User-relative path

  • ~/configs:/etc/configs/:ro

Named volume

  • datavolume:/var/lib/mysql##### volumes_from 从另一个服务或者容器挂载卷。可以指定只读或者可读写,如果访问模式没有指定,则默认是可读写。volumes_from:##### environment 设置环境变量。可以使用数组或者字典两种方式。只有一个key的环境变量可以在运行Compose的机器上找到对应的值,这有助于加密的或者特殊主机的值。environment: RACK_ENV: development SHOW: 'true' SESSION_SECRET:
  • service_name
  • service_name:ro
  • container:container_name
  • container:container_name:rw

environment:

  • RACK_ENV=development##### env_file 从文件中获取环境变量,可以为单独的文件路径或列表。如果通过 docker-compose -f FILE 指定了模板文件,则 env_file 中路径会基于模板文件路径。如果有变量名称与 environment 指令冲突,则以envirment 为准。env_file: .env
  • SHOW=true
  • SESSION_SECRET

env_file:

  • ./common.env##### extends 继承另一个服务,基于已有的服务进行扩展。 ##### net 设置网络模式。net: "bridge" net: "host" net: "none" net: "container:service name or container name/id"##### dns 配置dns服务器。可以是一个值,也可以是一个列表。dns: 8.8.8.8 dns:##### dns_search 配置DNS的搜索域,可以是一个值,可以是一个列表。dns_search: example.com dns_search:> ## DockerfileFROM mcr.microsoft.com/dotnet/core/aspnet:2.2-stretch-slim AS base WORKDIR /app EXPOSE 80
  • ./apps/web.env
  • /opt/secrets.env
  • 8.8.8.8
  • 9.9.9.9
  • dc1.example.com
  • dc2.example.com

FROM mcr.microsoft.com/dotnet/core/sdk:2.2-stretch AS build

WORKDIR /src

COPY DockerComposeDemo/DockerComposeDemo.csproj DockerComposeDemo/

RUN dotnet restore "DockerComposeDemo/DockerComposeDemo.csproj"

COPY . .

WORKDIR "/src/DockerComposeDemo"

RUN dotnet build "DockerComposeDemo.csproj" -c Release -o /app

FROM build AS publish

RUN dotnet publish "DockerComposeDemo.csproj" -c Release -o /app

FROM base AS final

WORKDIR /app

COPY --from=publish /app .

ENTRYPOINT "dotnet", "DockerComposeDemo.dll"

代码语言:txt
复制
> ## 编辑 docker-compose.yml

version: '3.4'

services:

dockercomposedemoo:

代码语言:txt
复制
image: ${DOCKER_REGISTRY-}dockercomposedemo
代码语言:txt
复制
build:
代码语言:txt
复制
  context: .
代码语言:txt
复制
  dockerfile: DockerComposeDemo/Dockerfile

redis:

container_name: redis

image: redis

ports:

代码语言:txt
复制
  # 端口映射
代码语言:txt
复制
  - 6379:6379

nginx:

container_name: nginx

image: nginx

ports:

代码语言:txt
复制
  # 端口映射
代码语言:txt
复制
  - 8081:80   volumes:
      - /Users/fenghui/projects/nginx/nginx.conf:/etc/nginx/nginx.conf 
代码语言:txt
复制
加入了redis和nginx镜像,直接用nginx进行部署该项目。
上面也体现了端口的映射以及文件的映射,演示的示例是nginx.conf文件映射(切记一定要共享文件夹)

##### nginx.conf

user nginx;

worker_processes 1;

error_log /var/log/nginx/error.log warn;

pid /var/run/nginx.pid;

events {

代码语言:txt
复制
worker_connections  1024;

}

http {

代码语言:txt
复制
include       /etc/nginx/mime.types;
代码语言:txt
复制
default_type  application/octet-stream;
代码语言:txt
复制
log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
代码语言:txt
复制
                  '$status $body_bytes_sent "$http_referer" '
代码语言:txt
复制
                  '"$http_user_agent" "$http_x_forwarded_for"';
代码语言:txt
复制
access_log  /var/log/nginx/access.log  main;
代码语言:txt
复制
sendfile        on;
代码语言:txt
复制
#tcp_nopush     on;
代码语言:txt
复制
keepalive_timeout  65;
代码语言:txt
复制
#gzip  on;
代码语言:txt
复制
#include /etc/nginx/conf.d/*.conf;
代码语言:txt
复制
    server {
代码语言:txt
复制
    listen       80;
代码语言:txt
复制
    server_name  localhost;
代码语言:txt
复制
    #charset koi8-r;
代码语言:txt
复制
    #access_log  logs/host.access.log  main;
代码语言:txt
复制
    #access_log logs/access.log main;
代码语言:txt
复制
    #error_log logs/error.log;
代码语言:txt
复制
 location / {
代码语言:txt
复制
         proxy_pass http://172.17.0.1:8082;
代码语言:txt
复制
         proxy_http_version 1.1;
代码语言:txt
复制
         proxy_set_header Upgrade $http_upgrade;
代码语言:txt
复制
         proxy_set_header Connection keep-alive;
代码语言:txt
复制
         proxy_set_header Host $http_host;
代码语言:txt
复制
         proxy_cache_bypass $http_upgrade;
代码语言:txt
复制
         proxy_set_header X-Real-IP $remote_addr;
代码语言:txt
复制
         proxy_set_header REMOTE-HOST $remote_addr;
代码语言:txt
复制
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
代码语言:txt
复制
     }
代码语言:txt
复制
}

}

代码语言:txt
复制
创建一个项目,演示访问次数,存储直接用redis存储

![](https://img2018.cnblogs.com/blog/1098068/201910/1098068-20191004185656586-996275480.png)



##### package

``using ServiceStack.Redis;
``

##### redis test

private readonly RedisManagerPool redisManger = new RedisManagerPool("172.17.0.1:6379");

代码语言:txt
复制
    public void OnGet()
代码语言:txt
复制
    {
代码语言:txt
复制
        using (var db = redisManger.GetClient()) {
代码语言:txt
复制
            ViewData["num"] = db.IncrementValue("count");
代码语言:txt
复制
        } 
代码语言:txt
复制
    }
代码语言:txt
复制
aspx

@ViewData["num"]

Run

构建容器

然后打开浏览器输入8081,8081为nginx代理的端口,同时可以通过wappalyzer看见我们的web服务器是nginx。

redis测试成功没问题

使用dockercompose编排工具进行构建容器是不是方便了好多。

概要

参考:https://docs.docker.com/compose/compose-file/

Demo: https://github.com/fhcodegit/DockerCompose

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Just specify a path and let the Engine create a volume
  • Specify an absolute path mapping
  • Path on the host, relative to the Compose file
  • User-relative path
  • Named volume
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档