欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-08 15:35:59
前言 上一章介绍了Docker通过多条命令创建启动运行Docker容器,由此可见这样一个个去创建单独的容器也是相当麻烦的,比如要在某个复杂项目中用DB、缓存、消息等等,这样我们还要去一个个再创建,为此这时候需要用上我们三剑客中的一员大将自动挡的( DockerCompose ). Compose 是 ......

前言

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

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

base

image

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

build

指定dockerfile文件的路径

build: ./dir

也可以是一个对象。

build: context: ./dir dockerfile: dockerfile-alternate args: buildno: 1

command

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

command: bundle exec thin -p 3000

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

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

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

  links:
   - db
   - db:database
   - redis

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

external_links:
  - redis_1
  - project_db_1:mysql
  - project_db_1:postgresql
  
ports

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

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

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

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:
 - service_name
 - service_name:ro
 - container:container_name
 - container:container_name:rw
environment

设置环境变量。可以使用数组或者字典两种方式。只有一个key的环境变量可以在运行compose的机器上找到对应的值,这有助于加密的或者特殊主机的值。

environment:
  rack_env: development
  show: 'true'
  session_secret:

environment:
  - rack_env=development
  - show=true
  - session_secret
env_file

从文件中获取环境变量,可以为单独的文件路径或列表。如果通过 docker-compose -f file 指定了模板文件,则 env_file 中路径会基于模板文件路径。如果有变量名称与 environment 指令冲突,则以envirment 为准。

env_file: .env

env_file:
  - ./common.env
  - ./apps/web.env
  - /opt/secrets.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:
  - 8.8.8.8
  - 9.9.9.9

配置dns的搜索域,可以是一个值,可以是一个列表。

dns_search: example.com
dns_search:
  - dc1.example.com
  - dc2.example.com

dockerfile

from mcr.microsoft.com/dotnet/core/aspnet:2.2-stretch-slim as base
workdir /app
expose 80

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"]

编辑 docker-compose.yml

version: '3.4'

services:
  dockercomposedemoo:
    image: ${docker_registry-}dockercomposedemo
    build:
      context: .
      dockerfile: dockercomposedemo/dockerfile
   
  redis:
   container_name: redis
   image: redis
   ports:
      # 端口映射
      - 6379:6379

  nginx:
   container_name: nginx
   image: nginx
   ports:
      # 端口映射
      - 8081:80
   volumes:
      - /users/fenghui/projects/nginx/nginx.conf:/etc/nginx/nginx.conf 

加入了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 {
    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:8082;
  
             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;

         }


    }
    
}

创建一个项目,演示访问次数,存储直接用redis存储

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

package

using servicestack.redis;

redis test
 private readonly redismanagerpool redismanger = new redismanagerpool("172.17.0.1:6379");
        public void onget()
        {
            using (var db = redismanger.getclient()) {
                viewdata["num"] = db.incrementvalue("count");
            } 
        }
aspx

@viewdata["num"]

run

构建容器

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

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

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

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

redis测试成功没问题

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

概要

参考:

demo: https://github.com/fhcodegit/dockercompose