docker虽然能够部署有状态服务,但若是不是有特别须要,仍是建议不要部署有状态服务
K8S同理,也不建议部署有状态服务,如mysql,zk等。
所以手动将zookeeper建立集群提供给dubbo使用java
集群分布:7-11,7-12,7-21
zk是java服务,须要依赖jdkmysql
jdk请自行下载,只要是1.8版本的就能够,rpm安装或二进制安装都可:linux
mkdir /opt/src mkdir /usr/java cd /opt/src tar -xf jdk-8u221-linux-x64.tar.gz -C /usr/java/ ln -s /usr/java/jdk1.8.0_221/ /usr/java/jdk
cat >>/etc/profile <<'EOF' #JAVA HOME export JAVA_HOME=/usr/java/jdk export PATH=$JAVA_HOME/bin:$JAVA_HOME/bin:$PATH export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar EOF # 使环境变量生效 source /etc/profile
验证结果nginx
[root@hdss7-11 ~]# java -version java version "1.8.0_221" Java(TM) SE Runtime Environment (build 1.8.0_221-b11) Java HotSpot(TM) 64-Bit Server VM (build 25.221-b11, mixed mode)
下载地址git
wget https://archive.apache.org/dist/zookeeper/zookeeper-3.4.14/zookeeper-3.4.14.tar.gz tar -zxf zookeeper-3.4.14.tar.gz -C /opt/ ln -s /opt/zookeeper-3.4.14/ /opt/zookeeper
cat >/opt/zookeeper/conf/zoo.cfg <<'EOF' tickTime=2000 initLimit=10 syncLimit=5 dataDir=/data/zookeeper/data dataLogDir=/data/zookeeper/logs clientPort=2181 server.1=zk1.zq.com:2888:3888 server.2=zk2.zq.com:2888:3888 server.3=zk3.zq.com:2888:3888 EOF
建立相关目录sql
mkdir -p /data/zookeeper/data mkdir -p /data/zookeeper/logs
给每一个zk不一样的myid,以便区分主从docker
#7-11上 echo 1 > /data/zookeeper/data/myid #7-12上 echo 2 > /data/zookeeper/data/myid #7-21上 echo 3 > /data/zookeeper/data/myid
到7.11
上增长dns解析记录apache
vi /var/named/zq.com.zone ... zk1 A 10.4.7.11 zk2 A 10.4.7.12 zk3 A 10.4.7.21 #验证结果 ~]# dig -t A zk1.zq.com +short 10.4.7.11
在每台zk机器上都执行此操做架构
/opt/zookeeper/bin/zkServer.sh start
~]# ss -ln|grep 2181 tcp LISTEN 0 50 :::2181 :::*
[root@hdss7-11 ~]# /opt/zookeeper/bin/zkServer.sh status ZooKeeper JMX enabled by default Using config: /opt/zookeeper/bin/../conf/zoo.cfg Mode: follower [root@hdss7-12 ~]# /opt/zookeeper/bin/zkServer.sh status ZooKeeper JMX enabled by default Using config: /opt/zookeeper/bin/../conf/zoo.cfg Mode: leader [root@hdss7-21 ~]# /opt/zookeeper/bin/zkServer.sh status ZooKeeper JMX enabled by default Using config: /opt/zookeeper/bin/../conf/zoo.cfg Mode: follower
到此,zookeeper集群就搭建好了。运维
运维主机上操做
docker pull stanleyws/jre8:8u112 docker tag fa3a085d6ef1 harbor.zq.com/public/jre:8u112 docker push harbor.zq.com/public/jre:8u112
mkdir -p /data/dockerfile/jre8/ cd /data/dockerfile/jre8/
cat >Dockerfile <<'EOF' FROM harbor.zq.com/public/jre:8u112 RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime &&\ echo 'Asia/Shanghai' >/etc/timezone ADD config.yml /opt/prom/config.yml ADD jmx_javaagent-0.3.1.jar /opt/prom/ WORKDIR /opt/project_dir ADD entrypoint.sh /entrypoint.sh CMD ["sh","/entrypoint.sh"] EOF
添加config.yml
此文件是为后面用普罗米修斯监控作准备的
cat >config.yml <<'EOF' --- rules: - pattern: '.*' EOF
下载jmx_javaagent,监控jvm信息:
wget https://repo1.maven.org/maven2/io/prometheus/jmx/jmx_prometheus_javaagent/0.3.1/jmx_prometheus_javaagent-0.3.1.jar -O jmx_javaagent-0.3.1.jar
建立entrypoint.sh启动脚本:
使用exec 来运行java的jar包,可以使脚本将本身的pid 为‘1’ 传递给java进程,避免docker容器因没有前台进程而退出。而且不要加&符。
cat >entrypoint.sh <<'EOF' #!/bin/sh M_OPTS="-Duser.timezone=Asia/Shanghai -javaagent:/opt/prom/jmx_javaagent-0.3.1.jar=$(hostname -i):${M_PORT:-"12346"}:/opt/prom/config.yml" C_OPTS=${C_OPTS} JAR_BALL=${JAR_BALL} exec java -jar ${M_OPTS} ${C_OPTS} ${JAR_BALL} EOF
在harbor中建立名为base
的公开仓库,用来存放本身自定义的底包
docker build . -t harbor.zq.com/base/jre8:8u112 docker push harbor.zq.com/base/jre8:8u112