使用docker-compose搭建AspNetCore开发环境

1 使用docker-compose搭建开发环境

我们的目标很简单:使用docker-compose把若干个docker容器组合起来就成了。

首先使用Nginx代理所有的Web程序,这样只需要在主机上监听一个端口就可以了,不污染主机。再组合各Web程序、Redis/Memcached、SqlServerOnLinux。
新建一个目录sites,所有和集群相关的都放在这里,目录结构如下所示

sites
    nginx
        sites-enabled
            default
        Dockerfile
    redis
        Dockerfile
        redis.conf
    docker-compose.yml

新建docker-compose.yml

version: "2"
services:
 redis:
 build: ./redis/
 restart: always
 container_name: mac-redis 
 identity:
 build: ~/identity/src/Web/ #identity项目的Dockerfile所在的目录
 restart: always
 volumes:
  - ~/identity/src/Web/bin/Debug/netcoreapp1.1/publish:/app #把编译好的序集添加到数据卷中
 links:
  - 'ucenter:api.ucenter.com' #因为identity项目依赖ucenter项目,identity目内部通过url:api.ucenter.com调用ucenter的webapi,所以这里要给设置一个和ur一样的别名,这样identity项目访问`api.ucenter.com`就会被转发到ucenter容器。
  - redis
 extra_hosts:
  - "dbserver:192.168.199.143" #之前搭建了一个sqlserver容器,那个是单独放在个Linux机器里面,所以这里就直接通过地址调用,注意要开启远程访问。
 container_name: identity
 logging:
  driver: "json-file"
  options:
  max-size: "50k" #因为随着程序的运行,日志会越来越多,导致每次加载时间越越长,所以规定日志文件大小,节省时间
  max-file: "10"
 ucenter:
 build: ~/UCenter/src/WebAPI #ucenter项目的Dockerfile所在的目录
 restart: always
 volumes:
  - ~/UCenter/src/WebAPI/bin/Debug/netcoreapp1.1/publish:/app
 links:
  - redis
 extra_hosts:
  - "dbserver:192.168.199.143"
 container_name: ucenter
 nginx-host:
 build: ./nginx #nginx的Dockerfile所在的目录
 restart: always
 ports:
  - "80:80" #监听主机的80端口,或者其它的端口都可以
 links:
  - identity
  - ucenter
 volumes:
  - ./nginx/sites-enabled:/etc/nginx/sites-enabled #nginx的配置文件放在据卷中,以后需要改动的时候,重启nginx就可以了,不用重新build
  - /WebCommon:/www/data #各个项目共用的静态文件,一般走cdn的,在开发环境里就nginx代理
 container_name: nginx-host
 logging:
  driver: "json-file"
  options:
  max-size: "50k"
  max-file: "10"

上面在集群中配置了4个服务,一个nginx负责监听主机的80端口,并转发到相应的服务中去。
identity是我开发的项目,依赖于ucenter项目
项目中都依赖redis缓存,还有通过host解析的数据库服务dbserver。

2 下面先搭建nginx服务

sites->nginx目录下面,新建sites-enabled目录,再新建一个名为default的配置文件

server {
 listen 80;
 server_name account.xxx.com; #identity项目的域名
 location / {
 proxy_pass  http://identity; #转发到identity服务处理
 proxy_set_header Host $host;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_connect_timeout 150;
 proxy_send_timeout 100;
 proxy_read_timeout 100;
 proxy_buffers 4 32k;
 client_max_body_size 8m;
 client_body_buffer_size 128;
 }
}

server {
 listen 80;
 server_name ucenter.xxx.com; #ucenter项目的域名
 location / {
 proxy_pass  http://ucenter; #转发到ucenter服务处理
 proxy_set_header Host $host;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_connect_timeout 150;
 proxy_send_timeout 100;
 proxy_read_timeout 100;
 proxy_buffers 4 32k;
 client_max_body_size 8m;
 client_body_buffer_size 128;
 }
}

server {
 listen 80;
 server_name cdn.xxx.com; #这里把静态文件打包成一个服务,替代cdn
 root /www/data;
 location / {
 }
}

这个是nginx的配置文件,主要配置Nginx的代理方式。下面编写生成Nginx的Dockerfile,sites->nginx下面新建Dockerfile

FROM tutum/nginx
VOLUME /etc/nginx/sites-enabled

通过这个Dockerfile就可以创建Nginx了,

3 安装redis

1).再sites下新建目录:mkdir redis

2).vim Dockerfile

FROM redis
COPY redis.conf /usr/local/etc/redis/redis.conf
CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ]

3).vim redis.conf, 复制粘贴redis的配置,这是redis的官方默认配置。

4).docker build -t mac-redis .我给它起了个名字叫mac-redis

5).镜像创建好之后,先测试一下能不能用,docker run -d --name mac-redis mac-redis。这时候mac-redis的容器已经在后台跑起来了,我们再用redis-cli测试这个redis服务,docker run -it --link mac-redis:redis --rm redis redis-cli -h redis -p 6379使用--rm参数,用完就清除这个容器。测试如下:

redis:6379> set key1 value1
OK
redis:6379> get key1
"value1"

看来redis服务没问题,exit退出。再把测试用的redis服务容器也删除掉docker rm -f mac-redis。

4 使用docker跑aspnetcore程序

这个是最简单的了,根据微软的镜像来就行了,园子里也有大量的教程。

在这里我把它们放在集群中,只要在docker-compose.yml中配置各个aspnetcore程序的Dockerfile所在的路径即可,在我们的yml文件中有

build: ~/identity/src/Web/ #identity项目的Dockerfile所在的目录

identity的源代码所在的目录为~/identity/,Dockerfile在其中的src/web里面,如下:

FROM microsoft/aspnetcore:1.1.1
LABEL Name=identity Version=0.0.1
ENV ASPNETCORE_ENVIRONMENT Development
ENTRYPOINT ["dotnet", "Identity.Web.dll"]

如果有多个Dockerfile,可以在yml中指定Dockerfile的名称。

另外一个ucenter的Dockerfile如下:

FROM microsoft/aspnetcore:1.1.1
LABEL Name=ucenter Version=0.0.1
ENTRYPOINT ["dotnet", "UCenter.WebAPI.dll"]

代码修改了之后,dotnet publis && docker restart xxx(xxx就是容器的名称)就生效了。

使用chrome浏览器访问

最后进入sites目录,docker-compose up启动集群,由于nginx监听的是主机的80端口,所以需要把绑定的url指向主机的80端口,一种方法是直接在hosts中加解析,但是不推荐这样做,因为如果要访问线上的项目的话,又要改hosts。为了不污染主机环境,推荐使用chrome浏览器,chrome有多用户功能,因此新建一个用户,使用SwitchyOmega插件,将所需要的URl代理到主机的80端口,这样以后开发的时候用这个chrome的这个用户就可以了,完全不影响主机环境。

利用docker-compose搭建AspNetCore开发环境

在开发环节中,debug是必不可少的需求,所以下篇介绍如何用VSCode在Docker中debug。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

风云阁资源网 Design By www.bgabc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
风云阁资源网 Design By www.bgabc.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。