设为首页 收藏本站
查看: 2330|回复: 0

[经验分享] Docker Stack 部署web集群

[复制链接]

尚未签到

发表于 2018-9-21 09:21:17 | 显示全部楼层 |阅读模式
  Docker越来越成熟,功能也越来越强大。使用Dokcer Stack做服务集群也是非常的方便,docker 自己就提供了负载功能,感觉很方便,就想给大家分享一下,做一个简单的教程。

环境
  我是用了两台centos7的虚拟机来做这个教程他们的ip分别是
  

主服务器:192.168.0.105  // 也是私有仓库服务器  
服务器2: 192.168.0.49
  

  这篇帖子中所有的代码 github地址:https://github.com/lpxxn/godockerswarm

设置Docker Swarm
  我以192.168.0.105做为主服务器,在他上面开启swarm
  

docker swarm init  

  执行命令后会给出加入这个swarm的命令
DSC0000.png

  在192.168.0.49上执行命令加入swarm
  

docker swarm join --token SWMTKN-1-425vswwmb8o34uhnmo58w0k4rfzs5okjtye7mokpqps1vl9ymq-0p6pr2gua7l8a6udb67tfndoo 192.168.0.105:2377  

DSC0001.png

  这样我们就建好了swarm,两台主机现在建立好了关系。

web服务
  web服务是用go语言写一个简单的接口,返回主机的名称:这样方便我们查看是否有负载
  

package main  

  
import (
  

"fmt"  
"log"
  
"net/http"
  
"os"
  
)
  

  
func main() {
  
http.HandleFunc("/hi", func(w http.ResponseWriter, r *http.Request) {
  
hostName, _ := os.Hostname()
  
fmt.Fprintf(w, "HostName: %s", hostName)
  
})
  

  
log.Fatal(http.ListenAndServe(":8000", nil))
  
}
  


Docker file
  看一下dockerfile 文件:
  执行的意思就是基于golang境像,把代码复制到相应文件夹,暴露出端口,运行程序。简单吧
  

FROM golang  

  
# Copy the current directory contents into the container
  
COPY .
/go/src/github.com/lpxxn/godockerswarm/  

  
WORKDIR
/go/src/github.com/lpxxn/godockerswarm/  

  
RUN go build
  

  
EXPOSE
8000  

  
CMD [
"./godockerswarm"]  

  看一下dockerfile 文件所在的文件夹
DSC0002.png

  在这个目录下执行docker build 命令:
  

docker build . -t goweb:1.0  

DSC0003.png

  你可以运行一下新生成的镜像
  

docker run -p 8100:8000 7a7e3  

DSC0004.png




镜像提交到私有仓库
  关于如何搭建私有仓库服务器我这里的就多说了,可以去我之前的帖子看一下
  地址1:http://www.cnblogs.com/li-peng/p/6511331.html
  地址2:https://yq.aliyun.com/articles/303216?spm=5176.8091938.0.0.2ce387dadknIQu
  也可以用harbor自己搭建,这个我还没有做过教程,有时间再写。
  因为集群的上机器是自动从仓库取镜像然后再运行程序,所以需要将我们上面生成的镜像推送到我们的私有仓库上去。我自己搭建的
  使用tag重新命名
  

docker tag goweb:1.0 lpxxn.com:5000/goweb:1.0  

DSC0005.png

  推送
  

docker push lpxxn.com:5000/goweb:1.0  

DSC0006.png


docker-compose 文件
  接下来创建docker-compose.yml文件
  image 就是我们上面创建好的镜像。运行5个应用程序,docker 会自己做负载,端口映射8111,失败时自动重启服务,并且创建了自己的网络,当有多个server服务时这个非常有用。
  里面的具体参数,大家可以看官方教程:
  https://docs.docker.com/compose/compose-file/#dockerfile
  

version: "3"  
services:
  
web:
  
image: lpxxn.com:
5000/goweb:1.0  
deploy:
  
replicas:
5  
resources:
  
limits:
  
cpus:
"0.1"  
memory: 50M
  
restart_policy:
  
condition: on
-failure  
ports:
  

- "8111:8000"  
networks:
  

- gowebnet  
networks:
  
gowebnet:
  


部署应用
  到了最后的阶段了,部属一样很简单,执行deploy命令
  

docker stack deploy -c docker-compose.yml mygoweb  

DSC0007.png

  查看启动的服务
  

docker service ps mygoweb  

DSC0008.png

DSC0009.png


测试服务
  看这些返回的主机名:不一样吧。docker 为我们做了负载了。
DSC00010.png

  这篇帖子中所有的代码 github地址:https://github.com/lpxxn/godockerswarm
  我的博客即将搬运同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-599217-1-1.html 上篇帖子: grpc 入门(一) 下篇帖子: 自己动手开启QUIC
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表