k8s部署rocketmq 雙主

因爲apache 官網的 docker image 是單點,要實現集羣方式部署。html

 

rocketmq 分爲 nameserver 和 broker , 對於之間調用頻繁的服務,會增長網絡壓力, 因此 考慮又網絡通訊 變成 進程間通訊, 那麼1個pod 中包含兩個container。docker

 

關於rocketmq 下載編譯, https://www.cnblogs.com/fengjian2016/p/10150394.html

拿到 編譯後的  apache-rocketmq , 須要修改一些配置, 例如:apache

1. rm -rf  刪除 rocketmq/bin/*.cmd
2 .把runserver.sh  HEAP_OPTS 變成環境變量, 把runbroker.sh  HEAP_OPTS 變成環境變量

  


3. 指定消息存儲路徑
[root@rocketmq1 conf]#mkdir -p /data/rocketmq/store
[root@rocketmq1 conf]#mkdir -p /data/rocketmq/store/commitlog
[root@rocketmq1 conf]#mkdir -p /data/rocketmq/logs 
4. 指定日誌輸出路徑
/data/rocketmq/conf/ 中的xml文件
sed -i 's#${user.home}#/data/rocketmq/logs#g' *.xml
5. 刪除多餘配置文件 2m-2s 2master 等等, 啓動的時候k8s command 直接指向文件
/data/rocketmq/conf/ 目錄下新建 broker-a.conf broker-b.conf 2個文件

6. 配置修改

  (1) rocketmqHome 修改vim

  (2) namesrvAddr 修改,強調  通一個pod 必須寫localhost 或者 127.0.0.1 要否則調不通centos

 

[root@harbor conf]# cat broker-a.conf 
rocketmqHome=/data/rocketmq
namesrvAddr=localhost:9876;rocketmq2:9876
brokerName=broker-a
brokerClusterName=DefaultCluster
brokerId=0
brokerPermission=6
#在發送消息時,自動建立服務器不存在的topic,默認建立的隊列數
defaultTopicQueueNums=4
#是否容許 Broker 自動建立Topic,建議線下開啓,線上關閉
autoCreateTopicEnable=true
clusterTopicEnable=true
brokerTopicEnable=true
#是否容許 Broker 自動建立訂閱組,建議線下開啓,線上關閉
autoCreateSubscriptionGroup=true
sendMessageThreadPoolNums=1
pullMessageThreadPoolNums=20
queryMessageThreadPoolNums=10
adminBrokerThreadPoolNums=16
clientManageThreadPoolNums=32
consumerManageThreadPoolNums=32
heartbeatThreadPoolNums=2
endTransactionThreadPoolNums=12
flushConsumerOffsetInterval=5000
flushConsumerOffsetHistoryInterval=60000
rejectTransactionMessage=false
fetchNamesrvAddrByAddressServer=false
sendThreadPoolQueueCapacity=10000
pullThreadPoolQueueCapacity=100000
queryThreadPoolQueueCapacity=20000
clientManagerThreadPoolQueueCapacity=1000000
consumerManagerThreadPoolQueueCapacity=1000000
heartbeatThreadPoolQueueCapacity=50000
endTransactionPoolQueueCapacity=100000
filterServerNums=0
longPollingEnable=true
shortPollingTimeMills=1000
notifyConsumerIdsChangedEnable=true
highSpeedMode=false
commercialEnable=true
commercialTimerCount=1
commercialTransCount=1
commercialBigCount=1
commercialBaseCount=1
transferMsgByHeap=true
maxDelayTime=40
regionId=DefaultRegion
registerBrokerTimeoutMills=6000
slaveReadEnable=false
disableConsumeIfConsumerReadSlowly=false
consumerFallbehindThreshold=17179869184
brokerFastFailureEnable=true
waitTimeMillsInSendQueue=200
waitTimeMillsInPullQueue=5000
waitTimeMillsInHeartbeatQueue=31000
waitTimeMillsInTransactionQueue=3000
startAcceptSendRequestTimeStamp=0
traceOn=true
enableCalcFilterBitMap=false
expectConsumerNumUseFilter=32
maxErrorRateOfBloomFilter=20
filterDataCleanTimeSpan=86400000
filterSupportRetry=false
enablePropertyFilter=false
compressedRegister=false
forceRegister=true
registerNameServerPeriod=30000
transactionTimeOut=6000
transactionCheckMax=15
transactionCheckInterval=60000
#Broker 對外服務的監聽端口
listenPort=10911
serverWorkerThreads=8
serverCallbackExecutorThreads=0
serverSelectorThreads=3
serverOnewaySemaphoreValue=256
serverAsyncSemaphoreValue=64
serverChannelMaxIdleTimeSeconds=120
serverSocketSndBufSize=131072
serverSocketRcvBufSize=131072
serverPooledByteBufAllocatorEnable=true
useEpollNativeSelector=false
clientWorkerThreads=4
clientCallbackExecutorThreads=2
clientOnewaySemaphoreValue=65535
clientAsyncSemaphoreValue=65535
connectTimeoutMillis=3000
channelNotActiveInterval=60000
clientChannelMaxIdleTimeSeconds=120
clientSocketSndBufSize=131072
clientSocketRcvBufSize=131072
clientPooledByteBufAllocatorEnable=false
clientCloseSocketIfTimeout=false
useTLS=false
storePathRootDir=/data/rocketmq/store
storePathCommitLog=/root/rocketmq/store/commitlog
#commitLog每一個文件的大小默認1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每一個文件默認存60W條,根據業務狀況調整,
mapedFileSizeConsumeQueue=3000000
enableConsumeQueueExt=false
mappedFileSizeConsumeQueueExt=50331648
bitMapLengthConsumeQueueExt=64
flushIntervalCommitLog=500
commitIntervalCommitLog=200
useReentrantLockWhenPutMessage=false
flushCommitLogTimed=false
flushIntervalConsumeQueue=1000
cleanResourceInterval=10000
deleteCommitLogFilesInterval=100
deleteConsumeQueueFilesInterval=100
destroyMapedFileIntervalForcibly=120000
redeleteHangedFileInterval=120000
#刪除文件時間點,默認凌晨 2點
deleteWhen=02
#檢測物理文件磁盤空間
diskMaxUsedSpaceRatio=75
#文件保留時間,默認 72 小時
fileReservedTime=128
putMsgIndexHightWater=600000
#限制的消息大小
maxMessageSize=65536
checkCRCOnRecover=true
flushCommitLogLeastPages=4
commitCommitLogLeastPages=4
flushLeastPagesWhenWarmMapedFile=4096
flushConsumeQueueLeastPages=2
flushCommitLogThoroughInterval=10000
commitCommitLogThoroughInterval=200
flushConsumeQueueThoroughInterval=60000
maxTransferBytesOnMessageInMemory=262144
maxTransferCountOnMessageInMemory=32
maxTransferBytesOnMessageInDisk=65536
maxTransferCountOnMessageInDisk=8
accessMessageInMemoryMaxRatio=40
messageIndexEnable=true
maxHashSlotNum=5000000
maxIndexNum=20000000
maxMsgsNumBatch=64
messageIndexSafe=false
haListenPort=10912
haSendHeartbeatInterval=5000
haHousekeepingInterval=20000
haTransferBatchSize=32768
haMasterAddress=
haSlaveFallbehindMax=268435456
brokerRole=ASYNC_MASTER
flushDiskType=ASYNC_FLUSH
syncFlushTimeout=5000
messageDelayLevel=1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h
flushDelayOffsetInterval=10000
cleanFileForciblyEnable=true
warmMapedFileEnable=false
offsetCheckInSlave=false
debugLockEnable=false
duplicationEnable=false
diskFallRecorded=true
osPageCacheBusyTimeOutMills=1000
defaultQueryMaxNum=32
transientStorePoolEnable=false
transientStorePoolSize=5
fastFailIfNoBufferInStorePool=false

 

[root@harbor conf]# cat broker-b.conf 
rocketmqHome=/data/rocketmq
namesrvAddr=rocketmq1:9876;localhost:9876
brokerName=broker-b
brokerClusterName=DefaultCluster
brokerId=0
brokerPermission=6
#在發送消息時,自動建立服務器不存在的topic,默認建立的隊列數
defaultTopicQueueNums=4
#是否容許 Broker 自動建立Topic,建議線下開啓,線上關閉
autoCreateTopicEnable=true
clusterTopicEnable=true
brokerTopicEnable=true
#是否容許 Broker 自動建立訂閱組,建議線下開啓,線上關閉
autoCreateSubscriptionGroup=true
sendMessageThreadPoolNums=1
pullMessageThreadPoolNums=20
queryMessageThreadPoolNums=10
adminBrokerThreadPoolNums=16
clientManageThreadPoolNums=32
consumerManageThreadPoolNums=32
heartbeatThreadPoolNums=2
endTransactionThreadPoolNums=12
flushConsumerOffsetInterval=5000
flushConsumerOffsetHistoryInterval=60000
rejectTransactionMessage=false
fetchNamesrvAddrByAddressServer=false
sendThreadPoolQueueCapacity=10000
pullThreadPoolQueueCapacity=100000
queryThreadPoolQueueCapacity=20000
clientManagerThreadPoolQueueCapacity=1000000
consumerManagerThreadPoolQueueCapacity=1000000
heartbeatThreadPoolQueueCapacity=50000
endTransactionPoolQueueCapacity=100000
filterServerNums=0
longPollingEnable=true
shortPollingTimeMills=1000
notifyConsumerIdsChangedEnable=true
highSpeedMode=false
commercialEnable=true
commercialTimerCount=1
commercialTransCount=1
commercialBigCount=1
commercialBaseCount=1
transferMsgByHeap=true
maxDelayTime=40
regionId=DefaultRegion
registerBrokerTimeoutMills=6000
slaveReadEnable=false
disableConsumeIfConsumerReadSlowly=false
consumerFallbehindThreshold=17179869184
brokerFastFailureEnable=true
waitTimeMillsInSendQueue=200
waitTimeMillsInPullQueue=5000
waitTimeMillsInHeartbeatQueue=31000
waitTimeMillsInTransactionQueue=3000
startAcceptSendRequestTimeStamp=0
traceOn=true
enableCalcFilterBitMap=false
expectConsumerNumUseFilter=32
maxErrorRateOfBloomFilter=20
filterDataCleanTimeSpan=86400000
filterSupportRetry=false
enablePropertyFilter=false
compressedRegister=false
forceRegister=true
registerNameServerPeriod=30000
transactionTimeOut=6000
transactionCheckMax=15
transactionCheckInterval=60000
#Broker 對外服務的監聽端口
listenPort=10911
serverWorkerThreads=8
serverCallbackExecutorThreads=0
serverSelectorThreads=3
serverOnewaySemaphoreValue=256
serverAsyncSemaphoreValue=64
serverChannelMaxIdleTimeSeconds=120
serverSocketSndBufSize=131072
serverSocketRcvBufSize=131072
serverPooledByteBufAllocatorEnable=true
useEpollNativeSelector=false
clientWorkerThreads=4
clientCallbackExecutorThreads=2
clientOnewaySemaphoreValue=65535
clientAsyncSemaphoreValue=65535
connectTimeoutMillis=3000
channelNotActiveInterval=60000
clientChannelMaxIdleTimeSeconds=120
clientSocketSndBufSize=131072
clientSocketRcvBufSize=131072
clientPooledByteBufAllocatorEnable=false
clientCloseSocketIfTimeout=false
useTLS=false
storePathRootDir=/data/rocketmq/store
storePathCommitLog=/root/rocketmq/store/commitlog
#commitLog每一個文件的大小默認1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每一個文件默認存60W條,根據業務狀況調整,
mapedFileSizeConsumeQueue=3000000
enableConsumeQueueExt=false
mappedFileSizeConsumeQueueExt=50331648
bitMapLengthConsumeQueueExt=64
flushIntervalCommitLog=500
commitIntervalCommitLog=200
useReentrantLockWhenPutMessage=false
flushCommitLogTimed=false
flushIntervalConsumeQueue=1000
cleanResourceInterval=10000
deleteCommitLogFilesInterval=100
deleteConsumeQueueFilesInterval=100
destroyMapedFileIntervalForcibly=120000
redeleteHangedFileInterval=120000
#刪除文件時間點,默認凌晨 2點
deleteWhen=02
#檢測物理文件磁盤空間
diskMaxUsedSpaceRatio=75
#文件保留時間,默認 72 小時
fileReservedTime=128
putMsgIndexHightWater=600000
#限制的消息大小
maxMessageSize=65536
checkCRCOnRecover=true
flushCommitLogLeastPages=4
commitCommitLogLeastPages=4
flushLeastPagesWhenWarmMapedFile=4096
flushConsumeQueueLeastPages=2
flushCommitLogThoroughInterval=10000
commitCommitLogThoroughInterval=200
flushConsumeQueueThoroughInterval=60000
maxTransferBytesOnMessageInMemory=262144
maxTransferCountOnMessageInMemory=32
maxTransferBytesOnMessageInDisk=65536
maxTransferCountOnMessageInDisk=8
accessMessageInMemoryMaxRatio=40
messageIndexEnable=true
maxHashSlotNum=5000000
maxIndexNum=20000000
maxMsgsNumBatch=64
messageIndexSafe=false
haListenPort=10912
haSendHeartbeatInterval=5000
haHousekeepingInterval=20000
haTransferBatchSize=32768
haMasterAddress=
haSlaveFallbehindMax=268435456
brokerRole=ASYNC_MASTER
flushDiskType=ASYNC_FLUSH
syncFlushTimeout=5000
messageDelayLevel=1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h
flushDelayOffsetInterval=10000
cleanFileForciblyEnable=true
warmMapedFileEnable=false
offsetCheckInSlave=false
debugLockEnable=false
duplicationEnable=false
diskFallRecorded=true
osPageCacheBusyTimeOutMills=1000
defaultQueryMaxNum=32
transientStorePoolEnable=false
transientStorePoolSize=5
fastFailIfNoBufferInStorePool=false

 

broker Dockerfileapi

[root@harbor rocketmq-broker]# cat Dockerfile 
FROM centos

MAINTAINER fengjian <fengjian@senyint.com>

ENV TZ "Asia/Shanghai"
ENV TERM xterm
ENV MALLOC_ARENA_MAX=1
ENV JAVA_HOME /data/jdk
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /data/tomcat
ENV CATALINA_BASE /data/tomcat
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
ENV ROCKETMQ_HOME /data/rocketmq

RUN rm /etc/yum.repos.d/* -rf
ADD Centos-7.repo /etc/yum.repos.d/
ADD epel.repo /etc/yum.repos.d/
RUN yum clean all
RUN yum -y install net-tools bind-utils sysstat

ADD localtime  /etc/
ADD jdk.tar.gz /data
ADD profile /etc
ADD sysctl.conf /etc
ADD 20-nproc.conf /etc/security/limits.d/
ADD limits.conf /etc/security/

ADD rocketmq.tar.gz /data/
WORKDIR ${ROCKETMQ_HOME}/bin

EXPOSE 10909 10911

 

 

nameserver  Dockerfiletomcat

FROM centos

MAINTAINER fengjian <fengjian@senyint.com>

ENV TZ "Asia/Shanghai"
ENV TERM xterm
ENV MALLOC_ARENA_MAX=1
ENV JAVA_HOME /data/jdk
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /data/tomcat
ENV CATALINA_BASE /data/tomcat
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
ENV ROCKETMQ_HOME /data/rocketmq

RUN rm /etc/yum.repos.d/* -rf
ADD Centos-7.repo /etc/yum.repos.d/
ADD epel.repo /etc/yum.repos.d/
RUN yum clean all
RUN yum -y install net-tools bind-utils sysstat

ADD localtime  /etc/
ADD jdk.tar.gz /data
ADD profile /etc
ADD sysctl.conf /etc
ADD 20-nproc.conf /etc/security/limits.d/
ADD limits.conf /etc/security/

ADD rocketmq.tar.gz /data/
WORKDIR ${ROCKETMQ_HOME}/bin

EXPOSE 9876

ENTRYPOINT ["sh","mqnamesrv"]

 

cat ceph-rocketmq1-pvc.yaml服務器

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: rocketmq1-brokerstore-pvc
  annotations:
    volume.beta.kubernetes.io/storage-class: ceph-rbd-rocketmq
spec:
  accessModes:
  - ReadWriteOnce  #必須寫ReadWriteOnce,不然報錯。
  resources:
    requests:
      storage: 20Gi
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: rocketmq1-brokerlog-pvc
  annotations:
    volume.beta.kubernetes.io/storage-class: ceph-rbd-rocketmq
spec:
  accessModes:
  - ReadWriteOnce  #必須寫ReadWriteOnce,不然報錯。
  resources:
    requests:
      storage: 20Gi
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: rocketmq1-namesrvlog-pvc
  annotations:
    volume.beta.kubernetes.io/storage-class: ceph-rbd-rocketmq
spec:
  accessModes:
  - ReadWriteOnce  #必須寫ReadWriteOnce,不然報錯。
  resources:
    requests:
      storage: 20Gi

 

rocketmq1 yaml文件網絡

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: rocketmq1
spec:
  replicas: 1
  template:
    metadata:
     labels:
       app: rocketmq1
    spec:
      containers:
      - name: namesrv
        image: 192.168.200.10/fengjian/rocketmq-nameserver:4.3
        imagePullPolicy: Always
        ports:
          - containerPort: 9876
        env:
        - name: ROCKETMQ_HEAP_OPTS
          value : "-Xms1g -Xmx1g -Xmn512m"
        volumeMounts:
        - name: rocketmq1namesrvlog
          mountPath: /data/rocketmq/logs
      - name: broker
        image: 192.168.200.10/fengjian/rocketmq-broker:4.3
        imagePullPolicy: Always
        ports:
          - name: brockerserver
            containerPort: 10909
          - name: brockerslave
            containerPort: 10911
        command: ["/data/rocketmq/bin/mqbroker"]
        args: ["-c", "/data/rocketmq/conf/broker-a.conf"]
        env:
        - name: ROCKETMQ_HEAP_OPTS
          value : "-Xms2g -Xmx2g -Xmn1g"
        volumeMounts:
          - name: brokerlogs
            mountPath: /data/rocketmq/logs
          - name: brokerstore
            mountPath: /data/rocketmq/store
      volumes:
      - name: rocketmq1namesrvlog
        persistentVolumeClaim:
          claimName: rocketmq1-namesrvlog-pvc
      - name: brokerlogs
        persistentVolumeClaim:
          claimName: rocketmq1-brokerlog-pvc
      - name: brokerstore
        persistentVolumeClaim:
          claimName: rocketmq1-brokerstore-pvc


---
apiVersion: v1
kind: Service
metadata:
  name: rocketmq1
spec:
  ports:
  - name: brokerslave
    port: 10909
    protocol: TCP
    targetPort: 10909
  - name: brokerserver
    port: 10911
    protocol: TCP
    targetPort: 10911
  - name: namesrvport
    port: 9876
    protocol: TCP
    targetPort: 9876
  selector:
    app: rocketmq1

 

 

還要提早定義pvc 卷app

vim  rocketmq2.yaml

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: rocketmq1
spec:
  replicas: 1
  template:
    metadata:
     labels:
       app: rocketmq1
    spec:
      containers:
      - name: namesrv
        image: 192.168.200.10/fengjian/rocketmq-nameserver:4.3
        imagePullPolicy: Always
        ports:
          - containerPort: 9876
        env:
        - name: ROCKETMQ_HEAP_OPTS
          value : "-Xms1g -Xmx1g -Xmn512m"
        volumeMounts:
        - name: rocketmq1namesrvlog
          mountPath: /data/rocketmq/logs
      - name: broker
        image: 192.168.200.10/fengjian/rocketmq-broker:4.3
        imagePullPolicy: Always
        ports:
          - name: brockerserver
            containerPort: 10909
          - name: brockerslave
            containerPort: 10911
        command: ["/data/rocketmq/bin/mqbroker"]
        args: ["-c", "/data/rocketmq/conf/broker-b.conf"]
        env:
        - name: ROCKETMQ_HEAP_OPTS
          value : "-Xms2g -Xmx2g -Xmn1g"
        volumeMounts:
          - name: brokerlogs
            mountPath: /data/rocketmq/logs
          - name: brokerstore
            mountPath: /data/rocketmq/store
      volumes:
      - name: rocketmq1namesrvlog
        persistentVolumeClaim:
          claimName: rocketmq1-namesrvlog-pvc
      - name: brokerlogs
        persistentVolumeClaim:
          claimName: rocketmq1-brokerlog-pvc
      - name: brokerstore
        persistentVolumeClaim:
          claimName: rocketmq1-brokerstore-pvc


---
apiVersion: v1
kind: Service
metadata:
  name: rocketmq1
spec:
  ports:
  - name: brokerslave
    port: 10909
    protocol: TCP
    targetPort: 10909
  - name: brokerserver
    port: 10911
    protocol: TCP
    targetPort: 10911
  - name: namesrvport
    port: 9876
    protocol: TCP
    targetPort: 9876
  selector:
    app: rocketmq1
相關文章
相關標籤/搜索