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

[经验分享] load balancer docker解决方案

[复制链接]

尚未签到

发表于 2015-4-18 08:18:32 | 显示全部楼层 |阅读模式
  一.gbalancer_keepalived image创建和container创建
  1.gbalancer_keepalived Dockerfile:






FROM letv:centos6
MAINTAINER yaofaliang
RUN rpm -ivh http://pkg-repo.oss.letv.com/pkgs/centos6/letv-release.noarch.rpm
RUN yum install cronie -y
RUN yum install vim -y
RUN yum install gbalancer -y
RUN yum install keepalived -y
EXPOSE 80 8000 2222 3333
USER root
ADD ./init/init.sh /srv/mcluster/init/init.sh
RUN chmod 755 /srv/mcluster/init/init.sh
ENTRYPOINT /srv/mcluster/init/init.sh && /bin/bash
  
  2.在init目录下创建初始化脚本init.sh,内容如下:






cat > /etc/sysconfig/network-scripts/ifcfg-peth0 > /var/log/gbalancer.log
      exit 1
   fi   
fi
  
  i.添加gbalancer的系统启动脚本






#!/bin/bash
#
# Description:  This shell script takes care of starting and stopping dennis
# Hu Dennis created on Sep. 24th, 2010
#
# Source function library
. /etc/init.d/functions
   
#the service name  for example: dennis
SNAME=gbalancer
   
#the full path and name of the daemon program
#Warning: The name of executable file must be identical with service name
PROG() {
     /usr/bin/gbalancer --config=/etc/gbalancer/configuration.json &>/dev/null &
}
   
kill_gbalancer() {
    kill -9 `ps -ef | grep -v "grep" | grep "/usr/bin/gbalancer --config=/etc/gbalancer/configuration.json" | awk '{print $2}'` &>/dev/null
}
   
# start function
start() {
    #check the daemon status first
    if [ -f /var/lock/subsys/$SNAME ]
    then
        echo "$SNAME is already started!"
        exit 0;
    else
        action "Starting $SNAME ..." PROG
        [ $? -eq 0 ] && touch /var/lock/subsys/$SNAME
        exit 0;
    fi
}
   
#stop function
stop() {
    echo -n "Stopping $SNAME ..."
    kill_gbalancer
    success
    echo
    rm -rf /var/lock/subsys/$SNAME
}
   
case "$1" in
start)
  start
  ;;
stop)
  stop
  ;;
reload|restart)
  stop
  start
  ;;
status)
  status $SNAME
  ;;
*)
  echo $"Usage: $0 {start|stop|restart|status}"
  exit 1
esac
  
  g.启动keepalived和gbalancer服务:






service gbalancer start
service keepalived start
  k .通过vip访问webportal admin和webportal app查看是否可以提供服务。
  

运维网声明 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-58281-1-1.html 上篇帖子: DOCKER,需要进入生产实践 下篇帖子: [Go语言]从Docker源码学习Go——init()方法和identifier首字母大小写区分
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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