利用docker-compose搭建AspNetCore开发环境
使用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所在的目录
- 利用pipework为docker容器设置固定IP
- 利用docker搭建gitlab代码仓库 推荐
- 利用gitlab、maven、docker自动构建web应用
- 利用gitlab、maven、docker自动构建web应用
- win7下利用DockerToolBox安装Docker步骤
- 有容云:实战总结之 利用Docker、Docker Compose &Rancher构建持续部署
- 【Docker】利用数据卷容器来备份、恢复、迁移数据卷
- springboot 利用 docker-maven插件生成docker镜像并推送到镜像仓库
- 利用Docker搭建gitlab
- 利用Docker制作Nginx+PHP镜像的步骤详解
- 利用docker搭建LAMP运行环境教程详解
- 利用内核cgroup机制轻松实现类似docker的系统资源管控
- tomcat利用setenv对内存的限制和docker中tomcat内存的优雅配置
- ubuntu14.04利用aliyun安装docker
- docker利用WebHook实现持续集成
- 利用Volume在主机和Docker容器文件传输。
- 利用SpringCloud和Docker搭建普通互联网应用架构
- 利用SpringCloud和Docker搭建普通互联网应用架构
- 利用Dockerfile构建docker镜像
- 详解利用Dockerfile构建mysql镜像并实现数据的初始化及权限设置