基于docker搭建测试环境

layout: post

title: 基于docker搭建测试环境

category: 技术

tags: Docker

keywords: Docker shipyard jenkins

简介

当web项目开发完毕后,一般会在测试环境上运行一下,供开发部门调错和测试部门测试。对于具有一定业务规模的公司,几十个上百个web服务,每个服务分别占用一个tomcat目录,配置过程繁琐,且无法集中管理。此外,对于公司的新手来讲,需要一定的背景知识才可以上手。

本文主要讲述基于docker搭建测试环境,或许可以解决部分上述问题。

总体思路

  1. 业务代码(包括Dockerfile文件)通过git提交,使用Jenkins或hudson触发maven编译项目代码、并制作成docker镜像,push到docker镜像服务器。
  2. 登录shipyard,deploy docker容器

业务流程

1、在web项目目录中添加一个Dockerfile文件

FROM tomcat

ADD *.war $TOMCAT_HOME/webapps

# 启动tomcat并监听tomcat日志

CMD bash start.sh

2、创建一个新的hudson job,并build。

3、进入http://shipyard:8080/,通过web ui决定在哪台主机上运行项目实例,并配置映射端口。

基于docker测试环境的安装

jenkin与docker的整合参见:[使用Jenkins来构建Docker容器](http://www.cnblogs.com/Leo_wl/p/4314792.html ""),在此就不班门弄斧了。

该测试环境使用shipyard管理docker镜像和容器(运行web实例)。shipyard, Built on Docker Swarm, Shipyard gives you the ability to manage Docker resources including containers, images, private registries and more.

示例环境描述:在192.168.56.154,192.168.56.155上搭建docker swarm集群,并在192.168.56.154上运行shipyard controller。

安装docker registry

docker run -d -p 5000:5000 -v /root/registry:/tmp/registry registry

安装docker swarm

1、为192.168.56.154,192.168.56.155安装docker,并配置其DOCKER_OPTS="--insecure-registry 私服ip:5000 -H 0.0.0.0:2375 -H unix:///var/run/docker.sock"

2、为192.168.56.154,192.168.56.155搭建zookeeper集群(也可以使用现成的zookeeper集群,其它配置工具etcd等也可)

3、为192.168.56.154,192.168.56.155搭建docker swarm(zookeeper只是其中一种服务发现的方式)

  • root@192.168.56.155 # docker run -ti -d --restart=always --name shipyard-swarm-agent swarm join zk://192.168.56.154,192.168.56.155/swarm --addr=192.168.56.155:2375

这容器工作就是:不停的向zookeeper注册该节点的信息,进入zookeeper命令行可以看到


  1. [zk: 192.168.56.154:2181(CONNECTED) 5] ls /swarm/docker/swarm/nodes 
  2.  
  3. [192.168.56.155:2375] 
  4.  
  5. root@192.168.56.154 # docker run -ti -d --restart=always --name shipyard-swarm-agent swarm join zk://192.168.56.154,192.168.56.155/swarm --addr=192.168.56.154:2375 
  6. root@192.168.56.154 # docker run -ti -d --restart=always --name shipyard-swarm-manager -p 2376:2376 swarm manage zk://192.168.56.154,192.168.56.155/swarm --host tcp://0.0.0.0:2376 

--host tcp://0.0.0.0:2376是设置容器中swarm的http server监听2376端口,-p 2376:2376是将容器的2376端口映射出来,注意2376端口是随意弄的,但该端口不能命名为2375。至此,docker swarm将以192.168.56.154:2376对外提供web服务

shipyard 手动安装步骤

shipyard最新的是3.0.0版,基于docker swarm,其所有组件以docker容器方式运行,有两种部署方式

  1. 自动部署,命令:curl -sSL https://shipyard-project.com/deploy | bash -s
  2. 手动部署,手动依次启动必须的容器组件。

安装过程

1、通过/root/shipyard/data持久化数据库中的数据


  1. root@192.168.56.154 # docker run -ti -d --restart=always --name shipyard-rethinkdb -v /root/shipyard/data:/data rethinkdb 

2、安装shipyard-controller


  1. root@192.168.56.154 # docker run -ti -d --restart=always --name shipyard-controller --link shipyard-rethinkdb:rethinkdb --link shipyard-swarm-manager:swarm -p 8080:8080 shipyard/shipyard:latest server -d tcp://swarm:2376 

需要注意的问题

docker容器一定可以访问宿主机么

理论上是可以访问的,但如果你的宿主机打开了防火墙,对于192.168.56.154执行docker run -ti -d --restart=always --name shipyard-swarm-agent swarm join zk://192.168.56.154,192.168.56.155/swarm --addr=192.168.56.154:2375时,可能会失败,因为swarm容器无法访问192.168.56.154的2376端口

清掉过时的镜像和容器

对于测试环境,业务代码经常更新,因此会产生非常多的docker镜像和容器,需要在合适的实际将其干掉。这涉及到

  1. 镜像的命名策略
  2. 干掉old镜像以及对应container的时机

我采用以下策略:镜像名与jenkins的JOB_NAME相同,在使用jenkins build镜像时,便通过swarm/docker remote RESTFUL API干掉原有的镜像和容器。

优势

  1. docker镜像集中管理(通过web ui进行管理)
  2. docker容器(类似于一个项目实例)集中管理,并可以监控所有实例的运行状态,还可以创建、删除“运行实例”
  3. 减少操作步骤,只需要极少的背景知识(为调试项目,需要懂一点docker命令)。

不足

  1. 运行的web项目只可以调用其它服务(包括redis、rabbitmq等),不能对外提供服务(不是不可以做,而是复杂的端口映射不好管理(可以使用nginx可以解决))。

本文作者:骨汤鸡蛋面

来源:51CTO

时间: 2024-07-29 05:30:10

基于docker搭建测试环境的相关文章

深入浅出Docker(五):基于Fig搭建开发环境

深入浅出Docker(五):基于Fig搭建开发环境 1. 概述 在搭建开发环境时,我们都希望搭建过程能够简单,并且一劳永逸,其他的同事可以复用已经搭建好的开发环境以节省开发时间.而在搭建开发环境时,我们经常会被复杂的配置以及重复的下载安装所困扰.在Docker技术未出现之前,我们可以使用Pupet.Chef.Ansible等配置管理工具把复杂的配置管理起来,这样的管理配置技术仍然是目前比较流行的方式之一.配置管理工具使用的都是自己的DSL语法定义,考虑到环境的复杂性,配置一套通用的开发环境需要针

基于Docker搭建多节点Mesos/Marathon

本文讲的是基于Docker搭建多节点Mesos/Marathon[编者的话]在之前的一篇博客中,我介绍了基于Docker搭建单机版Mesos/Marathon,但是仅仅使用了单个节点.而在这篇博客中,我将介绍基于Docker搭建多节点Mesos/Marathon,开发者可以使用3个节点快速地搭建一个真正的分布式容器集群系统.服务发现和负载均衡是容器集群必不可少的功能,我选择了Marathon LB来实现. GitHub地址: kiwenlau/mesos-marathon-platform 一.

基于Nginx和Docker的测试环境 bara

bara 详细介绍 bara,即日语的バラ,也就是玫瑰. bara是一个基于Nginx和Docker的多版本程序同时在线的简易测试环境,只能单机使用,并且只是一个PoC而已,仅供参考. 简单来说,就是使用Nginx做反向代理,代理到后面的Docker容器,bara能动态创建Nignx配置文件,重启Nginx:而浏览器可以通过设置特殊header(默认为一个字母v)来通过Nginx代理,访问指定的后面的Docker容器. bara概览 bara架构很简单,一个Nginx服务器运行在host上,画图

Mac系统上用Docker搭建lamp环境_docker

前言 docker终于出来mac版本了,赶紧去下载,安装步骤,以前没有Mac版本的时候还要装docker toolbox,现在直接下载安装就好了. 安装好了的样子 状态栏 docker的提示 这个时候就可以到终端里面输入docker命令 $ docker --version Docker version 1.13.0-rc3, build 4d92237 $ docker-compose --version docker-compose version 1.9.0, build 2585387

Linux_基于Docker搭建Redis集群

说明:基于Ubuntu16.04-64bit,开始本教程前,请确保您的Linux系统已安装Docker. 步骤一:Redis镜像安装 1.下载Redis镜像 镜像中心 推荐使用网易蜂巢的镜像中心 地址:https://c.163.com/hub#/m/home/  Redis镜像 docker pull hub.c.163.com/library/redis:latest  安装完成后,使用docker images命令,查看是否安装成功 步骤二:Redis集群搭建 1.运行Redis镜像 分别

搭建基于Docker的PHP开发环境的详细教程_php技巧

现在很多开发者都使用Vagrant来管理他们的虚拟机开发环境,Vagrant确实很酷, 不过也有不少缺点(最主要的是它占用太多的资源).在容器技术.Docker和更多类Docker技术出现后,解决这个问题就变得简单了.免责声明 由于boot2docker的工作方式,本文所述的方法在你的环境中可能无法正常运行.如果需要在非Linux环境下共享文件夹到Docker容器,还需要注意更多额外的细节.后续我会写篇文章专门来介绍实际遇到的问题.怎样才算是好的开发环境 首先,我们得知道什么才是好的开发环境,

测试环境搭建

1,在ubuntu上搭建测试环境 需要安装的软件: sudo chmod 400 ~/.ssh/id_rsa   sudo ./Git.sh -i ~/.ssh/id_rsa clone git@gitlab.rd.chanjet.com:chanjet_web_gov/chanjet_web.git   静态资源: sudo ~/bin/git.sh -i ~/.ssh/id_rsa clone git@gitlab.rd.chanjet.com:zhengjiang/chanjet_web.

基于Docker的PHP开发环境

本文讲的是基于Docker的PHP开发环境,[编者的话]本文作者是Geoffrey,他是一个PHP的Web开发者,喜欢DevOps和Docker.本文主要介绍了如何使用Docker构建PHP的开发环境,文中作者也探讨了构建基于Docker的开发环境应该使用单容器还是多容器,各有什么利弊.推荐PHP开发者阅读. 现在很多开发者都使用Vagrant来管理他们的虚拟机开发环境,Vagrant确实很酷, 不过也有不少缺点(最主要的是它占用太多的资源).在容器技术.Docker和更多类Docker技术出现

基于 Docker 的 PHP 开发环境

基于 Docker 的 PHP 开发环境 [编者的话]本文作者是Geoffrey,他是一个PHP的Web开发者,喜欢DevOps和Docker.本文主要介绍了如何使用Docker构建 PHP的开发环境,文中作者也探讨了构建基于Docker的开发环境应该使用单容器还是多容器,各有什么利弊.推荐PHP开发者阅读. 现在很多开发者都使用Vagrant来管理他们的虚拟机开发环境,Vagrant确实很酷, 不过也有不少缺点(最主要的是它占用太多的资源).在容器技术.Docker和更多类Docker技术出现