Docker - 2 應用部署使用樣例
阿新 • • 發佈:2020-12-28
Docker - 2 應用部署使用樣例
一、部署MySQL
- 搜尋mysql映象
docker search mysql
- 拉取mysql映象
docker pull mysql:5.6
- 建立容器,設定埠對映、目錄對映
# 在/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 使用者的密碼。
- 進入容器,操作mysql
docker exec –it c_mysql /bin/bash
- 使用外部機器連線容器中的mysql
二、部署Tomcat
- 搜尋tomcat映象
docker search tomcat
- 拉取tomcat映象
docker pull tomcat
- 建立容器,設定埠對映、目錄對映
# 在/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
-
- 使用外部機器訪問tomcat
三、部署Nginx
- 搜尋nginx映象
docker search nginx
- 拉取nginx映象
docker pull nginx
- 建立容器,設定埠對映、目錄對映
# 在/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。日誌目錄
- 使用外部機器訪問nginx
四、部署Redis
- 搜尋redis映象
docker search redis
- 拉取redis映象
docker pull redis:5.0
- 建立容器,設定埠對映
docker run -id --name=c_redis -p 6379:6379 redis:5.0
- 使用外部機器連線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
方案二,在宿主機下後拷貝至容器內部
- 下載地址
- 上傳至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
驗證安裝成功
六、 部署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
同級下面相應的建立三個資料夾conf
、logs
、store
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