1. 程式人生 > >Docker 跑zookeeper

Docker 跑zookeeper

     使用Docker可以快速的安裝和啟動應用, 不需要複雜的安裝, 拉下來就可以使用了,但是呢, 需要掛載檔案目錄, 需要對映埠, 然後, 所以, 就特別的了.加油吧小夥子, 我也在學習, 近期在找工作, 自己平時也沒有做到個什麼, 使用這個來鍛鍊一下自己, 需要大家支援一下, 有問題大家一起討論, 一起進步.

 1、安裝 docker 省略了哈, 不知道的可以找我, 一起學習....

2、使用docker查詢zookeeper, 命令如下:

           docker search zookeeper 

好了, 出來了

3、拉取, 我已經拉取了, 所以就不搞了

命令:docker pull docker.io/zookeeper

4、拉取了, 然後, 製作目錄,然後掛靠到容器裡

分別建立目錄:

mkdir -p /var/local/zookeeper/zk

mkdir -p /var/local/zookeeper/data

mkdir -p /var/local/zookeeper/datalog

mkdir -p /var/local/zookeeper/conf #這個裡面有以下幾個檔案,需要注意以下

 

5、一下有zookeeper conf目錄下的檔案內容, 直接使用linux系統的vim  xxxx,然後把對應的內容拷貝進去就可以了, 內容貼到後面了, 自己弄哈   .

zoo.cfg檔案內容如下:

clientPort=2181

dataDir=/data

dataLogDir=/datalog

tickTime=2000

initLimit=5

syncLimit=2

autopurge.snapRetainCount=3

autopurge.purgeInterval=0

maxClientCnxns=6

 

log4j.properties檔案內容如下:

# Define some default values that can be overridden by system properties

zookeeper.root.logger=INFO, CONSOLE

zookeeper.console.threshold=INFO

zookeeper.log.dir=.

zookeeper.log.file=zookeeper.log

zookeeper.log.threshold=DEBUG

zookeeper.tracelog.dir=.

zookeeper.tracelog.file=zookeeper_trace.log

 

#

# ZooKeeper Logging Configuration

#

 

# Format is "<default threshold> (, <appender>)+

 

# DEFAULT: console appender only

log4j.rootLogger=${zookeeper.root.logger}

 

# Example with rolling log file

#log4j.rootLogger=DEBUG, CONSOLE, ROLLINGFILE

 

# Example with rolling log file and tracing

#log4j.rootLogger=TRACE, CONSOLE, ROLLINGFILE, TRACEFILE

 

#

# Log INFO level and above messages to the console

#

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender

log4j.appender.CONSOLE.Threshold=${zookeeper.console.threshold}

log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout

log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L] - %m%n

 

#

# Add ROLLINGFILE to rootLogger to get log file output

# Log DEBUG level and above messages to a log file

log4j.appender.ROLLINGFILE=org.apache.log4j.RollingFileAppender

log4j.appender.ROLLINGFILE.Threshold=${zookeeper.log.threshold}

log4j.appender.ROLLINGFILE.File=${zookeeper.log.dir}/${zookeeper.log.file}

 

# Max log file size of 10MB

log4j.appender.ROLLINGFILE.MaxFileSize=10MB

# uncomment the next line to limit number of backup files

#log4j.appender.ROLLINGFILE.MaxBackupIndex=10

 

log4j.appender.ROLLINGFILE.layout=org.apache.log4j.PatternLayout

log4j.appender.ROLLINGFILE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L] - %m%n

 

 

#

# Add TRACEFILE to rootLogger to get log file output

# Log DEBUG level and above messages to a log file

log4j.appender.TRACEFILE=org.apache.log4j.FileAppender

log4j.appender.TRACEFILE.Threshold=TRACE

log4j.appender.TRACEFILE.File=${zookeeper.tracelog.dir}/${zookeeper.tracelog.file}

 

log4j.appender.TRACEFILE.layout=org.apache.log4j.PatternLayout

### Notice we are including log4j's NDC here (%x)

log4j.appender.TRACEFILE.layout.ConversionPattern=%d{ISO8601} [myid:%X{myid}] - %-5p [%t:%C{1}@%L][%x] - %m%n

 

 

configuration.xsl檔案內容如下:

<?xml version="1.0"?>

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">

<xsl:output method="html"/>

<xsl:template match="configuration">

<html>

<body>

<table border="1">

<tr>

<td>name</td>

<td>value</td>

<td>description</td>

</tr>

<xsl:for-each select="property">

<tr>

<td><a name="{name}"><xsl:value-of select="name"/></a></td>

<td><xsl:value-of select="value"/></td>

<td><xsl:value-of select="description"/></td>

</tr>

</xsl:for-each>

</table>

</body>

</html>

</xsl:template>

</xsl:stylesheet>

 

 

 

好了, 內容也有了, 現在開始啟動, 啟動命令在下面:

docker run -d -p 12181:2181 --privileged=true -v /var/local/zookeeper/data:/data -v /var/local/zookeeper/datalog:/datalog -v /var/local/zookeeper/conf/:/conf --publish 12181:2181 -p 13888:3888 --name zookeeper docker.io/zookeeper

檢視一下日誌(怎麼檢視? docker logs -f  啟動的時候顯示的那個很長的編碼)

好了,騎起來了, 沒有問題了哦

docker ps 看一下

說明一下, 我的啟動的其他的系統, 所以埠號採用的是在前面加一個1的對映規則, 看你自己怎麼設定哈