1. 程式人生 > 實用技巧 >Docker - 2 應用部署使用樣例

Docker - 2 應用部署使用樣例

Docker - 2 應用部署使用樣例

一、部署MySQL

  1. 搜尋mysql映象
docker search mysql
  1. 拉取mysql映象
docker pull mysql:5.6
  1. 建立容器,設定埠對映、目錄對映
# 在/root目錄下建立mysql目錄用於儲存mysql資料資訊
mkdir ~/mysql
cd ~/mysql
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6
  • 引數說明:
    • -p 3307:3306:將容器的 3306 埠對映到宿主機的 3307 埠。
    • -v $PWD/conf:/etc/mysql/conf.d:將主機當前目錄下的 conf/my.cnf 掛載到容器的 /etc/mysql/my.cnf。配置目錄
    • -v $PWD/logs:/logs:將主機當前目錄下的 logs 目錄掛載到容器的 /logs。日誌目錄
    • -v $PWD/data:/var/lib/mysql :將主機當前目錄下的data目錄掛載到容器的 /var/lib/mysql 。資料目錄
    • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 使用者的密碼。
  1. 進入容器,操作mysql
docker exec –it c_mysql /bin/bash
  1. 使用外部機器連線容器中的mysql

二、部署Tomcat

  1. 搜尋tomcat映象
docker search tomcat
  1. 拉取tomcat映象
docker pull tomcat
  1. 建立容器,設定埠對映、目錄對映
# 在/root目錄下建立tomcat目錄用於儲存tomcat資料資訊
mkdir ~/tomcat
cd ~/tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat 
  • 引數說明:

    • -p 8080:8080:將容器的8080埠對映到主機的8080埠

      -v $PWD:/usr/local/tomcat/webapps:將主機中當前目錄掛載到容器的webapps

  1. 使用外部機器訪問tomcat

三、部署Nginx

  1. 搜尋nginx映象
docker search nginx
  1. 拉取nginx映象
docker pull nginx
  1. 建立容器,設定埠對映、目錄對映
# 在/root目錄下建立nginx目錄用於儲存nginx資料資訊
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下建立nginx.conf檔案,貼上下面內容
vim nginx.conf
user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}


docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx

  • 引數說明:
    • -p 80:80:將容器的 80埠對映到宿主機的 80 埠。
    • -v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:將主機當前目錄下的 /conf/nginx.conf 掛載到容器的 :/etc/nginx/nginx.conf。配置目錄
    • -v $PWD/logs:/var/log/nginx:將主機當前目錄下的 logs 目錄掛載到容器的/var/log/nginx。日誌目錄
  1. 使用外部機器訪問nginx

四、部署Redis

  1. 搜尋redis映象
docker search redis

  1. 拉取redis映象
docker pull redis:5.0

  1. 建立容器,設定埠對映
docker run -id --name=c_redis -p 6379:6379 redis:5.0

  1. 使用外部機器連線redis
./redis-cli.exe -h 192.168.149.135 -p 6379

五 、部署 ES+kibana+ik

執行es容器,若沒有該映象則自動下載

docker run --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -d elasticsearch:7.4.0
  • 注意,如果容器啟動失敗,則大部分情況為記憶體問題導致,執行以下命令指定jvm記憶體。
  • 啟動失敗,需要先把原來的容器刪掉,再次建立容器
docker run --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e "ES_JAVA_OPTS=-Xms128m -Xmx512m" -d elasticsearch:7.4.0

說明

-Xms 堆記憶體的最小大小,預設為實體記憶體的1/64

-Xmx 堆記憶體的最大大小,預設為實體記憶體的1/4

-Xmn 堆內新生代的大小。通過這個值也可以得到老生代的大小:-Xmx減去-Xmn

進入es容器配置跨域

  • 進入容器
docker exec -it elasticsearch bash
  • 配置跨域
vi /usr/share/elasticsearch/config/elasticsearch.yml
# 追加以下內容
http.cors.enabled: true
http.cors.allow-origin: "*"
  • 退出並重啟容器
exit
docker restart elasticsearch

安裝ik分詞器

方案一,進入容器手動下載
  • 進入容器
docker exec -it elasticsearch bash
  • 安裝ik分詞器(安裝過程有提示就輸入y)
cd /usr/share/elasticsearch/plugins/
elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.4.0/elasticsearch-analysis-ik-7.4.0.zip
  • 退出並重啟容器
exit
docker restart elasticsearch
方案二,在宿主機下後拷貝至容器內部
  • 下載地址

ik分詞器下載地址

  • 上傳至linux容器
  • 建立目錄elasticsearch,並將zip包移動至該目錄下進行解壓
mkdir elasticsearch
mv elasticsearch-analysis-ik-7.4.0.zip ./elasticsearch
cd elasticsearch/
unzip elasticsearch-analysis-ik-7.4.0.zip
  • 退出到目錄上一級,並將整個目錄拷貝至docker容器中
cd ..
docker cp ./elasticsearch elasticsearch:/usr/share/elasticsearch/plugins
  • 重啟容器
docker restart elasticsearch
執行kibana,若沒有該映象則自動下載
docker run --name kibana --link elasticsearch:elasticsearch -p 5601:5601 -d kibana:7.4.0
驗證安裝成功

http://192.168.200.169:5601/

http://192.168.200.169:9200/

六、 部署RocketMQ

方案一

1. 建立docker-compose.yml配置檔案並編寫
version: '3.5'
services:
  rmqnamesrv:
    image: foxiswho/rocketmq:server-4.5.2
    container_name: rmqnamesrv
    ports:
      - 9876:9876
    volumes:
      - ./logs:/opt/logs
      - ./store:/opt/store
    networks:
        rmq:
          aliases:
            - rmqnamesrv

  rmqbroker:
    image: foxiswho/rocketmq:broker-4.5.2
    container_name: rmqbroker
    ports:
      - 10909:10909
      - 10911:10911
    volumes:
      - ./logs:/opt/logs
      - ./store:/opt/store
      - ./conf/broker.conf:/etc/rocketmq/broker.conf
    environment:
        NAMESRV_ADDR: "rmqnamesrv:9876"
        JAVA_OPTS: " -Duser.home=/opt"
        JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"
    command: mqbroker -c /etc/rocketmq/broker.conf
    depends_on:
      - rmqnamesrv
    networks:
      rmq:
        aliases:
          - rmqbroker

  rmqconsole:
    image: styletang/rocketmq-console-ng
    container_name: rmqconsole
    ports:
      - 8081:8080
    environment:
        JAVA_OPTS: "-Drocketmq.namesrv.addr=rmqnamesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false"
    depends_on:
      - rmqnamesrv
    networks:
      rmq:
        aliases:
          - rmqconsole

networks:
  rmq:
    name: rmq
    driver: bridge
2. 建立conf、logs、store三個資料夾

在與docker-compose.yml同級下面相應的建立三個資料夾conflogsstore

mkdir conf
mkdir logs
mkdir store
3. 在conf下建立broker.conf

conf/broker.conf

# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.  See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License.  You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
#  Unless required by applicable law or agreed to in writing, software
#  distributed under the License is distributed on an "AS IS" BASIS,
#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#  See the License for the specific language governing permissions and
#  limitations under the License.


# 所屬叢集名字
brokerClusterName=DefaultCluster

# broker 名字,注意此處不同的配置檔案填寫的不一樣,如果在 broker-a.properties 使用: broker-a,
# 在 broker-b.properties 使用: broker-b
brokerName=broker-a

# 0 表示 Master,> 0 表示 Slave
brokerId=0

# nameServer地址,分號分割
# namesrvAddr=rocketmq-nameserver1:9876;rocketmq-nameserver2:9876

# 啟動IP,如果 docker 報 com.alibaba.rocketmq.remoting.exception.RemotingConnectException: connect to <192.168.0.120:10909> failed
# 解決方式1 加上一句 producer.setVipChannelEnabled(false);,解決方式2 brokerIP1 設定宿主機IP,不要使用docker 內部IP
brokerIP1=192.168.31.130

# 在傳送訊息時,自動建立伺服器不存在的topic,預設建立的佇列數
defaultTopicQueueNums=4

# 是否允許 Broker 自動建立 Topic,建議線下開啟,線上關閉 !!!這裡仔細看是 false,false,false
autoCreateTopicEnable=true

# 是否允許 Broker 自動建立訂閱組,建議線下開啟,線上關閉
autoCreateSubscriptionGroup=true

# Broker 對外服務的監聽埠
listenPort=10911

# 刪除檔案時間點,預設凌晨4點
deleteWhen=04

# 檔案保留時間,預設48小時
fileReservedTime=120

# commitLog 每個檔案的大小預設1G
mapedFileSizeCommitLog=1073741824

# ConsumeQueue 每個檔案預設存 30W 條,根據業務情況調整
mapedFileSizeConsumeQueue=300000

# destroyMapedFileIntervalForcibly=120000
# redeleteHangedFileInterval=120000
# 檢測物理檔案磁碟空間
diskMaxUsedSpaceRatio=88
# 儲存路徑
# storePathRootDir=/home/ztztdata/rocketmq-all-4.1.0-incubating/store
# commitLog 儲存路徑
# storePathCommitLog=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/commitlog
# 消費佇列儲存
# storePathConsumeQueue=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/consumequeue
# 訊息索引儲存路徑
# storePathIndex=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/index
# checkpoint 檔案儲存路徑
# storeCheckpoint=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/checkpoint
# abort 檔案儲存路徑
# abortFile=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/abort
# 限制的訊息大小
maxMessageSize=65536

# flushCommitLogLeastPages=4
# flushConsumeQueueLeastPages=2
# flushCommitLogThoroughInterval=10000
# flushConsumeQueueThoroughInterval=60000

# Broker 的角色
# - ASYNC_MASTER 非同步複製Master
# - SYNC_MASTER 同步雙寫Master
# - SLAVE
brokerRole=ASYNC_MASTER

# 刷盤方式
# - ASYNC_FLUSH 非同步刷盤
# - SYNC_FLUSH 同步刷盤
flushDiskType=ASYNC_FLUSH

# 發訊息執行緒池數量
# sendMessageThreadPoolNums=128
# 拉訊息執行緒池數量
# pullMessageThreadPoolNums=128
enablePropertyFilter=true

注意:配置檔案中的內容我們只需要改動一點即可,即brokerIP1 這個屬性,我們將其更改為我們本機的ip,可以利用ipconfig進行檢視。

修改完以後我們直接在docker-compose.yml檔案所在的位置輸入命令docker-compose up即可啟動

瀏覽器輸入 http://192.168.31.130:8081

方案二

#部署RocketMQ
#拉取映象
docker pull foxiswho/rocketmq:server-4.5.2
docker pull foxiswho/rocketmq:broker-4.5.2

#建立nameserver容器
docker create -p 9876:9876 --name rmqserver \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m" \
-e "JAVA_OPTS=-Duser.home=/opt" \
-v rmqserver-logs:/opt/logs \
-v rmqserver-store:/opt/store \
foxiswho/rocketmq:server-4.5.2

#建立broker.conf檔案
mkdir -p /itcast/rmq/rmqbroker/conf/
vim /itcast/rmq/rmqbroker/conf/broker.conf
brokerIP1=192.168.31.130
namesrvAddr=192.168.31.130:9876
brokerName=broker_itcast

#建立broker容器
docker create -p 10911:10911 -p 10909:10909 --name rmqbroker \
-e "JAVA_OPTS=-Duser.home=/opt" \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m" \
-v /itcast/rmq/rmqbroker/conf/broker.conf:/etc/rocketmq/broker.conf \
-v rmqbroker-logs:/opt/logs \
-v rmqbroker-store:/opt/store \
foxiswho/rocketmq:broker-4.5.2

#啟動容器
docker start rmqserver rmqbroker

#停止刪除容器
docker stop rmqbroker rmqserver
docker rm rmqbroker rmqserver

#部署RocketMQ的管理工具
docker pull styletang/rocketmq-console-ng:1.0.0

#建立並啟動容器
docker create --name rocketmq-console-ng -e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.31.130:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8082:8080 --restart=always styletang/rocketmq-console-ng:1.0.0